Xamarin Forms - IOS - 汉堡包菜单 Header 颜色与状态栏不同

Xamarin Forms - IOS - Hamburger Menu Header color differs from Status Bar

我在 Xamarin Forms 应用程序中添加了一个汉堡包菜单。问题在于,对于 IOS 设备,当单击菜单时,状态栏颜色不会像 Android 那样根据菜单 Header 颜色更改。下面有图片可以看出区别。

这是主页:

<MasterDetailPage xmlns="http://xamarin.com/schemas/2014/forms"
                 xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
                 x:Class="MyProject.UI.Pages.Menu.MainPage"
                 xmlns:pages="clr-namespace:MyProject.UI.Pages.Menu"
                 xmlns:calendar="clr-namespace:MyProject.UI.Pages.Calendar;assembly=MyProject"
                 Title="Main">
        <MasterDetailPage.Master>
            <pages:HamburgerMenu x:Name="MasterPage" />
        </MasterDetailPage.Master>
        <MasterDetailPage.Detail>
            <NavigationPage>
                <x:Arguments>
                    <calendar:CalendarPage />
                </x:Arguments>
            </NavigationPage>
        </MasterDetailPage.Detail>
    </MasterDetailPage>

IOS Hamburger menu, Android Hamburger menu

因为 android 它是状态栏的默认颜色,默认显示,您可以在 Resources 文件夹下的 Styles.xml 文件中找到类似 <item name="colorPrimaryDark">#4286f4</item> 的颜色。

您可以手动更改 iOS 的状态栏颜色:
在 LoadApplication

之前将此代码写入您的 AppDelegate.cs 文件
var statusBar = UIApplication.SharedApplication.ValueForKey(new NSString("statusBar")) as UIView;
    if (statusBar.RespondsToSelector(new ObjCRuntime.Selector("setBackgroundColor:")))
    {
        statusBar.BackgroundColor = UIColor.FromRGB(66, 134, 244);
        statusBar.TintColor = UIColor.White;
    }

希望这能解决您的问题。