Android繪制平移動畫的示例代碼
1、具體操作步驟
創建ImageView對象
創建ObjectAnimator對象
通過ofFloat方法實現平移
2、具體實施
創建ImageView
<ImageView android:id="@+id/car" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerInParent="true" android:src="@mipmap/car"/>
創建ObjectAnimator對象
1.第一位參數是需要移動的圖片
2.第二位參數是設置在什麼軸移動,例子translationX,就是在X軸移動
ObjectAnimator objectAnimator = ObjectAnimator.ofFloat(car, "translationX", 0f, -200); objectAnimator.setDuration(2000); objectAnimator.start();
3、具體實例
activity_main.xml
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity"> <ImageView android:id="@+id/car" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerInParent="true" android:src="@mipmap/car"/> <LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerHorizontal="true" android:orientation="horizontal" android:layout_below="@id/car" android:layout_marginTop="100dp"> <Button android:id="@+id/left" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Forward" android:textAllCaps="false"/> <Button android:id="@+id/reset" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Reset" android:textAllCaps="false" android:layout_marginLeft="20dp"/> <Button android:id="@+id/right" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Backword" android:textAllCaps="false" android:layout_marginLeft="20dp"/> </LinearLayout> </RelativeLayout>
MainActivity.java
package com.example.a4_10_float; import androidx.appcompat.app.AppCompatActivity; import android.animation.ObjectAnimator; import android.os.Bundle; import android.view.View; import android.widget.Button; import android.widget.ImageView; public class MainActivity extends AppCompatActivity { private ImageView car; private Button left; private Button reset; private Button right; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); car = findViewById(R.id.car); left = findViewById(R.id.left); reset = findViewById(R.id.reset); right = findViewById(R.id.right); } @Override protected void onStart() { super.onStart(); left.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Floaat(1); } }); reset.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Floaat(0); } }); right.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Floaat(2); } }); } //封裝好一個方法,開控制向左向右移動和回到初始位置 private void Floaat(int a) { if (a==1) { ObjectAnimator objectAnimator = ObjectAnimator.ofFloat(car, "translationX", 0f, -200); objectAnimator.setDuration(2000); objectAnimator.start(); }else if (a==0){ ObjectAnimator objectAnimator = ObjectAnimator.ofFloat(car, "translationX", 0f, 0); objectAnimator.setDuration(2000); objectAnimator.start(); }else if (a==2){ ObjectAnimator objectAnimator = ObjectAnimator.ofFloat(car, "translationX", 0f, 200); objectAnimator.setDuration(2000); objectAnimator.start(); } } }
一個最簡單的平移動畫就實現瞭
到此這篇關於Android繪制平移動畫的示例代碼的文章就介紹到這瞭,更多相關Android平移動畫內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!