android自定义view实现圆周运动

本文实例为大家分享了android自定义view实现圆周运动的具体代码,供大家参考,具体内容如下

思想

自定义Animation,自己定义半径,相当于原来控件的位置为(0,0),按照每个角度区间,计算新的位置,跟着时间变动

逆时针转动

public class VenusCircleAnimation extends Animation {

  private int radii;
  public VenusCircleAnimation(int radii) {
    this.radii = radii;
  }

  @Override
  protected void applyTransformation(float interpolatedTime, Transformation t) {
    //根据取值范围 确定圆周运动的角度范围。360-0
    float d = 360 * interpolatedTime;//interpolatedTime 取值范围 0-1,表示时间
    if (d > 360) { //算法二
      d = d-360;
    }
    int[] ps = getNewLocation((int) d, radii);//
    t.getMatrix().setTranslate(ps[0], ps[1]);
  }

  public int[] getNewLocation(int newAngle, int r) {
    int newAngle1;
    int newX = 0, newY = 0;
    if (newAngle >= 0 && newAngle <= 90) {
      // Math.PI/180得到的结果就是1°,然后再乘以角度得到角度
      newX = (int) ( - (r * Math.cos(newAngle * Math.PI / 180)));
      newY = (int) (r * Math.sin(newAngle * Math.PI / 180));
    } else if (newAngle >= 90 && newAngle <= 180) {// 90-180
      newAngle1 = 180 - newAngle;
      newX = (int) (r * Math.cos(newAngle1 * Math.PI / 180));
      newY = (int) (r * Math.sin(newAngle1 * Math.PI / 180));
    } else if (newAngle >= 180 && newAngle <= 270) {//180-270
      newAngle1 = 270 - newAngle;
      newX = (int) (r * Math.sin(newAngle1 * Math.PI / 180));
      newY = (int) ( - (r * Math.cos(newAngle1 * Math.PI / 180)));
    } else if (newAngle >= 270) {//270-360
      newAngle1 = 360 - newAngle;
      newX = (int) ( - (r * Math.cos(newAngle1 * Math.PI / 180)));
      newY = (int) ( - (r * Math.sin(newAngle1 * Math.PI / 180)));
    }
    return new int[]{newX, newY};
  }

}

顺时针

public class CircleAnimation extends Animation {

  private int radii;

  public CircleAnimation(int radii) {
    this.radii = radii;
  }

  @Override
  protected void applyTransformation(float interpolatedTime, Transformation t) {
    float d = 360 * interpolatedTime ;
    if (d > 360) {
      d = d - 360;
    }
    int[] ps = getNewLocation((int) d, radii);//
    t.getMatrix().setTranslate(ps[0], ps[1]);
  }

  public int[] getNewLocation(int newAngle, int r) {
    int newAngle1;
    int newX = 0, newY = 0;
    if (newAngle >= 0 && newAngle <= 90) {
      newX = (int) (r * Math.sin(newAngle * Math.PI / 180));
      newY = (int) ( - (r * Math.cos(newAngle * Math.PI / 180)));
    } else if (newAngle >= 90 && newAngle <= 180) {// 90-180
      newAngle1 = 180 - newAngle;
      newX = (int) (r * Math.sin(newAngle1 * Math.PI / 180));
      newY = (int) (r * Math.cos(newAngle1 * Math.PI / 180));
    } else if (newAngle >= 180 && newAngle <= 270) {//180-270
      newAngle1 = 270 - newAngle;
      newX = (int) ( - (r * Math.cos(newAngle1 * Math.PI / 180)));
      newY = (int) (r * Math.sin(newAngle1 * Math.PI / 180));
    } else if (newAngle >= 270 && newAngle <= 360) {//270-360
      newAngle1 = 360 - newAngle;
      newX = (int) ( - (r * Math.sin(newAngle1 * Math.PI / 180)));
      newY = (int) ( - (r * Math.cos(newAngle1 * Math.PI / 180)));
    }
    return new int[]{newX, newY};
  }
}

使用

CircleAnimation animationw = new CircleAnimation(m);
 animationw.setDuration(d);
 animationw.setRepeatCount(-1);
 animationw.setInterpolator(new LinearInterpolator());
 imageView.startAnimation(animationw);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android贝塞尔曲线实现填充不规则图形并随手指运动

    贝塞尔曲线: 贝塞尔曲线于1962,由法国工程师皮埃尔·贝塞尔所广泛发表,他运用贝塞尔曲线来为汽车的主体进行设计.贝塞尔曲线最初由 Paul de Casteljau 于 1959 年运用 de Casteljau 演算法开发,以稳定数值的方法求出贝兹曲线.贝塞尔曲线主要用于二维图形应用程序中的数学曲线,曲线由起始点,终止点(也称锚点)和控制点组成,通过调整控制点,贝塞尔曲线的形状会发生变化. 在此举一个例子,实现贝塞尔曲线,基于以下场景: 上面的图片,我们可以见到一个白色的区域,边缘为弧形,这

  • Android贝塞尔曲线初步学习第三课 Android实现添加至购物车的运动轨迹

    不知上一节高仿QQ未读消息气泡大家还喜欢么,今天继续练习贝赛尔曲线,这一节我们通过贝赛尔曲线和属性动画估值器实现添加至购物车的运动轨迹,效果如下: 1.新建自定义View,重写构造方法,初始化Paint.Path: 2.确定起始点.终止点.控制点坐标,这里我们直接固定: @Override protected void onSizeChanged(int w, int h, int oldw, int oldh) { super.onSizeChanged(w, h, oldw, oldh);

  • Android自定义View图片按Path运动和旋转

    本文实例为大家分享了Android自定义View图片按Path运动旋转的具体代码,供大家参考,具体内容如下 View: /** * author : stone * email : aa86799@163.com * time : 16/5/29 15 29 */ public class EarthPathView extends View { private Path mPath; private Paint mPaint; private Bitmap mBitmap; private P

  • Android 利用三阶贝塞尔曲线绘制运动轨迹的示例

    本篇文章主要介绍了Android 利用三阶贝塞尔曲线绘制运动轨迹的示例,分享给大家,具体如下: 实现点赞效果,自定义起始点以及运动轨迹 效果图: xml布局: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/rl_root&

  • android自定义view实现圆周运动

    本文实例为大家分享了android自定义view实现圆周运动的具体代码,供大家参考,具体内容如下 思想 自定义Animation,自己定义半径,相当于原来控件的位置为(0,0),按照每个角度区间,计算新的位置,跟着时间变动 逆时针转动 public class VenusCircleAnimation extends Animation { private int radii; public VenusCircleAnimation(int radii) { this.radii = radii

  • Android自定义View实现游戏摇杆键盘的方法示例

    前言 本文主要给大家介绍的是关于Android自定义View实现游戏摇杆键盘的相关内容,为什么会有这篇文章呢?因为在之前的一个项目,操作方向的方式为上下左右,左上需要同时按住左键和右键的方式进行操作. 如下图: 近来需要升级项目,操作方式改为类似王者荣耀的摇杆操作. 如下图: 好了,下面话不多说了,跟着小编来一起看看是如何实现的吧. 绘制背景 实现遥感按钮,需要绘制背景,绘制中心的遥感按钮.绘制遥感背景,需要创建一个RemoteViewBg类,存储背景图,减少重复创建bitmap. Remote

  • Android自定义view实现阻尼效果的加载动画

    效果: 需要知识: 1. 二次贝塞尔曲线 2. 动画知识 3. 基础自定义view知识 先来解释下什么叫阻尼运动 阻尼振动是指,由于振动系统受到摩擦和介质阻力或其他能耗而使振幅随时间逐渐衰减的振动,又称减幅振动.衰减振动.[1] 不论是弹簧振子还是单摆由于外界的摩擦和介质阻力总是存在,在振动过程中要不断克服外界阻力做功,消耗能量,振幅就会逐渐减小,经过一段时间,振动就会完全停下来.这种振幅随时间减小的振动称为阻尼振动.因为振幅与振动的能量有关,阻尼振动也就是能量不断减少的振动.阻尼振动是非简谐运

  • Android 自定义View 密码框实例代码

    暴露您view中所有影响可见外观的属性或者行为. •通过XML添加和设置样式 •通过元素的属性来控制其外观和行为,支持和重要事件交流的事件监听器 详细步骤见:Android 自定义View步骤 效果图展示: 支持的样式 可以通过XML定义影响外边和行为的属性如下 边框圆角值,边框颜色,分割线颜色,边框宽度,密码长度,密码大小,密码颜色 <declare-styleable name="PasswordInputView"> <attr name="borde

  • Android自定义View详解

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/24252901 很多的Android入门程序猿来说对于Android自定义View,可能都是比较恐惧的,但是这又是高手进阶的必经之路,所有准备在自定义View上面花一些功夫,多写一些文章.先总结下自定义View的步骤: 1.自定义View的属性 2.在View的构造方法中获得我们自定义的属性 [ 3.重写onMesure ] 4.重写onDraw 我把3用[]标出了,所以说3不一

  • Android自定义View中attrs.xml的实例详解

    Android自定义View中attrs.xml的实例详解 我们在自定义View的时候通常需要先完成attrs.xml文件 在values中定义一个attrs.xml 然后添加相关属性 这一篇先详细介绍一下attrs.xml的属性. <?xml version="1.0" encoding="utf-8"?> <resources> //自定义属性名,定义公共属性 <attr name="titleText" for

  • Android自定义View 仿QQ侧滑菜单的实现代码

    先看看QQ的侧滑效果 分析一下 先上原理图(不知道能否表达的清楚 ==) -首先这里使用了 Android 的HorizontalScrollView 水平滑动布局作为容器,当然我们需要继承它自定义一个侧滑视图 - 这个容器里面有一个父布局(一般用LinerLayout,本demo用的是),这个父布局里面有且只有两个子控件(布局),初始状态菜单页的位置在Y轴上存在偏移这样可以就可以形成主页叠在菜单页的上方的视觉效果:然后在滑动的过程程中 逐渐修正偏移,最后菜单页和主页并排排列.原理搞清了实现起来

  • Android自定义View绘制随机生成图片验证码

    本篇文章讲的是Android自定义View之随机生成图片验证码,开发中我们会经常需要随机生成图片验证码,但是这个是其次,主要还是想总结一些自定义View的开发过程以及一些需要注意的地方. 按照惯例先看看效果图: 一.先总结下自定义View的步骤: 1.自定义View的属性 2.在View的构造方法中获得我们自定义的属性 3.重写onMesure 4.重写onDraw 其中onMesure方法不一定要重写,但大部分情况下还是需要重写的 二.View 的几个构造函数 1.public CustomV

  • Android自定义View绘制的方法及过程(二)

    上一篇<Android 自定义View(一) Paint.Rect.Canvas介绍>讲了最基础的如何自定义一个View,以及View用到的一些工具类.下面讲下View绘制的方法及过程 public class MyView extends View { private String TAG = "--------MyView"; private int width, height; public MyView(Context context, AttributeSet a

  • Android自定义View实现等级滑动条的实例

     Android自定义View实现等级滑动条的实例 实现效果图: 思路: 首先绘制直线,然后等分直线绘制点: 绘制点的时候把X值存到集合中. 然后绘制背景图片,以及图片上的数字. 点击事件down的时候,换小图片为大图片.move的时候跟随手指移动. up的时候根据此时的X计算最近的集合中的点,然后自动吸附回去. 1,自定义属性 <?xml version="1.0" encoding="utf-8"?> <resources> <de

随机推荐