Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/projektanker/icons.avalonia
https://github.com/projektanker/icons.avalonia
avaloniaui fontawesome6 icons materialdesignicons
Last synced: 4 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/projektanker/icons.avalonia
- Owner: Projektanker
- License: mit
- Created: 2020-07-15T17:31:30.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2025-02-11T06:22:48.000Z (10 days ago)
- Last Synced: 2025-02-17T02:02:29.989Z (4 days ago)
- Topics: avaloniaui, fontawesome6, icons, materialdesignicons
- Language: C#
- Homepage:
- Size: 10.3 MB
- Stars: 338
- Watchers: 5
- Forks: 15
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Icons.Avalonia
A library to easily display icons in an Avalonia App.
[data:image/s3,"s3://crabby-images/d2a18/d2a18db2839c5d33559abda41c7618ea415c4818" alt="🚀 Push"](https://github.com/Projektanker/Icons.Avalonia/actions/workflows/push.yml)
[data:image/s3,"s3://crabby-images/d1402/d14026474099f979a38c6761423787c1857f2294" alt="🔄 Sync Fontawesome"](https://github.com/Projektanker/Icons.Avalonia/actions/workflows/sync-fontawesome.yml)
[data:image/s3,"s3://crabby-images/ed501/ed501b6576079bed4af70e646bb91ed9305ae31a" alt="🔄 Sync Material Design"](https://github.com/Projektanker/Icons.Avalonia/actions/workflows/sync-materialdesign.yml)## NuGet
| Name | Description | Version |
| :----------------------------------------------------------------------------------------------------------------------- | :-------------------------------------------------------------- | :------------------------------------------------------------------------------ |
| [Projektanker.Icons.Avalonia](https://www.nuget.org/packages/Projektanker.Icons.Avalonia/) | Core library | data:image/s3,"s3://crabby-images/46ec0/46ec0321ad7f9a868f2b97d733c3d1409284e962" alt="Nuget" |
| [Projektanker.Icons.Avalonia.FontAwesome](https://www.nuget.org/packages/Projektanker.Icons.Avalonia.FontAwesome/) | [Font Awesome 6 Free](https://fontawesome.com) | data:image/s3,"s3://crabby-images/ca478/ca47860ae3e406424cd82088640b657b773b5ab0" alt="Nuget" |
| [Projektanker.Icons.Avalonia.MaterialDesign](https://www.nuget.org/packages/Projektanker.Icons.Avalonia.MaterialDesign/) | [Material Design Icons](https://pictogrammers.com/library/mdi/) | data:image/s3,"s3://crabby-images/71171/71171b9c26766ac72548f0eeb33549bdac78a64f" alt="Nuget" |## Icon providers
| Name | Prefix | Example |
| :------------- | :----: | :----------- |
| FontAwesome 6 | `fa` | `fa-github` |
| MaterialDesign | `mdi` | `mdi-github` |## Usage
A full example is available in the [Demo project](src/Demo/Demo.csproj).
### 1. Register icon providers on app start up
Register the icon provider(s) with the `IconProvider.Current`.
```csharp
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()
.Register();return AppBuilder.Configure()
.UsePlatformDetect()
.LogToTrace();
}
}
```### 2. Add xml namespace
Add `xmlns:i="https://github.com/projektanker/icons.avalonia"` to your view.
### 3. Use the icon
**Standalone**
```xml
```
**Attached to ContentControl (e.g. Button)**
```xml
```
**Attached to MenuItem**
```xml
```
**Custom icon size**
```xml
```
**Animated**
```xml
```
**As an [Image](https://docs.avaloniaui.net/docs/reference/controls/image) source**
```xml
```
### Done
data:image/s3,"s3://crabby-images/79446/79446db461c7513b76629dda3b734b8fcaa15da1" alt="Screenshot"
## Implement your own Icon Provider
Just implement the `IIconProvider` interface:
```csharp
namespace Projektanker.Icons.Avalonia
{
///
/// Represents an icon reader.
///
public interface IIconReader
{
///
/// Gets the model of the requested icon.
///
/// The value specifying the icon to return it's model from.
/// The model of the icon.
///
/// The icon associated with the specified does not exists.
///
IconModel GetIcon(string value);
}///
/// Represents an icon provider.
///
public interface IIconProvider : IIconReader
{
///
/// Gets the prefix of the .
///
string Prefix { get; }
}
}
```and register it with the `IIconProviderContainer`:
```csharp
IconProvider.Current.Register()
```or
```csharp
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`.