VisualElement LegacyFarbmodus unter Android
Einige der Xamarin.Forms Ansichten weisen einen älteren Farbmodus auf. Wenn die IsEnabled
Eigenschaft der Ansicht in diesem Modus auf festgelegt false
ist, überschreibt die Ansicht die vom Benutzer festgelegten Farben mit den standardmäßigen nativen Farben für den deaktivierten Zustand. Aus Gründen der Abwärtskompatibilität bleibt dieser Legacyfarbmodus das Standardverhalten für unterstützte Ansichten.
Diese plattformspezifische Android-Plattform deaktiviert diesen Legacyfarbmodus, sodass Farben, die für eine Ansicht durch den Benutzer festgelegt werden, auch dann beibehalten werden, wenn die Ansicht deaktiviert ist. Sie wird in XAML genutzt, indem die angefügte VisualElement.IsLegacyColorModeEnabled
-Eigenschaft auf false
festgelegt wird:
<ContentPage ...
xmlns:android="clr-namespace:Xamarin.Forms.PlatformConfiguration.AndroidSpecific;assembly=Xamarin.Forms.Core">
<StackLayout>
...
<Button Text="Button"
TextColor="Blue"
BackgroundColor="Bisque"
android:VisualElement.IsLegacyColorModeEnabled="False" />
...
</StackLayout>
</ContentPage>
Alternativ kann sie mit der Fluent-API von C# genutzt werden:
using Xamarin.Forms.PlatformConfiguration;
using Xamarin.Forms.PlatformConfiguration.AndroidSpecific;
...
_legacyColorModeDisabledButton.On<Android>().SetIsLegacyColorModeEnabled(false);
Die VisualElement.On<Android>
Methode gibt an, dass diese plattformspezifisch nur auf Android läuft. Die VisualElement.SetIsLegacyColorModeEnabled
Methode im Xamarin.Forms.PlatformConfiguration.AndroidSpecific
Namespace wird verwendet, um zu steuern, ob der Legacyfarbmodus deaktiviert ist. Darüber hinaus kann die VisualElement.GetIsLegacyColorModeEnabled
Methode verwendet werden, um zurückzugeben, ob der Legacyfarbmodus deaktiviert ist.
Das Ergebnis ist, dass der Legacyfarbmodus deaktiviert werden kann, sodass farben, die für eine Ansicht durch den Benutzer festgelegt werden, auch wenn die Ansicht deaktiviert ist:
Hinweis
Beim Festlegen einer VisualStateGroup
Ansicht wird der Legacyfarbmodus vollständig ignoriert. Weitere Informationen zu visuellen Zuständen finden Sie im Xamarin.Forms Visual State-Manager.