Freigeben über


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 falseist, ü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:

Legacyfarbmodus deaktiviert

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.