最近试着做了个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
# 扇形弹出菜单
# 扇形菜单
# 扇形展开菜单
# Android编程实现仿优酷圆盘旋转菜单效果的方法详解【附demo源码下载】
# Android自定义控件之仿优酷菜单
# Android仿优酷圆形菜单学习笔记分享
# Android编程实现仿优酷旋转菜单效果(附demo源码)
# Android菜单(动画菜单、360波纹菜单)
# Android实现360手机助手底部的动画菜单
# Android程序开发之使用Design包实现QQ动画侧滑效果和滑动菜单导航
# Android利用属性动画实现优酷菜单
# 小图
# 弹出
# 试着
# 转换为
# 大家多多
# 留个
# setOnClickListener
# onClick
# add
# switch
# showOpenAnim
# getId
# case
# super
# setContentView
# Bundle
# savedInstanceState
# layout
# id
# img_publish
相关文章:
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
如何通过服务器快速搭建网站?完整步骤解析
建站主机类型有哪些?如何正确选型
高防服务器:AI智能防御DDoS攻击与数据安全保障
高性价比服务器租赁——企业级配置与24小时运维服务
淘宝制作网站有哪些,淘宝网官网主页?
,石家庄四十八中学官网?
高防服务器租用首荐平台,企业级优惠套餐快速部署
如何通过宝塔面板实现本地网站访问?
想学网站制作怎么学,建立一个网站要花费多少?
网站制作模板下载什么软件,ppt模板免费下载网站?
建站之星微信建站一键生成小程序+多端营销系统
北京网站制作网页,网站升级改版需要多久?
网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?
如何快速打造个性化非模板自助建站?
公众号网站制作网页,微信公众号怎么制作?
我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?
官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站
装修招标网站设计制作流程,装修招标流程?
教程网站设计制作软件,怎么创建自己的一个网站?
如何通过FTP空间快速搭建安全高效网站?
网站制作员失业,怎样查看自己网站的注册者?
如何快速生成高效建站系统源代码?
如何选择建站程序?包含哪些必备功能与类型?
如何登录建站主机?访问步骤全解析
如何用已有域名快速搭建网站?
定制建站方案优化指南:企业官网开发与建站费用解析
css网站制作参考文献有哪些,易聊怎么注册?
在线制作视频网站免费,都有哪些好的动漫网站?
网站插件制作软件免费下载,网页视频怎么下到本地插件?
新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?
网页制作模板网站推荐,网页设计海报之类的素材哪里好?
如何高效完成自助建站业务培训?
郑州企业网站制作公司,郑州招聘网站有哪些?
家具网站制作软件,家具厂怎么跑业务?
企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?
成都网站制作报价公司,成都工业用气开户费用?
官网自助建站平台指南:在线制作、快速建站与模板选择全解析
,网站推广常用方法?
如何续费美橙建站之星域名及服务?
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
公司网站制作价格怎么算,公司办个官网需要多少钱?
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?
建站之星后台密码遗忘如何找回?
如何高效利用200m空间完成建站?
电商网站制作公司有哪些,1688网是什么意思?
如何在腾讯云免费申请建站?
佛山网站制作系统,佛山企业变更地址网上办理步骤?
*请认真填写需求信息,我们会在24小时内与您取得联系。