提取了下PATH的菜单的那种动画效果。先看贴图 源码: PathMenu.zip 效果APK: PathMenu.apk 原理: 点击红色加号触发事件:
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搞定
最新推荐文章于 2021-12-27 10:56:25 发布