FloatingActionButton实现 展开/折叠 的多级悬浮菜单
来源:互联网 发布:音乐软件下载 编辑:程序博客网 时间:2024/06/04 18:48
作者:阿钟
博客:http://my.csdn.net/a_zhon
虽然类似这样效果的库网上现在已经有一大堆了,甚至写的比较完美那我为什么还是要去实现呢?理由也很简单:只有自己尝试着去实现才能体会其中的奥妙 ,才能学习到新的知识这样当你在遇到自己陌生的东西就能从容的解决了。
一:万年必放效果图(没效果图鬼知道你写的是啥…)
二:使用详情
https://github.com/azhong1011/SuspensionFAB/blob/master/README.md
三:总体的实现思路
注
继承RelativeLayout 并往里面添加要展示的菜单按钮,默认不展示的时候将其设置为隐藏状态。剩下的重点就是将隐藏的菜单展示出来,这里我通过ObjectAnimator(属性动画)实现位移动画(如果还没了解过的童鞋可以网上搜一搜资料ObjectAnimator)、折叠时同样使用位移动画只需将坐标反转一下即可。
四:为了支持更高的扩展性,供使用者自定义每个菜单按钮的动画在这里添加了一个动画管理者(AnimationManager)只需要继承并实现所有的抽象方即可
只需要在动画执行的时候调用manager中的方法,如下代码:
五:这里对菜单展开的方向使用了枚举来来定义 ExpandOrientation,之前对枚举也是一脸蒙蔽现在用着用着也就会了、在实际运用中也是非常的爽 ^_^。
六:因为SuspensionFab view的默认大小正好是默认按钮的大小,而按钮还有阴影效果所以会导致阴影显示不全如下左图;要解决这个问题也是很简单第一种就是加大view的高宽(这也是最常用的)、第二种就是在他的父布局容器中添加android:clipChildren=”false”这个属性就是允许子view可以超出父容器的大小,这样阴影也就全部显示了如下右图:
注
这里需要注意的是:虽然view可以超出父容器,但是如果你需要点击事件的话就比较坑了,因为只有点击原来的容器范围内才能响应点击事件(不知道为什么,有大神知道可以告知一二)….
一命二运三风水,四修阴德五读书!
刘桂林
微信号 : Android_LiuGuiLin
新浪微博:@刘某人程序员
- FloatingActionButton实现 展开/折叠 的多级悬浮菜单
- FloatingActionButton实现 展开/折叠 的多级悬浮菜单
- 纯css实现多级折叠菜单,折叠树
- 菜单折叠的实现
- javascript使用DOM模型和CSS实现菜单的折叠和展开
- Android编程:悬浮菜单按钮FloatingActionButton实例
- Axure折叠与展开效果的实现
- jquery实现内容的折叠与展开
- 异步请求的多级可增长折叠菜单
- 折叠菜单的实现(不明白)
- js实现折叠&展开
- jquery mutillevel Accordion 多级折叠组件 多级折叠菜单
- 用于控制二级菜单展开/折叠的函数
- 可滑动展开折叠的jQurey简洁信息导航菜单
- 多级树形菜单的实现
- 多级树形菜单的实现
- 多级菜单的逻辑实现
- Android 多级菜单的实现
- 自定义FlexibleLayout动态加载页面布局实现标题与内容分离
- 巧用第三方快速开发Android App 热门第三方SDK及框架
- MediaProjection实现截图,与MediaMuxer实现录屏为MP4,Gif格式
- Android打造不一样的圆盘签到
- 关于IE8和IE8以上加载CSS文件时的不能加载全的问题
- FloatingActionButton实现 展开/折叠 的多级悬浮菜单
- 自定义FlexibleLayout动态加载页面布局实现title与content分离
- 公开课 | 佐治亚理工大学宋乐教授:用Structure2Vec提取特征,解决网络数据的表征学习问题
- 用神经网络续写《权力的游戏》,这个脑洞有点大(附完整小说下载)
- 太上感应篇0036
- 022:第二章 导数的定义
- Leetcode526. 回溯法之应用(一):统计数组排列数目
- 太上感应篇0037
- Python浅拷贝与深拷贝