最近试着做了个Android 带有弹出收缩动画的扇形菜单,留个笔记记录一下。
效果如下
public class MainActivity extends AppCompatActivity implements View.OnClickListener { private ImageView imgPublish; private TextView textView1; private TextView textView2; private boolean isMenuOpen = false; private List<TextView> 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"?> <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.example.lina.animationapplication.MainActivity"> <TextView android:id="@+id/tv_1" android:layout_width="40dp" android:layout_height="40dp" android:layout_gravity="bottom|end" android:layout_marginBottom="40dp" android:layout_marginRight="40dp" android:gravity="center" android:text="标题1" android:textColor="#ffffff" android:visibility="gone" android:background="@drawable/circle_purple" /> <TextView android:id="@+id/tv_2" android:layout_width="40dp" android:layout_height="40dp" android:layout_gravity="bottom|end" android:layout_marginBottom="40dp" android:layout_marginRight="40dp" android:gravity="center" android:text="标题2" android:textColor="#ffffff" android:visibility="gone" android:background="@drawable/circle_orange"/> <ImageView android:id="@+id/img_publish" android:layout_width="60dp" android:layout_height="60dp" android:layout_gravity="bottom|end" android:layout_marginBottom="35dp" android:layout_marginRight="35dp" android:src="@mipmap/fabu" /> </FrameLayout>
circle_purple.xml
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="oval"> <solid android:color="#5d2a89" /> </shape>
参考
Android开罐头———快速打造扇形卫星菜单
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍Android PopupMenu弹出菜单的实现,包括了Android PopupMenu弹出菜单的实现的使用技巧和注意事项,需要的朋友参考一下 Android PopupMenu弹出菜单的实现 (1)布局文件:用于弹出菜单的处罚button: (2)res-menu目录下的main.xml文件: (3)类的文件: 如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢
本文向大家介绍android SectorMenuView底部导航扇形菜单的实现代码,包括了android SectorMenuView底部导航扇形菜单的实现代码的使用技巧和注意事项,需要的朋友参考一下 这次分析一个扇形菜单展开的自定义View, 也是我实习期间做的一个印象比较深刻的自定义View, 前后切换了很多种实现思路, 先看看效果展示 效果展示 效果分析 点击圆形的FloatActionB
本文向大家介绍JavaScript实战之带收放动画效果的导航菜单,包括了JavaScript实战之带收放动画效果的导航菜单的使用技巧和注意事项,需要的朋友参考一下 虽然有很多插件可用,但为了共同提高,我做了一系列JavaScript实战系列的实例,分享给大家,前辈们若有好的建议,请务必指出,免得误人子弟啊! 今天是第一战:带收放动画效果的菜单,效果如下图:(样式有点丑(-^-)) ( 由于在写本
本文向大家介绍简单实现Android弹出菜单效果,包括了简单实现Android弹出菜单效果的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Android弹出菜单效果的具体代码,供大家参考,具体内容如下 功能描述:用户单击按钮弹出菜单。当用户选择一个菜单项,会触发MenuItemClick事件并让弹出的菜单消失;如果用户在菜单外单击,则直接消失弹出的菜单。当菜单消失时,会引发Dismi
我创建了这个弹出菜单,但背景阴影缺失。我如何添加一些?如果阴影只在左侧和底部,那就太酷了。 这里有一张图片:你可以看到弹出窗口的颜色和工具栏下面的活动背景是齐头并进的。 这是我的代码: 活动代码段 弹出窗口。xml 编辑:
mui框架内置了弹出菜单插件,弹出菜单显示内容不限,但必须包裹在一个含.mui-popover类的div中,如下即为一个弹出菜单内容: <div id="popover" class="mui-popover"> <ul class="mui-table-view"> <li class="mui-table-view-cell"><a href="#">Item1</a></li