123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- using PixiEditor.Extensions.Sdk;
- namespace Preferences;
- public class PreferencesSampleExtension : PixiEditorExtension
- {
- /// <summary>
- /// This method is called when extension is loaded.
- /// All extensions are first loaded and then initialized. This method is called before <see cref="OnInitialized"/>.
- /// </summary>
- public override void OnLoaded()
- {
- }
- /// <summary>
- /// This method is called when extension is initialized. After this method is called, you can use Api property to access PixiEditor API.
- /// </summary>
- public override void OnInitialized()
- {
- Api.Preferences.AddCallback<int>("HelloCount", (name, value) => Api.Logger.Log($"Hello count changed to {value}!"));
- Api.Preferences.AddCallback<double>("TestDouble", (name, value) => Api.Logger.Log($"Test double changed to {value}!"));
- Api.Preferences.AddCallback<string>("TestString", (name, value) => Api.Logger.Log($"Test string changed to {value}!"));
- Api.Preferences.AddCallback<bool>("TestBool", (name, value) => Api.Logger.Log($"Test bool changed to {value}!"));
-
- // Internally this preference will have name "yourCompany.Samples.Preferences:HelloCount".
- int helloCount = Api.Preferences.GetPreference<int>("HelloCount");
- Api.Preferences.UpdatePreference("HelloCount", helloCount + 1);
-
- Api.Preferences.UpdatePreference("TestDouble", 3.14);
- Api.Preferences.UpdatePreference("TestString", "Hello, World!");
- Api.Preferences.UpdatePreference("TestBool", true);
- // This will overwrite built-in PixiEditor preference. Extension must have WriteNonOwnedPreferences permission.
- // Prepending "PixiEditor:" to preference name will access built-in PixiEditor preferences. If you set it to other extension unique name,
- // it will access extension preferences.
- // You can do analogous thing with UpdatePreference.
- Api.Preferences.UpdateLocalPreference(
- "PixiEditor:OverwrittenPixiEditorPreference",
- "This is overwritten value of preference that is built-in in PixiEditor.");
- // You don't need any special permission for reading any kind of preference.
- Api.Logger.Log(Api.Preferences.GetLocalPreference<string>("PixiEditor:OverwrittenPixiEditorPreference"));
- }
- }
|