前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android开发(43) 动画演示,会跑的小人,从屏幕左侧跑到右侧

Android开发(43) 动画演示,会跑的小人,从屏幕左侧跑到右侧

作者头像
张云飞Vir
发布2020-03-16 15:32:25
1.2K0
发布2020-03-16 15:32:25
举报
文章被收录于专栏:写代码和思考写代码和思考

需求

想做一个动画,一个会跑的小人,从屏幕右侧跑道右侧,于是做了个尝试,上图:

实现步骤

要完成这样需要三步:

  1. 做一个 帧动画 (frame animation),由多张图片组成,组成小人连续跑动的样子。
  2. 做一个 位移动画 使得小人 从左到右产生移动。
  3. 在onStart里启动动画

第一步,描述 “人物动作的变化”的动画

准备多个动作的图片,写个xml animation :

代码语言:javascript
复制
<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
    android:oneshot="false" >

    <item
        android:drawable="@drawable/loading_iv_00"
        android:duration="60">
    </item>
    <item
        android:drawable="@drawable/loading_iv_01"
        android:duration="60">
    </item>
    <item
        android:drawable="@drawable/loading_iv_02"
        android:duration="60">
    </item>
    <item
        android:drawable="@drawable/loading_iv_03"
        android:duration="60">
    </item>
    <item
        android:drawable="@drawable/loading_iv_04"
        android:duration="60">
    </item>
    <item
        android:drawable="@drawable/loading_iv_05"
        android:duration="60">
    </item>
    <item
        android:drawable="@drawable/loading_iv_06"
        android:duration="60">
    </item>
    <item
        android:drawable="@drawable/loading_iv_07"
        android:duration="60">
    </item>
    <item
        android:drawable="@drawable/loading_iv_08"
        android:duration="60">
    </item>
    <item
        android:drawable="@drawable/loading_iv_09"
        android:duration="60">
    </item>
    <item
        android:drawable="@drawable/loading_iv_10"
        android:duration="60">
    </item>

</animation-list>

代码:

代码语言:javascript
复制
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    imageView1 = (ImageView) findViewById(R.id.imageView1);

    imageView1.setImageResource(R.anim.loading);
    imageView1.setVisibility(View.GONE);
    mAnimationDrawable = (AnimationDrawable) imageView1.getDrawable();
    mAnimationDrawable.setOneShot(false);
}

第二步,位移动画

代码:

代码语言:javascript
复制
    Animation translate = new TranslateAnimation(Animation.RELATIVE_TO_PARENT, -0.2f,
            Animation.RELATIVE_TO_PARENT, 1, Animation.RELATIVE_TO_SELF, 0,
            Animation.RELATIVE_TO_SELF, 0);

    translate.setDuration(3000);
    translate.setRepeatCount(Animation.INFINITE);

这句话的意思时,相对于 父容器 的x坐标移动,y轴不改变,一直循环

第三步,启动

启动动画即可,代码:

代码语言:javascript
复制
package com.example.demo_run;

import android.app.Activity;
import android.graphics.drawable.AnimationDrawable;
import android.os.Bundle;
import android.view.View;
import android.view.ViewTreeObserver;
import android.view.animation.Animation;
import android.view.animation.TranslateAnimation;
import android.widget.ImageView;

public class MainActivity extends Activity {
    ImageView imageView1;
    AnimationDrawable mAnimationDrawable;

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

        imageView1.setImageResource(R.anim.loading);
        imageView1.setVisibility(View.GONE);
        mAnimationDrawable = (AnimationDrawable) imageView1.getDrawable();
        mAnimationDrawable.setOneShot(false);
    }

    @Override
    protected void onStart() {
        startAnimation();
        super.onStart();
    }

    private void startAnimation() {

        mAnimationDrawable.start();
        Animation translate = new TranslateAnimation(Animation.RELATIVE_TO_PARENT, -0.2f,
                Animation.RELATIVE_TO_PARENT, 1, Animation.RELATIVE_TO_SELF, 0,
                Animation.RELATIVE_TO_SELF, 0);

        translate.setDuration(3000);
        translate.setRepeatCount(Animation.INFINITE);
        imageView1.startAnimation(translate);

        imageView1.setVisibility(View.VISIBLE);
    }
}

页面布局:

代码语言:javascript
复制
<RelativeLayout 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"
    android:background="#3F99C3"
    tools:context=".MainActivity" >

    <ImageView
        android:id="@+id/imageView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_alignParentLeft="true" />

</RelativeLayout>

演示代码下载

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 需求
  • 实现步骤
    • 第一步,描述 “人物动作的变化”的动画
    • 第二步,位移动画
    • 第三步,启动
    相关产品与服务
    容器服务
    腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档