原来PATH的菜单效果如此简单。布局+TranslateAnimation搞定
来源:互联网 发布:淘宝超市怎么开 编辑:程序博客网 时间:2024/06/02 12:15
本帖最后由 shenallan 于 2012-2-29 16:05 编辑
提取了下PATH的菜单的那种动画效果。先看贴图
源码: PathMenu.zip
效果APK: PathMenu.apk
原理:
点击红色加号触发事件:
- public static void startAnimationsIn(ViewGroup viewgroup,int durationMillis) {
- for (int i = 0; i < viewgroup.getChildCount(); i++) {
- ImageButton inoutimagebutton = (ImageButton) viewgroup
- .getChildAt(i);
- inoutimagebutton.setVisibility(0);
- MarginLayoutParams mlp = (MarginLayoutParams) inoutimagebutton.getLayoutParams();
- Animation animation = new TranslateAnimation(mlp.rightMargin-xOffset,0F,yOffset + mlp.bottomMargin, 0F);
- //这个地方就是相对和绝对位置的区别,其实还有4个参数没有显示出来,但是她会根据单位自动识别。原句应该是:
- //new TranslateAnimation(Animation.ABSOLUTE,mlp.rightMargin - xOffset, Animation.RELATIVE_TO_SELF,0F,Animation.ABSOLUTE, yOffset + mlp.bottomMargin, Animation.RELATIVE_TO_SELF,0F);
- animation.setFillAfter(true);animation.setDuration(durationMillis);
- animation.setStartOffset((i * 100)
- / (-1 + viewgroup.getChildCount()));
- animation.setInterpolator(new OvershootInterpolator(2F));
- inoutimagebutton.startAnimation(animation);
- }
- }
Animation animation = new TranslateAnimation(0F,mlp.rightMargin-xOffset, 0F,yOffset + mlp.bottomMargin);
其中xOffset yOffset由布局中首尾item距离屏幕边距的距离。
private static int xOffset = 15;
private static int yOffset = -13;
public static void initOffset(Context context){//由布局文件
xOffset = (int) (10.667 *context.getResources().getDisplayMetrics().density);
yOffset = -(int) (8.667 *context.getResources().getDisplayMetrics().density);
}
如下图
值得一提的是 interpolator的使用,PATH中使用了OvershootInterpolator以及AnticipateInterpolator。
interpolator 被用来修饰动画效果,定义动画的变化率,可以使存在的动画效果可以 accelerated(加速),decelerated(减速),repeated(重复),bounced(弹跳)等。
AccelerateDecelerateInterpolator 在动画开始与介绍的地方速率改变比较慢,在中间的时候加速
AccelerateInterpolator 在动画开始的地方速率改变比较慢,然后开始加速
AnticipateInterpolator 开始的时候向后然后向前甩
AnticipateOvershootInterpolator 开始的时候向后然后向前甩一定值后返回最后的值
BounceInterpolator 动画结束的时候弹起
CycleInterpolator 动画循环播放特定的次数,速率改变沿着正弦曲线
DecelerateInterpolator 在动画开始的地方快然后慢
LinearInterpolator 以常量速率改变
OvershootInterpolator 向前甩一定值后再回到原来位置
感谢小熊屁屁不辞辛劳的努力,添加了按钮item点击放大的动画
代码 PathMenu.zip
另修改:添加了动画结束后将六个按钮焦点去掉的语句,防止阻挡到下面那一层的事件。
- 原来PATH的菜单效果如此简单。布局+TranslateAnimation搞定
- 原来PATH的菜单效果如此简单。布局+TranslateAnimation搞定
- 原来PATH的菜单效果如此简单。布局+TranslateAnimation搞定 and 高仿小米launcher(ZAKER)跨屏拖动item 02-29最新更新
- 原来PATH的菜单效果如此简单。布局+TranslateAnimation搞定 and 高仿小米launcher(ZAKER)跨屏拖动item 02-29最新更新
- 原来PATH的菜单效果如此简单。布局+TranslateAnimation搞定 and 高仿小米launcher(ZAKER)跨屏拖动item 02-29最新更新
- 原来PATH的菜单效果如此简单。布局+TranslateAnimation搞定 and 高仿小米launcher(ZAKER)跨屏拖动item 02-29最新更新
- Path----布局+TranslateAnimation
- 原来DataTable的Distinct竟如此简单!
- 原来问题如此简单
- 原来lucene如此简单
- 原来英语单词如此简单!
- 原来oracle的clob字段处理是如此的简单
- 原来win+apache实现ssl的证书认证如此简单
- 原来zabbix监控进程与端口是如此的简单!
- [转]屏幕截屏原来是如此的简单
- Path的Menu菜单(加号)效果
- 模仿Path菜单按钮的效果
- 模仿Path菜单按钮的效果
- 把经纬度显示定位在google地图 (精简)
- NAT,ARP之”混战
- bit
- PROTEL常用元件封装列表
- 计算纳税金额
- 原来PATH的菜单效果如此简单。布局+TranslateAnimation搞定
- 遇到的计算机日语总结(待续)
- gedit显示行号
- 两个多位数相乘
- Sharepoint 2007 权限开发(二)
- CString类型
- 百度之星 2005年 初赛题目一 java 版本
- PPT超链接字体颜色修改方法
- 程序员,你应该知道(转)