我正在使用Xamarin
表单,我需要禁用我用作上下文菜单的Master
页面,具体取决于用户是否已登录。我将Master
和Detail
页面分别作为XAML
个页面。
<MasterDetailPage.Master>
<view:MenuPage/>
</MasterDetailPage.Master>
<MasterDetailPage.Detail>
<view:MainViewPage
x:Name="MainView"/>
</MasterDetailPage.Detail>
正如您可能已经猜到的那样,我正在尝试将MVVM
合并到此处,因此我尝试绑定IsVisible
的可见性(IsEnabled
)和已启用(Master
)属性但是,当按下导航按钮访问我的菜单时,我仍然会得到不希望的黑色淡入淡出效果。相反,我需要完全按下按钮按下动作。
答案 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;
}