旋转动画的一点总结

方式一:


<?xml version="1.0" encoding="utf-8"?>

<set xmlns:android="http://schemas.android.com/apk/res/android">

    <rotate

    android:duration="2000"

    android:fillAfter="false"

    android:fillBefore="true"

    android:fillEnabled="true"

    android:fromDegrees="0"

    android:pivotX="50%"

  android:pivotY="50%"

    android:repeatCount="0"

    android:repeatMode="restart"

    android:startOffset="0"

    android:toDegrees="360"/>

</set>


final Animation animation = AnimationUtils.loadAnimation(mActivity, R.anim.welcome_anim);

animation.setInterpolator(new LinearInterpolator());

ivPoint.startAnimation(animation);

用调用xml的方式实现,本质是还是Animation动画,可以在xml里面设置各种参数

属性:

interpolator 指定一个动画的插入器

在我试验过程中,使用android.res.anim中的资源时候发现有三种动画插入器:

accelerate_decelerate_interpolator 加速-减速 动画插入器

accelerate_interpolator 加速-动画插入器

decelerate_interpolator 减速- 动画插入器

fromDegrees 属性为动画起始时物件的角度

toDegrees 属性为动画结束时物件旋转的角度 可以大于360度

说明:

当角度为负数——表示逆时针旋转

当角度为正数——表示顺时针旋转

(负数from——to正数:顺时针旋转)

(负数from——to负数:逆时针旋转)

(正数from——to正数:顺时针旋转)

(正数from——to负数:逆时针旋转)

pivotX 属性为动画相对于物件的X坐标的开始位置

pivotY 属性为动画相对于物件的Y坐标的开始位置

说明: 以上两个属性值 从0%-100%中取值, 50%为物件的X或Y方向坐标上的中点位置。如果这个数值不是一个百分数,而是一个具体的数值,那就是一个px为单位的坐标

android:pivotX 表示缩放/旋转起点 X 轴坐标,可以是整数值、百分数(或者小数)、百分数p 三种样式,比如 50、50% / 0.5、50%p。需要明确的是,这里以进行动画控件的左上角为原点坐标,当属性值为数值,如 50 时,表示原点坐标加上 50px,作为起始点;如果是百分数,比如 50%,表示原点坐标加上自己宽度的 50%(即控件水平中心)作为起始点 ;如果是 50%p(字母 p 是 parent 的意思),取值的基数是父控件,因此 50%p 就是表示在原点坐标加上父控件宽度的 50% 作为起始点 x 轴坐标。

startOffset 动画延迟开始时间(多长时间后开始执行动画)

duration 属性为动画持续时间 时间以毫秒为单位

方式二:直接用java代码实现(RotateAnimation)

这本质上也是Animation动画,RotateAnimation继承自Animation


RotateAnimation rotateAnimation3 = new RotateAnimation(0, 359,

        Animation.ABSOLUTE, DisplayUtil.dip2px(mActivity, 7), Animation.ABSOLUTE, DisplayUtil.dip2px(mActivity, 78));

rotateAnimation3.setFillAfter(true);

rotateAnimation3.setDuration(4000);

rotateAnimation3.setRepeatCount(-1);

rotateAnimation3.setInterpolator(new LinearInterpolator());

rotateAnimation3.setRepeatMode(Animation.RESTART);

ivPoint.startAnimation(rotateAnimation3);

构造函数里面的参数:


public RotateAnimation(float fromDegrees, float toDegrees, int pivotXType, float pivotXValue,

        int pivotYType, float pivotYValue)

fromDegrees,toDegrees:这个两个参数表示开始旋转角度和结束角度

pivotXType,pivotYType:这个类型有三个选项,表示旋转中心点的坐标

Animation.ABSOLUTE:坐标表示绝对的数值,如果设置为这个类型,那么pivotXValue就是个绝对的数值,px单位,所以为了适配手机,要转换一下,把dp转换为px的值

Animation.RELATIVE_TO_SELF:现对于自身的坐标,如果设置为这个类型,一般适用于控件自身的旋转,那么pivotXValue的值是一个0-1的小数,一般设置为0.5,那么控件就围绕自身的中心点旋转

Animation.RELATIVE_TO_PARENT:想读与父控件的坐标

RotateAnimation属性:

setFillAfter:表示旋转后是否保持旋转后的状态

setRepeatCount:旋转的次数,设置为-1表示为无限次

setRepeatMode:旋转的模式,RESTART:表示一圈一圈的转,REVERSE表示旋转完后反响旋转

方式三:属性动画


ivPoint.setPivotX(DisplayUtil.dip2px(mActivity, 7));//设置指定旋转中心点X坐标

ivPoint.setPivotY(DisplayUtil.dip2px(mActivity, 78));

PropertyValuesHolder propertyValuesHolder = PropertyValuesHolder.ofFloat("rotation", 0.0f, 359f);

ObjectAnimator rotate = ObjectAnimator.ofPropertyValuesHolder(ivPoint, propertyValuesHolder);

rotate.setDuration(2000);

rotate.setInterpolator(new AccelerateDecelerateInterpolator());

rotate.setRepeatCount(-1);

rotate.start();

属性动画通过PropertyValuesHolder来设置动画的参数,第一个参数为动画的类型,后面的参数表示旋转的开始角度和结束角度

旋转的属性动画的坐标点通过控件本身来设置,setPivotX,setPivotY。注意这里设置的也是绝对数值,也要dp转px

方式四:ValueAnimator


ivPoint.setPivotX(DisplayUtil.dip2px(mActivity, 7));//设置指定旋转中心点X坐标

ivPoint.setPivotY(DisplayUtil.dip2px(mActivity, 78));

ValueAnimator animator = ValueAnimator.ofFloat(0, 359);

animator.setTarget(ivPoint);

animator.setDuration(2000).start();

animator.setRepeatCount(-1);

animator.setInterpolator(new AccelerateDecelerateInterpolator());

animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {

    @Override

    public void onAnimationUpdate(ValueAnimator animation) {

        ivPoint.setRotation((Float) animation.getAnimatedValue());

    }

});

valueAnimator实际上是属性动画的父类,所以属性动画的远离实际上跟ValueAnimatior是一致的,ValueAnimatior要更灵活一点

参考:

图解 Android View动画中 android:pivotX 和 android:pivotY 属性的含义:https://blog.csdn.net/hust_twj/article/details/78587989

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容