全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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<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 


相关文章: 测试制作网站有哪些,测试性取向的权威测试或者网站?  深圳企业网站制作设计,在深圳如何网上全流程注册公司?  非常酷的网站设计制作软件,酷培ai教育官方网站?  制作充值网站的软件,做人力招聘为什么要自己交端口钱?  广州顶尖建站服务:企业官网建设与SEO优化一体化方案  ,巨量百应是干嘛的?  建站之星如何优化SEO以实现高效排名?  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?  济南专业网站制作公司,济南信息工程学校怎么样?  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  C#怎么创建控制台应用 C# Console App项目创建方法  建站之星如何保障用户数据免受黑客入侵?  如何在香港免费服务器上快速搭建网站?  网站制作多少钱一个,建一个论坛网站大约需要多少钱?  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  建站之星好吗?新手能否轻松上手建站?  想学网站制作怎么学,建立一个网站要花费多少?  武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?  如何在腾讯云服务器上快速搭建个人网站?  网站制作公司排行榜,抖音怎样做个人官方网站  手机网站制作与建设方案,手机网站如何建设?  七夕网站制作视频,七夕大促活动怎么报名?  如何用AWS免费套餐快速搭建高效网站?  免费视频制作网站,更新又快又好的免费电影网站?  建站之星体验版:智能建站系统+响应式设计,多端适配快速建站  建站之星各版本价格是多少?  制作农业网站的软件,比较好的农业网站推荐一下?  网站制作网站,深圳做网站哪家比较好?  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  家具网站制作软件,家具厂怎么跑业务?  C++中引用和指针有什么区别?(代码说明)  如何用西部建站助手快速创建专业网站?  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  建站之星如何快速更换网站模板?  在线制作视频网站免费,都有哪些好的动漫网站?  微课制作网站有哪些,微课网怎么进?  广州商城建站系统开发成本与周期如何控制?  建站之星安装路径如何正确选择及配置?  如何用IIS7快速搭建并优化网站站点?  无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?  如何在宝塔面板创建新站点?  免费公司网站制作软件,如何申请免费主页空间做自己的网站?  赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?  建站主机是否属于云主机类型?  建站之星免费版是否永久可用?  如何在建站之星绑定自定义域名?  建站之星如何一键生成手机站?  建站之星手机一键生成:多端自适应+小程序开发快速建站指南  昆明网站制作哪家好,昆明公租房申请网上登录入口? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。