Android(安卓)带有弹出收缩动画的扇形菜单实例
16lz
2022-06-01
介绍了Android 带有弹出收缩动画的扇形菜单实例,具有一定的参考价值,有兴趣的可以了解一下
最近试着做了个Android 带有弹出收缩动画的扇形菜单,留个笔记记录一下。
效果如下
public class MainActivity extends AppCompatActivity implements View.OnClickListener { private ImageView imgPublish; private TextView textView1; private TextView textView2; private boolean isMenuOpen = false; private List textViews = new ArrayList<>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); imgPublish = (ImageView) findViewById(R.id.img_publish); textView1 = (TextView) findViewById(R.id.tv_1); textView2 = (TextView) findViewById(R.id.tv_2); textViews.add(textView1); textViews.add(textView2); imgPublish.setOnClickListener(this); } @Override public void onClick(View v) { switch (v.getId()) { case R.id.img_publish: if (!isMenuOpen) { showOpenAnim(80); imgPublish.setImageResource(R.mipmap.publish_select); }else { showCloseAnim(80); imgPublish.setImageResource(R.mipmap.fabu); } break; } } //打开扇形菜单的属性动画, dp为半径长度 private void showOpenAnim(int dp) { textView1.setVisibility(View.VISIBLE); textView2.setVisibility(View.VISIBLE); //for循环来开始小图标的出现动画 for (int i = 0; i < textViews.size(); i++) { AnimatorSet set = new AnimatorSet(); //标题1与x轴负方向角度为20°,标题2为100°,转换为弧度 double a = -Math.cos(20 * Math.PI / 180 * (i * 2 + 1)); double b = -Math.sin(20 * Math.PI / 180 * (i * 2 + 1)); double x = a * dip2px(dp); double y = b * dip2px(dp); set.playTogether( ObjectAnimator.ofFloat(textViews.get(i), "translationX", (float) (x * 0.25), (float) x), ObjectAnimator.ofFloat(textViews.get(i), "translationY", (float) (y * 0.25), (float) y) , ObjectAnimator.ofFloat(textViews.get(i), "alpha", 0, 1).setDuration(2000) ); set.setInterpolator(new BounceInterpolator()); set.setDuration(500).setStartDelay(100); set.start(); set.addListener(new Animator.AnimatorListener() { @Override public void onAnimationStart(Animator animation) { } @Override public void onAnimationEnd(Animator animation) { //菜单状态置打开 isMenuOpen = true; } @Override public void onAnimationCancel(Animator animation) { } @Override public void onAnimationRepeat(Animator animation) { } }); } //转动加号大图标本身45° ObjectAnimator rotate = ObjectAnimator.ofFloat(imgPublish, "rotation", 0, 90).setDuration(300); rotate.setInterpolator(new BounceInterpolator()); rotate.start(); } //关闭扇形菜单的属性动画,参数与打开时相反 private void showCloseAnim(int dp) { //for循环来开始小图标的出现动画 for (int i = 0; i < textViews.size(); i++) { AnimatorSet set = new AnimatorSet(); double a = -Math.cos(20 * Math.PI / 180 * (i * 2 + 1)); double b = -Math.sin(20 * Math.PI / 180 * (i * 2 + 1)); double x = a * dip2px(dp); double y = b * dip2px(dp); set.playTogether( ObjectAnimator.ofFloat(textViews.get(i), "translationX", (float) x, (float) (x * 0.25)), ObjectAnimator.ofFloat(textViews.get(i), "translationY", (float) y, (float) (y * 0.25)), ObjectAnimator.ofFloat(textViews.get(i), "alpha", 1, 0).setDuration(2000) );// set.setInterpolator(new AccelerateInterpolator()); set.setDuration(500); set.start(); set.addListener(new Animator.AnimatorListener() { @Override public void onAnimationStart(Animator animation) { } @Override public void onAnimationEnd(Animator animation) { textView1.setVisibility(View.GONE); textView2.setVisibility(View.GONE); //菜单状态置关闭 isMenuOpen = false; } @Override public void onAnimationCancel(Animator animation) { } @Override public void onAnimationRepeat(Animator animation) { } }); } //转动加号大图标本身45° ObjectAnimator rotate = ObjectAnimator.ofFloat(imgPublish, "rotation", 0, 90).setDuration(300); rotate.setInterpolator(new BounceInterpolator()); rotate.start(); } private int dip2px(int value) { float density = getResources() .getDisplayMetrics().density; return (int) (density * value + 0.5f); }}
布局文件
<?xml version="1.0" encoding="utf-8"?>
circle_purple.xml
<?xml version="1.0" encoding="utf-8"?>
更多相关文章
- Android之Menu菜单 onCreateOptionsMenu使用Menu按键显示不了问
- Android(安卓)实现由下至上弹出并位于屏幕底部的提示框
- [Android] View动画特效(三)
- android开发之interpolator的用法详解
- android字体闪烁动画(线程)
- 7.1 DropTargetBar style
- Android(安卓)ValueAnimator和ObjectAnimator的高级用法(代码实现
- 选项菜单、子菜单、上下文菜单的使用
- Android(安卓)SDK Manager设置代理服务器和端口