我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android利用ObjectAnimator实现ArcMenu

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android利用ObjectAnimator实现ArcMenu

本文介绍利用ObjectAnimator简单地实现ArcMenu,直接使用本文的ArcMenu类即可快捷地实现菜单功能。 

最终使用效果:

先看下最终的使用效果:


 private int[] imageRes = {R.id.img_menu, R.id.img_menu1, R.id.img_menu2, R.id.img_menu3, 
R.id.img_menu4, R.id.img_menu5};
private ArcMenu arcMenu;
...
//初始化,参数为资源图片id
 arcMenu = new ArcMenu(this, imageRes);
//点击事件,这边使用了annotation,直接使用findViewById然后设置监听事件也可以
  @Click
  public void img_menu() {
    mylog.d(" @Click img_menu");
    arcMenu.switchMenu();
  }
  @Click
  public void img_menu1() {
    arcMenu.clickItem();
    mylog.d(" @Click img_menu1");
  }
  @Click
  public void img_menu2() {
    arcMenu.clickItem();
    mylog.d(" @Click img_menu2");
  }
  @Click
  public void img_menu3() {
    arcMenu.clickItem();
    mylog.d(" @Click img_menu3");
  }
  @Click
  public void img_menu4() {
    arcMenu.clickItem();
    mylog.d(" @Click img_menu4");
  }
  @Click
  public void img_menu5() {
    arcMenu.clickItem();
    mylog.d(" @Click img_menu5");
  } 

布局文件中,将需要用到的图片放在同一位置。


 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/widget33"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  android:background="#262a34">
  <ImageView
    android:id="@+id/img_menu"
    android:layout_width="50dp"
    android:layout_height="50dp"
    android:layout_alignParentBottom="true"
    android:layout_alignParentRight="true"
    android:layout_marginRight="10dp"
    android:layout_marginBottom="10dp"
    android:class="lazy" data-src="@drawable/menu_add" />
  <ImageView
    android:id="@+id/img_menu1"
    android:visibility="gone"
    android:layout_width="50dp"
    android:layout_height="50dp"
    android:layout_alignParentBottom="true"
    android:layout_alignParentRight="true"
    android:layout_marginRight="10dp"
    android:layout_marginBottom="10dp"
    android:class="lazy" data-src="@drawable/float_on" />
  <ImageView
    android:id="@+id/img_menu2"
    android:visibility="gone"
    android:layout_width="50dp"
    android:layout_height="50dp"
    android:layout_alignParentBottom="true"
    android:layout_alignParentRight="true"
    android:layout_marginRight="10dp"
    android:layout_marginBottom="10dp"
    android:class="lazy" data-src="@drawable/float_on" />
  <ImageView
    android:id="@+id/img_menu3"
    android:visibility="gone"
    android:layout_width="50dp"
    android:layout_height="50dp"
    android:layout_alignParentBottom="true"
    android:layout_alignParentRight="true"
    android:layout_marginRight="10dp"
    android:layout_marginBottom="10dp"
    android:class="lazy" data-src="@drawable/float_on" />
  <ImageView
    android:id="@+id/img_menu4"
    android:visibility="gone"
    android:layout_width="50dp"
    android:layout_height="50dp"
    android:layout_alignParentBottom="true"
    android:layout_alignParentRight="true"
    android:layout_marginRight="10dp"
    android:layout_marginBottom="10dp"
    android:class="lazy" data-src="@drawable/float_on" />
  <ImageView
    android:id="@+id/img_menu5"
    android:visibility="gone"
    android:layout_width="50dp"
    android:layout_height="50dp"
    android:layout_alignParentBottom="true"
    android:layout_alignParentRight="true"
    android:layout_marginRight="10dp"
    android:layout_marginBottom="10dp"
    android:class="lazy" data-src="@drawable/float_on" />
</RelativeLayout> 

下面为截图;

 

具体实现
 初始化,通过imageRes的数量设置相邻两个图标之间的角度,同时将imageView加入imageViewList中,方便后面使用


 public class ArcMenu {
  private Activity context;
  private int[] imageRes;
  private List<ImageView> imageViewList = new ArrayList<>();
  private boolean isShowMenu = false;
  int radius = 180;
  double angle;
  public ArcMenu(Activity context, int[] imageRes) {
    angle = Math.PI / 2 / (imageRes.length - 2);
    radius = Tool.dip2px(context, radius);
    this.context = context;
    this.imageRes = imageRes;
    for (int imagRe : imageRes) {
      ImageView imageView = (ImageView) context.findViewById(imagRe);
      imageViewList.add(imageView);
    }
  }
} 


菜单弹出动画,使用ObjectAnimator,对每一个图标进行平移操作,第0个图标为菜单开关,加入旋转动画。


 private void openMenu() {
    isShowMenu = true;
    setItemVisible(true);
    ObjectAnimator animator1;
    ObjectAnimator animator2;
    List<ObjectAnimator> objectAnimators = new ArrayList<>();
    AnimatorSet set = new AnimatorSet();
    for (int i = 1; i < imageRes.length; i++) {
      animator1 = ObjectAnimator.ofFloat(imageViewList.get(i), 
"translationX", (float) (-radius * Math.sin(angle * (i-1))));
      animator2 = ObjectAnimator.ofFloat(imageViewList.get(i), "translationY", 
(float) (-radius * Math.cos(angle * (i-1))));
      objectAnimators.add(animator1);
      objectAnimators.add(animator2);
    }
    for (int i = 0; i < objectAnimators.size(); i++) {
      set.playTogether(objectAnimators.get(i));
    }
    set.setDuration(200);
    set.start();
    //第0个图标,菜单图标,加入动画
    ObjectAnimator.ofFloat(imageViewList.get(0),"rotation",0,135f).setDuration(200).start();
  } 

同理,关闭菜单


 private void closeMenu() {
    isShowMenu = false;
    ObjectAnimator animator1 = null;
    ObjectAnimator animator2;
    List<ObjectAnimator> objectAnimators = new ArrayList<>();
    AnimatorSet set = new AnimatorSet();
    for (int i = 1; i < imageRes.length; i++) {
      animator1 = ObjectAnimator.ofFloat(imageViewList.get(i), "translationX", 0);
      animator2 = ObjectAnimator.ofFloat(imageViewList.get(i), "translationY", 0);
      objectAnimators.add(animator1);
      objectAnimators.add(animator2);
    }
    animator1.addListener(new AnimatorListenerAdapter() {
      @Override
      public void onAnimationEnd(Animator animation) {
        setItemVisible(false);
        super.onAnimationEnd(animation);
      }
    });
    for (int i = 0; i < objectAnimators.size(); i++) {
      set.playTogether(objectAnimators.get(i));
    }
    set.setDuration(200);
    set.start();
    ObjectAnimator.ofFloat(imageViewList.get(0),"rotation",135f,0).setDuration(200).start();
  } 

切换菜单开关


 public void switchMenu() {
    if (isShowMenu) {
      closeMenu();
    } else {
      openMenu();
    }
  } 

图标被点击后,将所有子图标隐藏,同时调用closMenu(),将图片移回原处。


 public void clickItem() {
    setItemVisible(false);
    closeMenu();
  }
  private void setItemVisible(boolean isVisible) {
    for (int i = 1; i < imageRes.length; i++) {
      if (isVisible) {
        imageViewList.get(i).setVisibility(View.VISIBLE);
      } else {
        imageViewList.get(i).setVisibility(View.GONE);
      }
    }
  } 

至此,整个功能大致完成。现有的功能默认arcmenu为界面右下角,其他位置相应地修改公式即可以实现,可自行进行拓展,兼容不同位置。

您可能感兴趣的文章:Android获取其他应用中的assets资源Android中WindowManager与WMS的解析Android自定义动态壁纸开发(时钟)Android自定义View实现简单炫酷的球体进度球实例代码Android自定义View仿腾讯TIM下拉刷新ViewAndroid高性能日志写入方案的实现Android动态修改应用图标与名称的方法实例Android实现百度地图两点画弧线Android百度地图定位、显示用户当前位置ObjectAnimator属性动画源码分析篇


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android利用ObjectAnimator实现ArcMenu

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android利用ObjectAnimator实现ArcMenu

本文介绍利用ObjectAnimator简单地实现ArcMenu,直接使用本文的ArcMenu类即可快捷地实现菜单功能。 最终使用效果:先看下最终的使用效果:private int[] imageRes = {R.id.img_menu,
2022-06-06

android利用xml实现分割线

因为没有美工, 所以只能自己动手了。 在layout文件夹里的xml 写 方法1:在layout里面的布局xml 文件里加上面的代码
2022-06-06

Android利用GridView实现单选功能

先看看GridView实现单选效果 如果是你需要的,你可以继续往下看了 实现起来比较简单,直接上代码 主Activity的布局,一个Button用来跳转到筛选Activity一个TextView用来显示筛选后的到的结果
2022-06-06

Android:利用SharedPreferences实现自动登录

本文介绍了Android:利用SharedPreferences实现自动登录,具体如下:主要代码:public class LoginActivity extends Activity {private EditText username;
2022-06-06

Android利用GridView实现单选效果

1.实现如图所示的单选效果由于Android提供的单选按钮radiobutton只能单行或单列显示,且样式并不美观,故可用GridView进行改造,实现单选效果,而要实现这样的效果重点就在GridView的适配器这块了。首先是GridVie
2023-05-31

Android利用Chronometer实现倒计时功能

项目需要实现一个计时的功能,利用Chronometer虽然可以很方便的实现计时功能,但需要的却是一个倒计时控件。 百度了一下方法不少,倒计时的却没有,于是用Chronometer封装了一个倒计时的类,本着开源的精神,分享给大家! 废话不说了
2022-06-06

Android实现APP环境分离(利用Gradle)

一、环境分离简介 每个App项目,至少都会有两个环境:测试环境和生产环境。多的甚至有四个环境:开发环境、测试环境、预生产环境和生产环境。开发人员经常需要在环境之间切换,测试人员也同样。经常出现测试人员今天需要测试环境的最新版本,叫App开发
2022-06-06

Android利用SurfaceView实现简单计时器

自学了android有几个月了,跟着网上的节奏,应该早点写些博客来提高自己的水准的。但苦于技术水准始终不自信(也是不过关的结果吧),就一直只是将自己学习过程中的问题和重要的知识点写在自己的笔记文档中。 但,总感觉一个人写下来成就感还是欠缺了
2022-06-06

Android如何利用SoundPool实现音乐池

这篇文章主要介绍了Android如何利用SoundPool实现音乐池,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。本文实例为大家分享了Android利用SoundPool实现
2023-06-25

Android中怎么利用OKHTTP实现单例

本篇文章为大家展示了Android中怎么利用OKHTTP实现单例,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Android OKHTTP的单例和再封装的实例public class OkHttpU
2023-05-30

Android入门之利用GrdidView实现可复用Adapter

这篇文章将使用Android里的高级控件-GridView来作为我们本次的课程样例,来构建一个可复用的自定义BaseAdapter,感兴趣的小伙伴可以了解一下
2022-11-21

Android利用Intent实现读取图片操作

本文实例演示如何从图库(Gallery)中读取图像并用ImageView将它显示出来,供大家参考,具体内容如下 运行本示例前,需要先利用相机模拟拍摄一些图片到图库中。 1、运行截图 2、主要设计步骤 (1)添加ch1203_Re
2022-06-06

Android利用Intent实现记事本功能(NotePad)

本文实例为大家分享了Intent如何实现一个简单的记事本功能的演示过程,供大家参考,具体内容如下 1、运行截图 单击右上角【…】会弹出【添加】菜单项,长按某条记录会弹出快捷菜单【删除】项。2、主要设计步骤 (1)添加引用 鼠标右击【引用】à
2022-06-06

Android中怎么利用ProgressBar实现进度条

这篇文章给大家介绍Android中怎么利用ProgressBar实现进度条,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。activity_main.xml
2023-05-30

怎么在android中利用Webview实现截屏

怎么在android中利用Webview实现截屏?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。第一种方式通过调用webview.capturePicture()
2023-05-31

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录