如何在Xamarin Forms的MasterDetailPage中禁用母版页

时间:2015-08-11 12:41:54

标签: c# xaml mvvm xamarin-forms

我正在使用Xamarin表单,我需要禁用我用作上下文菜单的Master页面,具体取决于用户是否已登录。我将MasterDetail页面分别作为XAML个页面。

  <MasterDetailPage.Master>
    <view:MenuPage/>
  </MasterDetailPage.Master>

  <MasterDetailPage.Detail>
    <view:MainViewPage 
      x:Name="MainView"/>
  </MasterDetailPage.Detail> 

正如您可能已经猜到的那样,我正在尝试将MVVM合并到此处,因此我尝试绑定IsVisible的可见性(IsEnabled)和已启用(Master)属性但是,当按下导航按钮访问我的菜单时,我仍然会得到不希望的黑色淡入淡出效果。相反,我需要完全按下按钮按下动作。

2 个答案:

答案 0 :(得分:0)

每当用户连接时您的网页是否可见? 或者,您是否在应用程序的开头有一个登录页面?

如果您没有两个已连接用户可见的页面,您可以通过将其定义为ContentPage来实现登录页面或其他页面。它将占用所有屏幕空间并隐藏navigationBar。 然后在用户连接后,您将页面调用为MasterDetailPage,然后您将拥有您的navigationBar,...

不知道那是你要找的东西,但我希望我能帮到你。

答案 1 :(得分:0)

这可以通过自定义NavigationRenderer实现,方法是使用自定义逻辑覆盖抽屉图标的Click事件。

[assembly: ExportRenderer(typeof(NavigationPage), typeof(CustomNavigationPageRenderer))]
namespace RTW.Mobile.App.Droid.Renderers
{
    public class CustomNavigationPageRenderer : NavigationPageRenderer, IMessageSender
    {
        protected override void OnLayout(bool changed, int l, int t, int r, int b)
        {
            base.OnLayout(changed, l, t, r, b);

            var toolbar = FindViewById<Android.Support.V7.Widget.Toolbar>(Resource.Id.toolbar);
            for (var i = 0; i < toolbar.ChildCount; i++)
            {
                var imageButton = toolbar.GetChildAt(i) as ImageButton;
                var drawerArrow = imageButton?.Drawable as DrawerArrowDrawable;

                if (drawerArrow == null)
                    continue;

                //ensure only one handler is registered
                imageButton.Click -= imageButton_Click;
                imageButton.Click += imageButton_Click;
            }
        }

        private void imageButton_Click(object sender, EventArgs e)
        {
            if (!App.IsBlockingConditionTrue)
            {
                MessagingCenter.Send<IMessageSender>(this, "ToggleMasterIsPresented");
            }
        }
    }
}

然后只需订阅消息 MessagingCenter.Subscribe<IMessageSender>(this, "ToggleMasterIsPresented", OnToggleMasterIsPresented); 处理它。

    private void OnToggleMasterIsPresented(IMessageSender obj)
    {
        _masterDetailPage.IsPresented = !_masterDetailPage.IsPresented;
    }