今天小編給大家分享一下怎么用Android studio實現左右滑動切換圖片的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
切換圖片首先要使用到圖片切換器ImageSwitcher
先了解一下ImageSwitcher
1.ImageSwitcher的重要屬性:
android:inAnimation:切入圖片時的效果。
android:outAnimation:切出圖片時的效果。
以上兩個屬性在XML中設定,可以通過XML資源文件自定義動畫效果,如果只是想使用Android自帶的一些簡單的效果,調用Android內置的資源即可,也可以在代碼中設定,可以直接使用setInAnimation()和setOutAnimation()方法。它們都傳遞一個Animation的抽象對象,Animation用于描述一個動畫效果,一般使用一個AnimationUtils的工具類獲得。
常用的動畫效果有:
fede_in:淡進
fade_out:淡出
slide_in_left:從左滑進
slide_out_right: 從右滑出
2.java文件中ImageSwitcher的重要重要方法:
setImageURL(URL) setImageResource(int) setImageDrawable(Drawable)
3.視圖工廠 setFactory()
ImageSwitcher通過setFactory()方法為它設置一個ViewSwitcher.ViewFactory接口。設置這個ViewFactory接口時需要實現makeView()方法,該方法通常會返回一個ImageView。makeView()為ImageSwitcher生成ImageView。
接下來代碼實現左右滑動切換圖片
XML
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent"> <ImageSwitcher android:id="@+id/imageswitch" android:layout_width="wrap_content" android:layout_height="wrap_content"/> </LinearLayout>
java代碼如下:
package com.example.tablelayout; import android.os.Bundle; import android.view.MotionEvent; import android.view.View; import android.view.WindowManager; import android.view.animation.AnimationUtils; import android.widget.ImageSwitcher; import android.widget.ImageView; import android.widget.ViewSwitcher; import androidx.appcompat.app.AppCompatActivity; public class ImageSwitcha_Activity extends AppCompatActivity { private int[] arrayPicture=new int[]{ R.drawable.pa,R.drawable.pb}; private ImageSwitcher imageSwitcher; private int index; private float touchDownX; private float touchUpX; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.imageswitch_main); //設置全屏顯示 getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); imageSwitcher=findViewById(R.id.imageswitch); //設置視圖工廠 imageSwitcher.setFactory(new ViewSwitcher.ViewFactory() { @Override public View makeView() { ImageView imageView=new ImageView(ImageSwitcha_Activity.this); imageView.setImageResource(arrayPicture[index]);//設置顯示圖片(利用下標) return imageView;//返回圖像視圖 } }); //設置觸摸監聽器 imageSwitcher.setOnTouchListener(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { //判斷動作是不是按下 獲得按下時的X坐標 if(event.getAction()==MotionEvent.ACTION_DOWN) { touchDownX=event.getX(); return true; } else if(event.getAction()==MotionEvent.ACTION_UP) { touchUpX=event.getX(); //判斷是左滑動還是右滑動 if(touchUpX-touchDownX>100){ //判斷是不是第一張圖片 是就將索引變成最后一張圖片索引, // 不是則當前索引減一 index=index==0?arrayPicture.length-1:index-1; //使用自帶的淡入淡出 imageSwitcher.setInAnimation(AnimationUtils.loadAnimation(ImageSwitcha_Activity.this,android.R.anim.fade_in)); imageSwitcher.setOutAnimation(AnimationUtils.loadAnimation(ImageSwitcha_Activity.this,android.R.anim.fade_out)); imageSwitcher.setImageResource(arrayPicture[index]); }else if(touchDownX-touchUpX>100){ index=index==arrayPicture.length-1?0:index+1;//注意這里下標是從0開始的,所以應該是長度減1 imageSwitcher.setInAnimation(AnimationUtils.loadAnimation(ImageSwitcha_Activity.this,android.R.anim.fade_in)); imageSwitcher.setOutAnimation(AnimationUtils.loadAnimation(ImageSwitcha_Activity.this,android.R.anim.fade_out)); imageSwitcher.setImageResource(arrayPicture[index]); } return true; } return false; } }); } }
以上就是“怎么用Android studio實現左右滑動切換圖片”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。