Projektanker.Icons.Avalonia
9.6.0
dotnet add package Projektanker.Icons.Avalonia --version 9.6.0
NuGet\Install-Package Projektanker.Icons.Avalonia -Version 9.6.0
<PackageReference Include="Projektanker.Icons.Avalonia" Version="9.6.0" />
paket add Projektanker.Icons.Avalonia --version 9.6.0
#r "nuget: Projektanker.Icons.Avalonia, 9.6.0"
// Install Projektanker.Icons.Avalonia as a Cake Addin #addin nuget:?package=Projektanker.Icons.Avalonia&version=9.6.0 // Install Projektanker.Icons.Avalonia as a Cake Tool #tool nuget:?package=Projektanker.Icons.Avalonia&version=9.6.0
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 project.
1. Register icon providers on app start up
Register the icon provider(s) with the IconProvider.Current
.
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()
{
IconProvider.Current
.Register<FontAwesomeIconProvider>()
.Register<MaterialDesignIconProvider>();
return AppBuilder.Configure<App>()
.UsePlatformDetect()
.LogToTrace();
}
}
2. Add xml namespace
Add xmlns:i="https://github.com/projektanker/icons.avalonia"
to your view.
3. Use the icon
Standalone
<i:Icon Value="fa-brands fa-anchor" />
Attached to ContentControl (e.g. Button)
<Button i:Attached.Icon="fa-brands fa-anchor" />
Attached to MenuItem
<MenuItem Header="About" i:MenuItem.Icon="fa-solid fa-circle-info" />
Custom icon size
<i:Icon Value="fa-brands fa-anchor" FontSize="24" />
Animated
<i:Icon Value="fa-spinner" Animation="Pulse" />
<i:Icon Value="fa-sync" Animation="Spin" />
As an Image source
<Image>
<Image.Source>
<i:IconImage Value="fa-brands fa-anchor" Brush="(defaults to black)" />
</Image.Source>
</Image>
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 model of the requested icon.
/// </summary>
/// <param name="value">The value specifying the icon to return it's model from.</param>
/// <returns>The model of the icon.</returns>
/// <exception cref="System.Collections.Generic.KeyNotFoundException">
/// The icon associated with the specified <paramref name="value"/> does not exists.
/// </exception>
IconModel GetIcon(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
:
IconProvider.Current.Register<MyCustomIconProvider>()
or
IIconProvider provider = new MyCustomIconProvider(/* custom ctor arguments */);
IconProvider.Current.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. |
.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.2.3)
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 | 402 | 12/22/2024 | |
9.5.0 | 2,683 | 11/24/2024 | |
9.4.3 | 1,848 | 11/18/2024 | |
9.4.2 | 180 | 11/18/2024 | |
9.4.1 | 7,725 | 10/4/2024 | |
9.4.0 | 32,705 | 7/21/2024 | |
9.3.0 | 28,180 | 4/7/2024 | |
9.2.0 | 1,057 | 3/29/2024 | |
9.1.2 | 6,581 | 3/12/2024 | |
9.1.1 | 6,354 | 2/22/2024 | |
9.0.1 | 11,172 | 12/8/2023 | |
9.0.0 | 677 | 12/6/2023 | |
8.4.0 | 2,382 | 12/6/2023 | |
8.3.0 | 9,519 | 10/11/2023 | |
8.2.0 | 4,901 | 8/6/2023 | |
8.1.0 | 1,080 | 7/26/2023 | |
8.0.0 | 1,277 | 7/17/2023 | |
7.0.1 | 1,253 | 7/16/2023 | |
7.0.0 | 691 | 7/16/2023 | |
6.6.0 | 1,843 | 7/10/2023 | |
6.6.0-rc1.1 | 5,950 | 6/7/2023 | |
6.6.0-preview6 | 1,055 | 4/26/2023 | |
6.5.0-preview6 | 1,553 | 3/24/2023 | |
6.5.0-preview5 | 1,212 | 2/28/2023 | |
6.4.0-preview5 | 777 | 2/4/2023 | |
6.3.0-preview4 | 1,826 | 12/12/2022 | |
6.2.0-preview1 | 810 | 9/21/2022 | |
6.1.0-preview1 | 575 | 8/29/2022 | |
6.0.0-preview1 | 597 | 8/24/2022 | |
5.13.0 | 4,568 | 4/26/2023 | |
5.12.0 | 1,500 | 4/2/2023 | |
5.11.0 | 1,077 | 3/26/2023 | |
5.10.0 | 1,522 | 2/28/2023 | |
5.9.0 | 1,840 | 2/12/2023 | |
5.8.0 | 2,277 | 12/12/2022 | |
5.7.0 | 1,060 | 12/12/2022 | |
5.6.0 | 3,302 | 11/20/2022 | |
5.5.0 | 12,583 | 9/4/2022 | |
5.4.0 | 1,441 | 8/29/2022 | |
5.3.0 | 2,625 | 7/31/2022 | |
5.2.0 | 1,705 | 7/24/2022 | |
5.1.0 | 2,991 | 7/3/2022 | |
5.0.2 | 2,714 | 5/27/2022 | |
5.0.1 | 1,607 | 5/23/2022 | |
5.0.0 | 1,391 | 5/23/2022 | |
4.5.0 | 1,355 | 5/22/2022 | |
4.4.0 | 3,253 | 4/3/2022 | |
4.3.0 | 1,523 | 3/27/2022 | |
4.2.1 | 1,689 | 3/16/2022 | |
4.2.0 | 1,431 | 3/14/2022 | |
4.1.0 | 1,677 | 3/9/2022 | |
4.0.1 | 1,453 | 3/8/2022 | |
4.0.0 | 1,488 | 3/7/2022 | |
3.7.1 | 2,678 | 12/15/2021 | |
3.7.0 | 2,672 | 11/20/2021 | |
3.5.0 | 1,188 | 11/12/2021 | |
3.4.1 | 1,574 | 11/8/2021 | |
3.4.0 | 1,318 | 11/8/2021 | |
3.2.0 | 1,563 | 10/17/2021 | |
3.1.4 | 1,078 | 10/14/2021 | |
3.1.2 | 2,305 | 8/13/2021 | |
3.1.1 | 1,050 | 8/11/2021 | |
3.1.0 | 1,874 | 3/22/2021 | |
3.1.0-pre | 272 | 3/22/2021 | |
3.0.0 | 985 | 10/29/2020 | |
3.0.0-pre | 833 | 10/29/2020 | |
2.0.2 | 1,220 | 8/12/2020 | |
2.0.1 | 1,215 | 7/27/2020 | |
2.0.0 | 1,140 | 7/27/2020 | |
1.0.0 | 1,185 | 7/27/2020 |