右上菜单,可以通过 重写 onCreateOptionsMenu指定 menu, 重写 onOptionsItemSelected 来响应点击事件

不过 这个菜单在某些手机上弹出的有点卡顿,而且如果不对主题进行设置,会从actionbar 上直接弹出,而不是下面

如果想从下面弹出,要先添加一个style

    <style name="MenuStyle" parent="@style/Widget.AppCompat.Light.PopupMenu.Overflow"><item name="overlapAnchor">false</item></style>

之后在activity引用的主题中添加一行  就行了

 <item name="actionOverflowMenuStyle">@style/MenuStyle</item>

Menu在没有特别要求的情况还是很好用的,但是如果要求比较复杂的时候就不如用PopupWindow了

要实现如图的效果

先拿到从美工拿到的图片

打开sdk的 tools文件夹   打开 draw9patch.bat  把图片拖进去

画黑边   左上两个方向的黑边 表示拉伸部分

右下表示布局中控件内容显示的区域

如果画错了 按住shift 抹掉

完成之后save

布局

  1 <?xml version="1.0" encoding="utf-8"?>
  2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3               android:layout_width="wrap_content"
  4               android:layout_height="wrap_content"
  5               android:background="@drawable/pop_bg_shadow9"
  6               android:gravity="center_horizontal"
  7               android:orientation="vertical"
  8     >
  9
 10     <LinearLayout
 11         android:id="@+id/ll_action_config"
 12         android:layout_width="match_parent"
 13         android:layout_height="wrap_content"
 14         android:gravity="center_vertical"
 15         android:orientation="horizontal"
 16         android:padding="10dp"
 17         >
 18
 19         <ImageView
 20             android:layout_width="25dp"
 21             android:layout_height="25dp"
 22             android:src="@drawable/pop_setting"/>
 23
 24         <TextView
 25             android:layout_width="wrap_content"
 26             android:layout_height="wrap_content"
 27             android:paddingLeft="15dp"
 28             android:text="关联配置"
 29             android:textColor="@color/white"/>
 30
 31     </LinearLayout>
 32
 33     <LinearLayout
 34         android:id="@+id/ll_action_history"
 35         android:layout_width="match_parent"
 36         android:layout_height="wrap_content"
 37         android:gravity="center_vertical"
 38         android:orientation="horizontal"
 39         android:padding="10dp"
 40         >
 41
 42         <ImageView
 43             android:layout_width="25dp"
 44             android:layout_height="25dp"
 45             android:src="@drawable/pop_history"/>
 46
 47         <TextView
 48             android:layout_width="wrap_content"
 49             android:layout_height="wrap_content"
 50             android:paddingLeft="15dp"
 51             android:text="历史记录"
 52             android:textColor="@color/white"/>
 53
 54     </LinearLayout>
 55
 56     <LinearLayout
 57         android:id="@+id/ll_action_ip"
 58         android:layout_width="match_parent"
 59         android:layout_height="wrap_content"
 60         android:gravity="center_vertical"
 61         android:orientation="horizontal"
 62         android:padding="10dp"
 63         >
 64
 65         <ImageView
 66             android:layout_width="25dp"
 67             android:layout_height="25dp"
 68             android:src="@drawable/pop_ip"/>
 69
 70         <TextView
 71             android:layout_width="wrap_content"
 72             android:layout_height="wrap_content"
 73             android:paddingLeft="15dp"
 74             android:text="IP地址"
 75             android:textColor="@color/white"/>
 76
 77     </LinearLayout>
 78
 79     <LinearLayout
 80         android:id="@+id/ll_action_about"
 81         android:layout_width="match_parent"
 82         android:layout_height="wrap_content"
 83         android:gravity="center_vertical"
 84         android:orientation="horizontal"
 85         android:padding="10dp"
 86         >
 87
 88         <ImageView
 89             android:layout_width="25dp"
 90             android:layout_height="25dp"
 91             android:src="@drawable/pop_about"/>
 92
 93         <TextView
 94             android:layout_width="wrap_content"
 95             android:layout_height="wrap_content"
 96             android:paddingLeft="15dp"
 97             android:text="关于"
 98             android:textColor="@color/white"/>
 99
100     </LinearLayout>
101 </LinearLayout>

View Code

现在要实现点击 右上菜单 弹出 这个布局,同时菜单的图标会变换。

在menu目录 新建一个xml    默认icon是 more_close

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"><itemandroid:id="@+id/action_menu"android:icon="@drawable/more_close"android:title="菜单"app:showAsAction="always"></item>
</menu>

回到activity

    @Overridepublic boolean onCreateOptionsMenu(Menu menu) {this.menu = menu;getMenuInflater().inflate(R.menu.face, menu);return super.onCreateOptionsMenu(menu);}@Overridepublic boolean onOptionsItemSelected(MenuItem item) {switch (item.getItemId()) {case R.id.action_menu:View view=findViewById(R.id.action_menu);showActionMenuPopup(view);break;}return super.onOptionsItemSelected(item);}

红色部分都是关键部分

先看  showActionMenuPopup  这个弹出菜单的方法

首先要改变菜单的图标

menu.getItem(0).setIcon(getResources().getDrawable(R.drawable.more_open));

这个menu是 全局的

private Menu menu;

在 onCreateOptionsMenu 中 把这个menu初始化

之后 设置 PopupWindow

 1         View view=LayoutInflater.from(this).inflate(R.layout.popup_actionmenu,null);
 2         actionmenupopupWindow = new PopupWindow(view, LinearLayout.LayoutParams.WRAP_CONTENT,LinearLayout.LayoutParams.WRAP_CONTENT);
 3         actionmenupopupWindow.setContentView(view);
 4
 5         view.findViewById(R.id.ll_action_config).setOnClickListener(this);
 6         view.findViewById(R.id.ll_action_history).setOnClickListener(this);
 7         view.findViewById(R.id.ll_action_ip).setOnClickListener(this);
 8         view.findViewById(R.id.ll_action_about).setOnClickListener(this);
 9
10         actionmenupopupWindow.setFocusable(true);
11         actionmenupopupWindow.setBackgroundDrawable(new BitmapDrawable());
12
13         actionmenupopupWindow.setOnDismissListener(new PopupWindow.OnDismissListener() {
14             @Override
15             public void onDismiss() {
16                 menu.getItem(0).setIcon(getResources().getDrawable(R.drawable.more_close));
17             }
18         });
19
20         actionmenupopupWindow.showAsDropDown(v);

5-8  设置弹出菜单的点击事件

11  点击PopupWindow之外的地方PopupWindow消失

13-18  监听PopupWindow消失  改变菜单图标

20  showAsDropDown  从下方出现   肯定要是一个view的, 回到onOptionsItemSelected  找到右上菜单的view  传入了方法中,最后在这里使用

还有一个显示方法   直接指定位置,不过要测量出状态栏和actionbar的高度

actionmenupopupWindow.showAtLocation(findViewById(R.id.action_menu),Gravity.RIGHT|Gravity.TOP ,0, getStatusBarHeight(this)+getSupportActionBar().getHeight());

IOS有一个底部菜单控件 UIActionSheet

安卓方面想实现这个  有第三方的 ActionSheet    有 谷歌官方的design包  BottomSheet

用PopupWindow 也可以实现

rootview = LayoutInflater.from(this).inflate(R.layout.activity_main,null);

 1         View view= LayoutInflater.from(this).inflate(R.layout.popup_camera_sel,null);
 2         bottompopupWindow = new PopupWindow(view, LinearLayout.LayoutParams.MATCH_PARENT,LinearLayout.LayoutParams.WRAP_CONTENT);
 3
 4         bottompopupWindow.setContentView(view);
 5
 6         view.findViewById(R.id.ll_gallery).setOnClickListener(this);
 7         view.findViewById(R.id.ll_camera).setOnClickListener(this);
 8         view.findViewById(R.id.ll_cancle).setOnClickListener(this);
 9
10         WindowManager.LayoutParams lp = getWindow().getAttributes();
11         lp.alpha = 0.6f;
12         getWindow().setAttributes(lp);
13
14         bottompopupWindow.setFocusable(true);
15         bottompopupWindow.setBackgroundDrawable(new BitmapDrawable());
16         bottompopupWindow.setAnimationStyle(R.style.mypopwindow_anim_style);
17
18         bottompopupWindow.setOnDismissListener(new PopupWindow.OnDismissListener() {
19             @Override
20             public void onDismiss() {
21                 WindowManager.LayoutParams lp = getWindow().getAttributes();
22                 lp.alpha = 1f;
23                 getWindow().setAttributes(lp);
24             }
25         });
26         bottompopupWindow.showAtLocation(rootview, Gravity.BOTTOM, 0, 0);

10-12   18-25   改变屏幕的透明度

style      从底部升上来 降下去的动画

    <style name="mypopwindow_anim_style"><item name="android:windowEnterAnimation">@anim/popshow_anim</item><!-- 指定显示的动画xml --><item name="android:windowExitAnimation">@anim/pophidden_anim</item><!-- 指定消失的动画xml --></style>

show

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"><translateandroid:duration="500"android:fromYDelta="50%p"android:toYDelta="0" />
</set>

hide

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"><translateandroid:duration="500"android:fromYDelta="0"android:toYDelta="50%p" />
</set>

布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="wrap_content"android:background="@color/white"android:orientation="vertical"android:gravity="center"><LinearLayoutandroid:id="@+id/ll_gallery"android:layout_width="match_parent"android:layout_height="50dp"android:gravity="center"><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:text="相册"android:textColor="#333333"android:textSize="20sp"/></LinearLayout><!--<TextView--><!--android:layout_width="200dp"--><!--android:layout_height="1dp"--><!--android:background="#838B8B"--><!--/>--><ImageViewandroid:src="@drawable/line_pop"android:scaleType="centerCrop"android:layout_width="match_parent"android:layout_height="wrap_content"/><LinearLayoutandroid:id="@+id/ll_camera"android:layout_width="match_parent"android:layout_height="50dp"android:gravity="center"><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:text="相机"android:textColor="#333333"android:textSize="20sp"/></LinearLayout><!--<TextView--><!--android:layout_width="200dp"--><!--android:layout_height="1dp"--><!--android:background="#838B8B"--><!--/>--><ImageViewandroid:src="@drawable/line_pop"android:scaleType="centerCrop"android:layout_width="match_parent"android:layout_height="wrap_content"/><LinearLayoutandroid:id="@+id/ll_cancle"android:layout_width="match_parent"android:layout_height="50dp"android:gravity="center"><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:text="取消"android:textSize="20sp"/></LinearLayout></LinearLayout>

View Code

最后 记得响应完点击事件之后  dismiss 关闭PopupWindow

转载于:https://www.cnblogs.com/demon9/p/6021980.html

项目回顾-PopupWindow相关推荐

  1. [项目回顾]基于Annotation与SpringAOP的缓存简单解决方案

    [项目回顾]基于Annotation与SpringAOP的缓存简单解决方案 参考文章: (1)[项目回顾]基于Annotation与SpringAOP的缓存简单解决方案 (2)https://www. ...

  2. 【项目回顾】基于Yanshee的AI服务型机器人(一)

    1月20日-1月25日 我参加了河海大学和深圳优必选公司联合举办的训练营 作为机器人领域的龙头企业,优必选公司的产品Alpha曾经登陆过春晚进行表演,这次活动中他们的机器人产品Yanshee也非常厉害 ...

  3. 【项目回顾】基于Yanshee的AI服务型机器人(二)

    1月20日-1月25日 我参加了河海大学和深圳优必选公司联合举办的训练营 作为机器人领域的龙头企业,优必选公司的产品Alpha曾经登陆过春晚进行表演,这次活动中他们的机器人产品Yanshee也非常厉害 ...

  4. 【项目回顾】基于Yanshee的AI服务型机器人(三)

    1月20日-1月25日 我参加了河海大学和深圳优必选公司联合举办的训练营 作为机器人领域的龙头企业,优必选公司的产品Alpha曾经登陆过春晚进行表演,这次活动中他们的机器人产品Yanshee也非常厉害 ...

  5. 项目回顾之三:练字秀【已开源】

    发现今天正好是自己注册博客园一周年,时间过得真快.很感谢博客园在过去一年里陪伴着我的成长,在这里不仅可以拜读大牛的博客,还能作为了解业界的窗口,时时关注正在IT界上正在发生的事情.过去的一年,迷茫过, ...

  6. 0525 项目回顾7.0

    一.sprint总结 当谈到团队,我开始真的不知道团队是怎么样的,怎么样进行工作的,要该怎么出力团队的关系,有时候会涉及到个人问题,是不是该考虑进来,但是很多时候是不能的,每一个人作为团队的一份子,有 ...

  7. Pytorch深度学习实战项目回顾

    1.前言 很久没有碰Pytorch了,准备以实战项目代码回顾的方式进行复习. 2.Pytorch安装 现在我又切回了ubuntu系统,里面没有Pytorch,所以顺便从Pytorch最新版安装开始讲起 ...

  8. 个人任务五-事后诸葛亮(项目回顾)

    设想和目标 1. 我们的软件要解决什么问题?是否定义得很清楚? 我们的软件主要是为了让用户感兴趣以及提升用户游玩的舒适度. 是,定义的很清楚,我们的软件是一款轻量级的网页小游戏合集. 2. 是否有充足 ...

  9. GD项目回顾总结之预热

    古人有云"温故而知新",GD项目从开始到完善也有3个多月的时间了,也该是给这段时间的工作做个总结了,接下来博主将通过一系列的总结来给这段美好而又精彩的历程画上一个完美的句号. 暂时 ...

最新文章

  1. 源码分析 @angular/cdk 之 Portal
  2. Codemirror-开源在线代码编辑器
  3. 对接第三方平台JAVA接口问题推送和解决
  4. 【CyberSecurityLearning 40】网络地址配置(Kali/CentOS)
  5. 超图理论的一点理解(一)
  6. Angular - - angular.element
  7. Node-ES6模块化
  8. Strusts2笔记6--拦截器
  9. CF卡镜像备份及恢复系统
  10. 启动prometheus问题-opening storage failed
  11. mtk audio笔记
  12. 淘宝新品补单平台怎么样才能为你的产品精准打标?大神导航,一个神奇的网站,从此开启大神之路!
  13. s7五杀大数据英雄_S7入围赛战报:首个五杀!LYN击败GMB
  14. 网络编程基础知识概括帮助你了解架框组成客户端服务端架构
  15. 揭秘Internet.org:这是扎克伯格的野心还是使命?
  16. 如何成为一名合格的程序员?
  17. 云鲸扫拖一体机器人说明书_云鲸小白鲸扫拖一体机器人 真实的测评带你走进智能化家居时代...
  18. syncthing开源工具,同步文件内容,入门操作简要指导
  19. 除网易、新浪、腾讯、TOM四大企业邮箱外还有哪些?
  20. 软件测试睡眠原理,智能手环检测睡眠质量的原理?

热门文章

  1. 【HDU - 1867 】A + B for you again(KMP,next数组应用)
  2. 【HDU - 5918 】Sequence I (数组(字符串)匹配问题,可选KMP)
  3. 【qduoj】最长公共子串
  4. 【九度oj 1135】【OpenJ_Bailian - 2915】 字符串排序 (水)
  5. 使用matplotlib进行简单的数据展示
  6. android adb 开机广播,Android中常用的adb指令
  7. ip地址合不合法怎么看_到底醇基燃料合不合法呢?
  8. matlab储备池算法,储备池计算概述.pdf
  9. mysql不能通过ip地址访问权限_解决mysql中只能通过localhost访问不能通过ip访问的问题...
  10. java二分查找递归_java学习之—递归实现二分查找法