Plugin.Maui.Feature
provides the ability to do this amazing thing in your .NET MAUI application.
Available on NuGet.
Install with the dotnet CLI: dotnet add package Plugin.Maui.Feature
, or through the NuGet Package Manager in Visual Studio.
Plugin.Maui.Feature
provides the Feature
class that has a single property Property
that you can get or set.
You can either use it as a static class, e.g.: Feature.Default.Property = 1
or with dependency injection: builder.Services.AddSingleton<IFeature>(Feature.Default);
Before you can start using Feature, you will need to request the proper permissions on each platform.
No permissions are needed for iOS.
No permissions are needed for Android.
You will first need to register the Feature
with the MauiAppBuilder
following the same pattern that the .NET MAUI Essentials libraries follow.
builder.Services.AddSingleton(Feature.Default);
You can then enable your classes to depend on IFeature
as per the following example.
public class FeatureViewModel
{
readonly IFeature feature;
public FeatureViewModel(IFeature feature)
{
this.feature = feature;
}
public void StartFeature()
{
feature.ReadingChanged += (sender, reading) =>
{
Console.WriteLine(reading.Thing);
};
feature.Start();
}
}
Alternatively if you want to skip using the dependency injection approach you can use the Feature.Default
property.
public class FeatureViewModel
{
public void StartFeature()
{
feature.ReadingChanged += (sender, reading) =>
{
Console.WriteLine(feature.Thing);
};
Feature.Default.Start();
}
}
Once you have created a Feature
you can interact with it in the following ways:
Occurs when feature reading changes.
Gets a value indicating whether reading the feature is supported on this device.
Gets a value indicating whether the feature is actively being monitored.
Start monitoring for changes to the feature.
Stop monitoring for changes to the feature.
This project could not have came to be without these projects and people, thank you! <3