Android图像与动画<2>

android项目中为了界面的展示和效果,不可避免的用到图片和动画,所以我会分三个模块来讲解自己所知道的图像处理和各种的动画视觉显示,学习中,虚心接受大神们的建议。

动画

APP项目中使用动画的目的就是在完成客户的需求之后提升app的“气质”,炫酷的动画效果总给人留下深刻的印象,也让我们程序员很自豪,哈哈,我是这样认为的,今天写动画的那几种简单的用法,适合初学者学习,全是干货,复杂的实现效果可以网上百度。

在Android 3.0之前有两种实现动画的方法,一种:帧动画(Frame Animation)。一种:视图动画(View Animation)。
在Android3.0之后系统推出了属性动画(property animation)弥补了视图动画的缺陷,几乎可以取代视图动画。

1.视图动画

视图动画:Android中提供四种视图动画:透明,平移,旋转,缩放。

1.1 透明动画
透明(alpha)动画 ,可以将一个View从某个透明度转变为另一个透明度。通过XML文件来定义一个透明动画,必须要将动画文件放到res/anim文件夹下。
alpha.xml

<set xmlns:android="http://schemas.android.com/apk/res/android">
    <alpha 
        android:fromAlpha="1.0"
        android:toAlpha="0"
        android:duration="5000" />
</set>

属性解释:

  • android:fromAlpha 控件的初始透明度。取值在0.0~1.0之间。1.0为完全不透明。
  • android:toAlpha 动画结束时,控件的透明度。
  • android:duration 播放动画时持续的时间。

MainActivity中两种添加动画的方法。

public class MainActivity extends AppCompatActivity {

    private ImageView mImageView;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mImageView= (ImageView) findViewById(R.id.imageView);

      //引入res/anim文件夹下的xml文件,然后启动动画
      Animation animation= AnimationUtils.loadAnimation(this,R.anim.alpha);
        mImageView.startAnimation(animation);

       /* //直接实例化animtion
        Animation animation=new AlphaAnimation(1.0f,0.1f);
        // 设置动画的播放时间,单位(毫秒)。
        animation.setDuration(5000);
        // 设置控件是否定格在动画播放完成后的状态。
        animation.setFillAfter(true);
        mImageView.startAnimation(animation);*/

    }
}

1.2 平移动画
平移(translate)动画,可以将指定的View从某一个位置移动到另一个位置。某个View的平移动画的播放范围是其父控件所占的空间。

translate.xml

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">

    <translate
        android:fromXDelta="0"
        android:fromYDelta="0"
        android:toXDelta="150"
        android:toYDelta="100"
        android:duration="5000"
        ></translate>
</set>```

属性解释:
-  android:fromXDelta    设置动画移动时的起始X坐标。
-  android:fromYDelta    设置动画移动时的起始Y坐标。
-  android:toXDelta      设置动画移动时的结束X坐标。
-  android:toYDelta      设置动画移动时的结束Y坐标。 

1.3 **旋转动画**
旋转(rotate)动画,可以将指定的View沿着某一个点从某一个角度旋转到另一个角度。旋转动画的可视范围同样是待播放动画的View的父控件所占据的空间。

rotate.xml

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">

<rotate
    android:fromDegrees="0"
    android:toDegrees="-90"
    android:pivotX="50%"
    android:pivotY="50%"
    android:duration="5000"
    ></rotate>

</set>```

属性解释:

  • android:fromDegrees 设置控件(相对于0度)最初旋转角度。若值为0则控件不旋转。
  • android:toDegrees 设置控件(相对于0度)最终旋转角度,若值与fromDegrees相等则控件不旋转。
  • android:pivotX和pivotY 设置控件旋转时所用的参照点的X和Y轴坐标。

若将fromDegrees或toDegrees属性的值设置为负数,则动画会按照逆时针旋转。

1.4 缩放动画
 缩放(scale)动画,可以将指定的View沿着某一个点从某一个尺寸缩放到另一个尺寸。缩放动画的可视范围同样是待播放动画的View的父控件所占据的空间。

scale.xml

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">

    <scale
        android:fromXScale="1.0"
        android:fromYScale="2.0"
        android:toXScale="3.0"
        android:toYScale="1.0"
        android:pivotY="50%"
        android:pivotX="50%"
        android:duration="5000"
        ></scale>
</set>```

属性解释:
-  android:fromXScale    设置控件最初在水平方向上被缩放的倍数。若为1.0则不缩放。
-  android:fromYScale    设置控件最初在垂直方向上被缩放的倍数。若为1.0则不缩放。
-  android:toXScale      设置控件最终在水平方向上被缩放的倍数。
-  android:toYScale      设置控件最终在垂直方向上被缩放的倍数。
-  android:pivotX        设置控件以某个中心点进行缩放时,中心点的X坐标。 
-  android:pivotY        设置控件以某个中心点进行缩放时,中心点的Y坐标。

**AnimationSet**

使用<set>标签来定义一个动画集合,其内部可以嵌套其他动画,甚至是另一个<set>,<set>使用AnimationSet类来表示。

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
<alpha
android:duration="1000"
android:fromAlpha="0.5"
android:toAlpha="1.0" />
<scale
android:duration="1000"
android:fromXScale="1"
android:fromYScale="1"
android:toXScale="0.5"
android:toYScale="0.5" />
<rotate
android:fromDegrees="0"
android:toDegrees="-90"
android:pivotX="50%"
android:pivotY="50%"
android:duration="5000"
android:startOffset="3000"
android:interpolator="@android:anim/accelerate_interpolator"
>

</rotate>

</set>

属性解释:

- startOffset 表示播放开始的时间  单位是毫秒。

- interpolator 表示AnimationSet设置的插值器,定义动画的速度。播放旋转动画时,如果不为其指定插值器,则系统会默认使用AccelerateDecelerateInterpolator,此插值器的特点是,在动画开始时候加速,在动画结束的时候减速。



**帧动画**

>  帧动画(Frame Animation)通过短时间内连续播放多张图片来实现动画效果,和电影类似。

帧动画的根标签为<animation-list>,帧动画的xml文件必须要放在res/drawable文件夹中。如下xml:

<animation-list xmlns:android="http://schemas.android.com/apk/res/android" android:oneshot="false">
<item android:drawable="@drawable/liangguliang_1" android:duration="120" />
<item android:drawable="@drawable/liangguliang_2" android:duration="120" />
<item android:drawable="@drawable/liangguliang_3" android:duration="120" />
<item android:drawable="@drawable/liangguliang_4" android:duration="120" />
</animation-list>


属性解释:

-  android:oneshot   设置动画是否只播放一次。若值为false,则动画会循环播放。
-  <item>标签的 android:drawable 当前帧所显示的图片。
-  <item>标签的 android:duration 当前帧的持续时间(毫秒)。

<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/look"
android:onClick="onClick"
android:id="@+id/img" />


播放动画:

public void onWindowFocusChanged(boolean hasFocus) {
super.onWindowFocusChanged(hasFocus);
if(hasFocus){ // 若当前Activity获得焦点。
TextView text = (TextView) findViewById(R.id.text);
AnimationDrawable drawable =(AnimationDrawable) text.getBackground();
drawable.start();
}
}


注意:AnimationDrawable.start不能在窗口不完全的状态下执行,所以在onWindewFocusChanged中执行(onWindewFocusChanged方法是在resume()之后且用户可操作之前调用)

下章讲解属性动画,大家可以交流~~~





 


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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,028评论 25 707
  • 内容抽屉菜单ListViewWebViewSwitchButton按钮点赞按钮进度条TabLayout图标下拉刷新...
    皇小弟阅读 46,749评论 22 665
  • 1 背景 不能只分析源码呀,分析的同时也要整理归纳基础知识,刚好有人微博私信让全面说说Android的动画,所以今...
    未聞椛洺阅读 2,701评论 0 10
  • 卮言春天 菩提心迟到千年 挥不去 印象被蔓延 拈花微笑 边界上的思念 忘川宇宙 在心间
    小至夏柯阅读 184评论 0 1
  • 孩子还在肚子里的时候,我就很注意向妈妈们讨教怀孕、生产及带娃经验。孩子生下来了,附在我身上的雷达工作地更加起劲了,...
    伊萨卡阅读 255评论 0 0