Projektanker.Icons.Avalonia
6.3.0-preview4
See the version list below for details.
dotnet add package Projektanker.Icons.Avalonia --version 6.3.0-preview4
NuGet\Install-Package Projektanker.Icons.Avalonia -Version 6.3.0-preview4
<PackageReference Include="Projektanker.Icons.Avalonia" Version="6.3.0-preview4" />
paket add Projektanker.Icons.Avalonia --version 6.3.0-preview4
#r "nuget: Projektanker.Icons.Avalonia, 6.3.0-preview4"
// Install Projektanker.Icons.Avalonia as a Cake Addin #addin nuget:?package=Projektanker.Icons.Avalonia&version=6.3.0-preview4&prerelease // Install Projektanker.Icons.Avalonia as a Cake Tool #tool nuget:?package=Projektanker.Icons.Avalonia&version=6.3.0-preview4&prerelease
Icons.Avalonia
A library to easily display icons in an Avalonia App.
NuGet
Name | Description | Version |
---|---|---|
Projektanker.Icons.Avalonia | Core library | |
Projektanker.Icons.Avalonia.FontAwesome | Font Awesome 6 Free | |
Projektanker.Icons.Avalonia.MaterialDesign | Material Design Icons |
Icon providers
Name | Prefix | Example |
---|---|---|
FontAwesome 6 | fa |
fa-github |
MaterialDesign | mdi |
mdi-github |
Usage
A full example is available in the demo directory.
1. Register icon providers on app start up
Register the icon provider(s) with the AppBuilder
.
class Program
{
// Initialization code. Don't use any Avalonia, third-party APIs or any
// SynchronizationContext-reliant code before AppMain is called: things aren't initialized
// yet and stuff might break.
public static void Main(string[] args)
{
BuildAvaloniaApp()
.StartWithClassicDesktopLifetime(args);
}
// Avalonia configuration, don't remove; also used by visual designer.
public static AppBuilder BuildAvaloniaApp()
{
return AppBuilder.Configure<App>()
.UsePlatformDetect()
.LogToTrace()
.WithIcons(container => container
.Register<FontAwesomeIconProvider>()
.Register<MaterialDesignIconProvider>());
}
}
2. Add xml namespace
Add xmlns:i="clr-namespace:Projektanker.Icons.Avalonia;assembly=Projektanker.Icons.Avalonia"
to your view.
3. Use the icon
Standalone
<i:Icon Value="fa-brands fa-github" />
Attached to ContentControl (e.g. Button)
<Button i:Attached.Icon="fa-brands fa-github" />
Attached to MenuItem
<MenuItem Header="About" i:MenuItem.Icon="fa-solid fa-circle-info" />
Animated
⚠️ There is currently a bug in Avalonia 11: https://github.com/AvaloniaUI/Avalonia/issues/8791
<i:Icon Value="fa-spinner" Animation="Pulse" />
<i:Icon Value="fa-sync" Animation="Spin" />
Done
Implement your own Icon Provider
Just implement the IIconProvider
interface:
namespace Projektanker.Icons.Avalonia
{
/// <summary>
/// Represents an icon reader.
/// </summary>
public interface IIconReader
{
/// <summary>
/// Gets the SVG path of the requested icon.
/// </summary>
/// <param name="value">The value specifying the icon to return it's path from.</param>
/// <returns>The path of the icon.</returns>
/// <exception cref="System.Collections.Generic.KeyNotFoundException">
/// The icon associated with the specified <paramref name="value"/> does not exists.
/// </exception>
string GetIconPath(string value);
}
/// <summary>
/// Represents an icon provider.
/// </summary>
public interface IIconProvider : IIconReader
{
/// <summary>
/// Gets the prefix of the <see cref="IIconProvider"/>.
/// </summary>
string Prefix { get; }
}
}
and register it with the IIconProviderContainer
:
container.Register<MyCustomIconProvider>()
or
IIconProvider provider = new MyCustomIconProvider(/* custom ctor arguments */);
container.Register(provider);
The IIconProvider.Prefix
property has to be unique within all registered providers. It is used to select the right provider. E.g. FontAwesomeIconProvider
's prefix is fa
.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Avalonia (>= 11.0.0-preview4)
NuGet packages (3)
Showing the top 3 NuGet packages that depend on Projektanker.Icons.Avalonia:
Package | Downloads |
---|---|
Projektanker.Icons.Avalonia.FontAwesome
A library to easily display FontAwesome icons in an Avalonia App. |
|
Projektanker.Icons.Avalonia.MaterialDesign
A library to easily display Material Design icons in an Avalonia App. |
|
MenuFactory
Simple Avalonia library to help manage the application menu |
GitHub repositories (11)
Showing the top 5 popular GitHub repositories that depend on Projektanker.Icons.Avalonia:
Repository | Stars |
---|---|
Ryubing/Ryujinx
Nintendo Switch emulator written in C#, originally created by gdkchan.
|
|
sn4k3/UVtools
MSLA/DLP, file analysis, calibration, repair, conversion and manipulation
|
|
aloneguid/parquet-dotnet
Fully managed Apache Parquet implementation
|
|
fifty-six/Scarab
An installer for Hollow Knight mods written in Avalonia.
|
|
BAndysc/WoWDatabaseEditor
Integrated development environment (IDE), an editor for Smart Scripts (SAI/smart_scripts) for TrinityCore based servers. Cmangos support work in progress. Featuring a 3D view built with OpenGL and custom ECS framework
|
Version | Downloads | Last updated | |
---|---|---|---|
9.6.0 | 1,269 | 12/22/2024 | |
9.5.0 | 3,139 | 11/24/2024 | |
9.4.3 | 1,983 | 11/18/2024 | |
9.4.2 | 186 | 11/18/2024 | |
9.4.1 | 9,278 | 10/4/2024 | |
9.4.0 | 37,783 | 7/21/2024 | |
9.3.0 | 28,437 | 4/7/2024 | |
9.2.0 | 1,062 | 3/29/2024 | |
9.1.2 | 6,585 | 3/12/2024 | |
9.1.1 | 6,395 | 2/22/2024 | |
9.0.1 | 11,241 | 12/8/2023 | |
9.0.0 | 679 | 12/6/2023 | |
8.4.0 | 2,385 | 12/6/2023 | |
8.3.0 | 9,537 | 10/11/2023 | |
8.2.0 | 4,906 | 8/6/2023 | |
8.1.0 | 1,085 | 7/26/2023 | |
8.0.0 | 1,279 | 7/17/2023 | |
7.0.1 | 1,255 | 7/16/2023 | |
7.0.0 | 693 | 7/16/2023 | |
6.6.0 | 1,845 | 7/10/2023 | |
6.6.0-rc1.1 | 5,991 | 6/7/2023 | |
6.6.0-preview6 | 1,057 | 4/26/2023 | |
6.5.0-preview6 | 1,556 | 3/24/2023 | |
6.5.0-preview5 | 1,213 | 2/28/2023 | |
6.4.0-preview5 | 779 | 2/4/2023 | |
6.3.0-preview4 | 1,828 | 12/12/2022 | |
6.2.0-preview1 | 812 | 9/21/2022 | |
6.1.0-preview1 | 577 | 8/29/2022 | |
6.0.0-preview1 | 599 | 8/24/2022 | |
5.13.0 | 4,598 | 4/26/2023 | |
5.12.0 | 1,502 | 4/2/2023 | |
5.11.0 | 1,080 | 3/26/2023 | |
5.10.0 | 1,523 | 2/28/2023 | |
5.9.0 | 1,857 | 2/12/2023 | |
5.8.0 | 2,303 | 12/12/2022 | |
5.7.0 | 1,062 | 12/12/2022 | |
5.6.0 | 3,318 | 11/20/2022 | |
5.5.0 | 12,797 | 9/4/2022 | |
5.4.0 | 1,443 | 8/29/2022 | |
5.3.0 | 2,630 | 7/31/2022 | |
5.2.0 | 1,707 | 7/24/2022 | |
5.1.0 | 2,995 | 7/3/2022 | |
5.0.2 | 2,718 | 5/27/2022 | |
5.0.1 | 1,609 | 5/23/2022 | |
5.0.0 | 1,393 | 5/23/2022 | |
4.5.0 | 1,357 | 5/22/2022 | |
4.4.0 | 3,255 | 4/3/2022 | |
4.3.0 | 1,525 | 3/27/2022 | |
4.2.1 | 1,693 | 3/16/2022 | |
4.2.0 | 1,433 | 3/14/2022 | |
4.1.0 | 1,680 | 3/9/2022 | |
4.0.1 | 1,455 | 3/8/2022 | |
4.0.0 | 1,490 | 3/7/2022 | |
3.7.1 | 2,681 | 12/15/2021 | |
3.7.0 | 2,675 | 11/20/2021 | |
3.5.0 | 1,190 | 11/12/2021 | |
3.4.1 | 1,576 | 11/8/2021 | |
3.4.0 | 1,320 | 11/8/2021 | |
3.2.0 | 1,567 | 10/17/2021 | |
3.1.4 | 1,080 | 10/14/2021 | |
3.1.2 | 2,307 | 8/13/2021 | |
3.1.1 | 1,052 | 8/11/2021 | |
3.1.0 | 1,876 | 3/22/2021 | |
3.1.0-pre | 274 | 3/22/2021 | |
3.0.0 | 987 | 10/29/2020 | |
3.0.0-pre | 835 | 10/29/2020 | |
2.0.2 | 1,222 | 8/12/2020 | |
2.0.1 | 1,218 | 7/27/2020 | |
2.0.0 | 1,143 | 7/27/2020 | |
1.0.0 | 1,190 | 7/27/2020 |