AvaloniaUI

This commit is contained in:
Pilzinsel64
2025-11-06 06:21:35 +01:00
parent ba59f7df79
commit 5650cb8fd6
10 changed files with 149 additions and 1 deletions

View File

@@ -0,0 +1,18 @@
using System.Reflection;
namespace Pilz.UI.AvaloniaUI.Symbols.Factories;
public class BasicFactory<T>(string baseName) : SymbolFactory<T> where T : Enum
{
private Assembly? assembly;
public override Assembly GetImageResourceAssembly()
{
return assembly ??= Assembly.Load(baseName);
}
public override string GetImageRessourcePath(T svgImage)
{
return $"{baseName}.Files.{svgImage}.svg";
}
}

View File

@@ -0,0 +1,21 @@
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFramework>net8.0</TargetFramework>
<ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable>
</PropertyGroup>
<PropertyGroup>
<Version>1.0.0</Version>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Pilz.SymbolPacks" Version="1.0.3" />
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\Pilz.UI.Avalonia\Pilz.UI.AvaloniaUI.csproj" />
</ItemGroup>
</Project>

View File

@@ -0,0 +1,13 @@
using Pilz.SymbolPacks.Sets;
using Pilz.UI.AvaloniaUI.Symbols.Factories;
namespace Pilz.UI.AvaloniaUI.Symbols;
public static class Symbols
{
private static ISymbolFactory<SymbolsColor>? color;
private static ISymbolFactory<SymbolsFluent>? fluent;
public static ISymbolFactory<SymbolsColor> Color => color ??= new BasicFactory<SymbolsColor>("Pilz.SymbolPacks.Color");
public static ISymbolFactory<SymbolsFluent> Fluent => fluent ??= new BasicFactory<SymbolsFluent>("Pilz.SymbolPacks.Fluent");
}

View File

@@ -0,0 +1,21 @@
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFramework>net8.0</TargetFramework>
<ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable>
</PropertyGroup>
<PropertyGroup>
<Version>1.0.0</Version>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Avalonia.Svg" Version="11.3.0" />
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\Pilz.UI\Pilz.UI.csproj" />
</ItemGroup>
</Project>

View File

@@ -0,0 +1,10 @@
using Avalonia.Media;
using Pilz.UI.Symbols;
namespace Pilz.UI.AvaloniaUI.Symbols;
public interface ISymbolFactory<TSymbols> : IBaseSymbolFactory<TSymbols>
{
IImage? GetImageSource(TSymbols image);
ISymbolProxy GetImage(TSymbols image);
}

View File

@@ -0,0 +1,8 @@
using Avalonia.Media;
namespace Pilz.UI.AvaloniaUI.Symbols;
public interface ISymbolProxy
{
IImage? GetImageSource();
}

View File

@@ -0,0 +1,26 @@
using Avalonia.Media;
using Avalonia.Svg;
using Pilz.UI.Symbols;
namespace Pilz.UI.AvaloniaUI.Symbols;
public abstract class SymbolFactory<TSymbols> : BaseSymbolFactory<TSymbols>, ISymbolFactory<TSymbols>
{
public IImage? GetImageSource(TSymbols image)
{
using var stream = GetImageRessourceStream(image);
if (stream is null)
return null;
return new SvgImage
{
Source = SvgSource.Load(stream),
};
}
public ISymbolProxy GetImage(TSymbols image)
{
return new SymbolProxy<TSymbols>(this, image);
}
}

View File

@@ -0,0 +1,11 @@
using Avalonia.Media;
namespace Pilz.UI.AvaloniaUI.Symbols;
public class SymbolProxy<TSymbols>(SymbolFactory<TSymbols> factory, TSymbols image) : ISymbolProxy
{
public IImage? GetImageSource()
{
return factory.GetImageSource(image);
}
}

View File

@@ -8,7 +8,7 @@
</PropertyGroup>
<PropertyGroup>
<Version>3.1.0</Version>
<Version>3.1.1</Version>
</PropertyGroup>
</Project>

View File

@@ -53,6 +53,10 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Pilz.UI", "Pilz.UI\Pilz.UI.
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Pilz.Plugins.Advanced.UI.Gtk", "Pilz.Plugins.Advanced.UI.Gtk\Pilz.Plugins.Advanced.UI.Gtk.csproj", "{F9CA6B5C-F14F-418D-9617-6007ED75E82F}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Pilz.UI.AvaloniaUI.Symbols", "Pilz.UI.AvaloniaUI.Symbols\Pilz.UI.AvaloniaUI.Symbols.csproj", "{C425EA21-F478-4FDB-B05D-5AE2A2FE1865}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Pilz.UI.AvaloniaUI", "Pilz.UI.AvaloniaUI\Pilz.UI.AvaloniaUI.csproj", "{919DC195-50C2-48AE-9885-94897B3DC5B4}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU
@@ -261,6 +265,22 @@ Global
{F9CA6B5C-F14F-418D-9617-6007ED75E82F}.Release|Any CPU.Build.0 = Release|Any CPU
{F9CA6B5C-F14F-418D-9617-6007ED75E82F}.Release|x86.ActiveCfg = Release|Any CPU
{F9CA6B5C-F14F-418D-9617-6007ED75E82F}.Release|x86.Build.0 = Release|Any CPU
{C425EA21-F478-4FDB-B05D-5AE2A2FE1865}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{C425EA21-F478-4FDB-B05D-5AE2A2FE1865}.Debug|Any CPU.Build.0 = Debug|Any CPU
{C425EA21-F478-4FDB-B05D-5AE2A2FE1865}.Debug|x86.ActiveCfg = Debug|Any CPU
{C425EA21-F478-4FDB-B05D-5AE2A2FE1865}.Debug|x86.Build.0 = Debug|Any CPU
{C425EA21-F478-4FDB-B05D-5AE2A2FE1865}.Release|Any CPU.ActiveCfg = Release|Any CPU
{C425EA21-F478-4FDB-B05D-5AE2A2FE1865}.Release|Any CPU.Build.0 = Release|Any CPU
{C425EA21-F478-4FDB-B05D-5AE2A2FE1865}.Release|x86.ActiveCfg = Release|Any CPU
{C425EA21-F478-4FDB-B05D-5AE2A2FE1865}.Release|x86.Build.0 = Release|Any CPU
{919DC195-50C2-48AE-9885-94897B3DC5B4}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{919DC195-50C2-48AE-9885-94897B3DC5B4}.Debug|Any CPU.Build.0 = Debug|Any CPU
{919DC195-50C2-48AE-9885-94897B3DC5B4}.Debug|x86.ActiveCfg = Debug|Any CPU
{919DC195-50C2-48AE-9885-94897B3DC5B4}.Debug|x86.Build.0 = Debug|Any CPU
{919DC195-50C2-48AE-9885-94897B3DC5B4}.Release|Any CPU.ActiveCfg = Release|Any CPU
{919DC195-50C2-48AE-9885-94897B3DC5B4}.Release|Any CPU.Build.0 = Release|Any CPU
{919DC195-50C2-48AE-9885-94897B3DC5B4}.Release|x86.ActiveCfg = Release|Any CPU
{919DC195-50C2-48AE-9885-94897B3DC5B4}.Release|x86.Build.0 = Release|Any CPU
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE