Xamarin 自定义 ToolbarItem 溢出菜单实现(Popover/Popup) 弹出下拉效果
使用 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) 弹出下拉效果的更多相关文章
- IOS第二天-新浪微博 - 添加搜索框,弹出下拉菜单 ,代理的使用 ,HWTabBar.h(自定义TabBar)
********HWDiscoverViewController.m(发现) - (void)viewDidLoad { [super viewDidLoad]; // 创建搜索框对象 HWSearc ...
- 【android开发】使用PopupWindow实现页面点击顶部弹出下拉菜单
没有太多花样,也没有很复杂的技术,就是简单的PopupWindow的使用,可以实现点击弹出一个自定义的view,view里可以随便设计,常用的可以放一个listview. demo中我只是一个点击展示 ...
- 有序无序Ul->Li Ol->Li菜单,默认点击当前弹出下拉,再次点击收起下拉菜单(变形2 ---修饰)
从上面可以看出,两个问题,第一:下拉出现的太快太突然,第二:再点击下一个下拉菜单的时候,上一个不会闭合,针对这两个问题,接下来会一 一解决. 解决下拉太快: js中有个jquery效果,有一个效果是j ...
- 有序无序ul->li ol->li菜单,默认点击当前弹出下拉,再次点击收起下拉菜单
实现这一效果利用css和js技术结合 以ul->li为例子 <!DOCTYPE html><html lang="en"><head> & ...
- bootstrap中popover.js(弹出框)使用总结+案例
bootstrap中popover.js(弹出框)使用总结+案例 *转载请注明出处: 作者:willingtolove: http://www.cnblogs.com/willingtolove/p/ ...
- Android定位&地图&导航——基于百度地图,实现自定义图标绘制并点击时弹出泡泡
一.问题描述 上一次我们使用百度地图实现基本的定位功能,接下来我们继续实现搜索和定位,并使用LocationOverlay绘制定位位置,同时展示如何使用自定义图标绘制并点击时弹出泡泡 如图所示: 二. ...
- UWP Popup 弹出
一:需求 做一个类似于安卓的弹出消息框,如图.当用户点击下载或者选择时,能够从底部弹出一个提示框,用于提示用户. 二:Popup 类 不需要我们自己额外去写一个弹窗类,微软自己有一个Popup 弹窗类 ...
- vant - 弹框 【Popup 弹出层】【DatetimePicker 时间选择】
[HelloWorld.vue] <template> <div class="hello"> <van-row class="m-head ...
- UWP Popup 弹出提示框
一:需求 做一个类似于安卓的弹出消息框,如图.当用户点击下载或者选择时,能够从底部弹出一个提示框,用于提示用户. 二:Popup 类 不需要我们自己额外去写一个弹窗类,微软自己有一个Popup 弹窗类 ...
随机推荐
- selenium执行JavaScript语句:控制滚动条 聚焦元素 改变下拉选项
1. 执行js脚本 控制滚动条 # http://www.cnblogs.com/yoyoketang/p/6128655.html In [347]: js = "window.scrol ...
- Linux 内核参数 arp_ignore & arp_announce 详解
arp_ignore定义了对目标地址为本机IP的ARP询问的不同应答模式. arp_announce对网络接口(网卡)上发出的ARP请求包中的源IP地址作出相应的限制:主机会根据这个参数值的不同选择使 ...
- jmeter 使用问题
问题1:导入脚本失败,提示 解决:没有安装JMemter plugins manager插件,具体安装参考http://www.cnblogs.com/cxx1/p/7883820.html,第二步.
- Json.NET Performance Tips
原文: http://www.newtonsoft.com/json/help/html/Performance.htm To keep an application consistently fas ...
- Tornado-Ajax
介绍 AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML).AJAX 不是新的编程语言,而是一种使用现有标准的新方法.AJAX是在不 ...
- ECMA Script 6_对象的扩展
对象 1. ES6 允许直接写入变量和函数,作为对象的属性和方法 const foo = 'bar'; /*****************属性的优化********************/ con ...
- JMeter参数化中存在逗号的解决方法
在Jmeter中通过CSV Data Set Config进行参数化时,如果参数化数据中存在逗号(,)我们可以通过一下方式进行设置 如何存在中文乱码,可以设置file encoding:gb2312
- foreach next 操作数组指针移动问题
2018年10月20日10:39:40 先说结论,foreach 维护的是一套属于自己的数组指针 会在操作数据的时候,分裂一套变量地址,即使你强制使用 & 取地址一样会分裂,不会引用同一套指针 ...
- 【Python基础】lpthw - Exercise 37 复习各种符号
本节需要熟悉python的符号和关键字的功能. 一.关键字 1. and 逻辑与,如 True and False == False的值为True 2. as with...as...的功能类似try ...
- tcpdump我的交叉编译(mips)
一.libpcap交叉编译 1.下载libpcap-1.8.1(http://www.tcpdump.org/) 2.解压 3.修改configure文件 a.注释掉 #if test -z &quo ...