使用  Rg.Plugins.Popup 插件

1.  新建 PopupMenu.xaml

<?xml version="1.0" encoding="utf-8" ?>
<pages:PopupPage xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
xmlns:pages="clr-namespace:Rg.Plugins.Popup.Pages;assembly=Rg.Plugins.Popup"
xmlns:animations="clr-namespace:Rg.Plugins.Popup.Animations;assembly=Rg.Plugins.Popup"
xmlns:iconize="clr-namespace:Plugin.Iconize;assembly=Plugin.Iconize"
x:Class="DCMS.Client.Views.CustomView.PopupMenu" x:Name="PopupMaster">
<pages:PopupPage.Resources>
<ResourceDictionary>
<Style x:Key="EntryStyle"
TargetType="Entry">
<Setter Property="PlaceholderColor"
Value="#9cdaf1" />
<Setter Property="TextColor"
Value="#7dbbe6" />
</Style>
</ResourceDictionary>
</pages:PopupPage.Resources>
<pages:PopupPage.Animation>
<animations:ScaleAnimation PositionIn="Top"
PositionOut="Center"
ScaleIn=""
ScaleOut="0.7"
DurationIn=""
EasingIn="BounceOut" />
</pages:PopupPage.Animation>
<ScrollView HorizontalOptions="End"
VerticalOptions="Start">
<AbsoluteLayout Margin="0,45,0,0"
x:Name="MainLayout">
<Frame x:Name="FrameContainer"
Margin="0,10,10,0"
HorizontalOptions="Center"
BorderColor="Transparent"
BackgroundColor="White">
<ListView x:Name="SecondaryToolbarListView"
VerticalOptions="Start"
HorizontalOptions="Start"
WidthRequest=""
HasUnevenRows="True"
ItemsSource="{Binding Source={x:Reference PopupMaster},Path=MenuItems}">
<ListView.ItemTemplate>
<DataTemplate>
<ViewCell>
<StackLayout Orientation="Horizontal"
HorizontalOptions="FillAndExpand"
Margin=""
Spacing=""
HeightRequest=""
Padding="15,0,0,0">
<iconize:IconImage x:Name="iconImage"
Icon="{Binding Icon}"
HorizontalOptions="Start"
VerticalOptions="Center"
Margin="0,0,8,0"
IconColor="{StaticResource PrimaryDarkColor}"
IconSize="" />
<Label x:Name="menuText"
Text="{Binding MenuText}"
FontSize=""
VerticalOptions="Center"
HorizontalOptions="Start" />
</StackLayout>
</ViewCell>
</DataTemplate>
</ListView.ItemTemplate>
</ListView>
</Frame>
<ContentView AbsoluteLayout.LayoutFlags="XProportional"
AbsoluteLayout.LayoutBounds=".8,5, 15, 15">
<ContentView.GestureRecognizers>
<TapGestureRecognizer Tapped="OnCloseButtonTapped" />
</ContentView.GestureRecognizers>
<BoxView HeightRequest=""
x:Name="CloseImage"
WidthRequest=""
BackgroundColor="White"></BoxView>
</ContentView>
</AbsoluteLayout>
</ScrollView>
</pages:PopupPage>
     [XamlCompilation(XamlCompilationOptions.Compile)]
public partial class PopupMenu : PopupPage
{
private List<ToolbarItemModel> MenuItems { get; set; }
public PopupMenu (List<ToolbarItemModel> data)
{
InitializeComponent ();
MenuItems = data;
} protected override void OnAppearing()
{
base.OnAppearing();
SecondaryToolbarListView.ItemsSource = MenuItems;
SecondaryToolbarListView.HeightRequest = MenuItems.Count * ;
} protected override void OnAppearingAnimationBegin()
{
base.OnAppearingAnimationBegin();
CloseImage.Rotation = ;
//CloseImage.TranslationY = -10;
MainLayout.RaiseChild(CloseImage);
} private void OnCloseButtonTapped(object sender, EventArgs e)
{
CloseAllPopup();
} protected override bool OnBackgroundClicked()
{
CloseAllPopup(); return false;
} private async void CloseAllPopup()
{
await PopupNavigation.Instance.PopAllAsync();
}
}

2.  在需要添加Toolbar 的页面中  添加 菜单项。

  public partial class SaleBillPage : ContentPage
{ private PopupMenu _popupMenu; public SaleBillPage()
{
InitializeComponent(); var items = new List<ToolbarItemModel>
{
new ToolbarItemModel {Icon = "fas-list-alt", MenuText = "历史单据"},
new ToolbarItemModel {Icon = "fas-list-alt", MenuText = "支付方式"},
new ToolbarItemModel {Icon = "fas-list-alt", MenuText = "欠款"},
new ToolbarItemModel {Icon = "fas-list-alt", MenuText = "优惠"},
new ToolbarItemModel {Icon = "fas-list-alt", MenuText = "整单备注"},
new ToolbarItemModel {Icon = "fas-list-alt", MenuText = "清空单据"},
new ToolbarItemModel {Icon = "fas-list-alt", MenuText = "打印"},
}; _popupMenu = new PopupMenu(items);
} #region Overrides protected override void OnAppearing()
{
base.OnAppearing();
this.ToolbarItems.Clear();
foreach (var toolBarItem in GetToolBarItems().ToList())
{
this.ToolbarItems.Add(toolBarItem);
}
} #endregion private IList<ToolbarItem> GetToolBarItems()
{
var list = new List<ToolbarItem>();
list.Add(new ToolbarItem("\uf0c7", "", () =>
{
Device.BeginInvokeOnMainThread(() =>
{
DisplayAlert("提示", "抱歉,功能稍后开放...", "取消");
});
},ToolbarItemOrder.Primary, ));
list.Add(new ToolbarItem("\uf0c9", "", () =>
{
Device.BeginInvokeOnMainThread(async () =>
{
await PopupNavigation.Instance.PushAsync(_popupMenu);
});
}, ToolbarItemOrder.Primary, )); return list;
}
}

效果如图:

Xamarin 自定义 ToolbarItem 溢出菜单实现(Popover/Popup) 弹出下拉效果的更多相关文章

  1. IOS第二天-新浪微博 - 添加搜索框,弹出下拉菜单 ,代理的使用 ,HWTabBar.h(自定义TabBar)

    ********HWDiscoverViewController.m(发现) - (void)viewDidLoad { [super viewDidLoad]; // 创建搜索框对象 HWSearc ...

  2. 【android开发】使用PopupWindow实现页面点击顶部弹出下拉菜单

    没有太多花样,也没有很复杂的技术,就是简单的PopupWindow的使用,可以实现点击弹出一个自定义的view,view里可以随便设计,常用的可以放一个listview. demo中我只是一个点击展示 ...

  3. 有序无序Ul->Li Ol->Li菜单,默认点击当前弹出下拉,再次点击收起下拉菜单(变形2 ---修饰)

    从上面可以看出,两个问题,第一:下拉出现的太快太突然,第二:再点击下一个下拉菜单的时候,上一个不会闭合,针对这两个问题,接下来会一 一解决. 解决下拉太快: js中有个jquery效果,有一个效果是j ...

  4. 有序无序ul->li ol->li菜单,默认点击当前弹出下拉,再次点击收起下拉菜单

    实现这一效果利用css和js技术结合 以ul->li为例子 <!DOCTYPE html><html lang="en"><head> & ...

  5. bootstrap中popover.js(弹出框)使用总结+案例

    bootstrap中popover.js(弹出框)使用总结+案例 *转载请注明出处: 作者:willingtolove: http://www.cnblogs.com/willingtolove/p/ ...

  6. Android定位&地图&导航——基于百度地图,实现自定义图标绘制并点击时弹出泡泡

    一.问题描述 上一次我们使用百度地图实现基本的定位功能,接下来我们继续实现搜索和定位,并使用LocationOverlay绘制定位位置,同时展示如何使用自定义图标绘制并点击时弹出泡泡 如图所示: 二. ...

  7. UWP Popup 弹出

    一:需求 做一个类似于安卓的弹出消息框,如图.当用户点击下载或者选择时,能够从底部弹出一个提示框,用于提示用户. 二:Popup 类 不需要我们自己额外去写一个弹窗类,微软自己有一个Popup 弹窗类 ...

  8. vant - 弹框 【Popup 弹出层】【DatetimePicker 时间选择】

    [HelloWorld.vue] <template> <div class="hello"> <van-row class="m-head ...

  9. UWP Popup 弹出提示框

    一:需求 做一个类似于安卓的弹出消息框,如图.当用户点击下载或者选择时,能够从底部弹出一个提示框,用于提示用户. 二:Popup 类 不需要我们自己额外去写一个弹窗类,微软自己有一个Popup 弹窗类 ...

随机推荐

  1. mysql触发器Before和After的区别

    Before与After区别:before:(insert.update)可以对new进行修改.                    after不能对new进行修改.                 ...

  2. 设计模式学习之访问者模式(Visitor,行为型模式)(21)

    参考:https://www.cnblogs.com/edisonchou/p/7247990.html 在患者就医时,医生会根据病情开具处方单,很多医院都会存在以下这个流程:划价人员拿到处方单之后根 ...

  3. shaderlab UV动画所需的变量声明

    优化资源.美术需要迫使自己的顶点shader能够进行TRANSFORM_TEX运算,进行该运算的前提是需要声明一个 _MainTex_ST 变量,类型为float4即可. 此时就可以使用unity c ...

  4. BigDecimal类型转换

    djjfbr.setMoney(new BigDecimal(djjfbillrecord.getMoney()));

  5. 初学Python的一些细节

    一.python的数据类型 1.python的基本数据类型包括数值数据类型和字符串数据类型:基本数据类型的特点是不允许改变,如果改变基本数据类型的值,会导致内存的重新分配. int 整形 二进制    ...

  6. python mysql 单表查询 多表查询

    一.外键 变种: 三种关系: 多对一 站在左表的角度: (1)一个员工 能不能在 多个部门? 不成立 (2)多个员工 能不能在 一个部门? 成立 只要有一个条件成立:多 对 一或者是1对多 如果两个条 ...

  7. 微信小程序采坑

    wx.request() complete回调函数执行时机问题 代码执行顺序有时候会严重影响用户体验:比如项目中请求数据时显示loading的图标,请求完成后不管失败还是成功都要把loading图标隐 ...

  8. archlinux下安装acroread打开pdf

    虽说acroread是个好东西,但是在打开pdf几秒后总是自动退出呢 在其aur网页下找到了这么一解决办法: 打开终端输入 sudo unshare -n sudo -u ${USER} ACRO_A ...

  9. 泡泡一分钟:Cooperative Object Transportation by Multiple Ground and Aerial Vehicles: Modeling and Planning

    张宁 Cooperative Object Transportation by Multiple Ground and Aerial Vehicles: Modeling and Planning 多 ...

  10. 如何在云服务器创建maven私有仓库

    参考链接:https://blog.csdn.net/silence_jjj/article/details/77531916 nexus3创建maven私有仓库(windows) 1.官网:http ...