本文實例為大家分享了Android實現自動播放圖片功能的具體代碼,供大家參考,具體內容如下
第一種方式:回退到第一張
效果圖
第二種方式:無限循環
效果圖:
源代碼
邏輯代碼--MainActivity
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
package com.example.week4_day4_viewpager2; import java.util.ArrayList; import java.util.List; import android.R.integer; import android.os.Bundle; import android.os.Handler; import android.app.Activity; import android.support.v4.view.ViewPager; import android.view.Menu; import android.widget.ImageView; public class MainActivity extends Activity { private ViewPager viewPager; // 數據源 private int [] images = { R.drawable.image1, R.drawable.image2, R.drawable.image3 }; // 存放數據源的集合 List<ImageView> list; @Override protected void onCreate(Bundle savedInstanceState) { super .onCreate(savedInstanceState); setContentView(R.layout.activity_main); viewPager = (ViewPager) findViewById(R.id.viewpager); // 實例化list list = new ArrayList<ImageView>(); for ( int i = 0 ; i < images.length; i++) { ImageView imageView = new ImageView(MainActivity. this ); imageView.setImageResource(images[i]); list.add(imageView); } // 綁定適配器 viewPager.setAdapter( new MyViewPagerAdapter(MainActivity. this , list)); // 當有3張圖片時,走到id=2時最后一張, viewPager.setCurrentItem(Integer.MAX_VALUE / 2 - Integer.MAX_VALUE / 2 % list.size()); // 假設viewPager有無數條數據 // 延遲兩秒發送一條消息 handler.sendEmptyMessageDelayed( 1 , 2000 ); } // 讓圖片自動播放,無限循環 private Handler handler = new Handler() { public void handleMessage(android.os.Message msg) { /** * 第一種方法,播放到最后一張時,回退到第一張照片從頭播放 * 弊端:回退時如果圖片過多,會出現回退重影,即3張時,從最后一張瞬間回退到第2張,又瞬間回退到第1張 */ // int i = viewPager.getCurrentItem();// 當前item // if (i == list.size() - 1) {// 如果第一條等于最后一條 // // false:是否顯示動畫 // viewPager.setCurrentItem(0, true);// 回到第一條item // } else { // viewPager.setCurrentItem(i + 1, true); // } /** * 第二種方法,無限循環播放,每次都把所有相片,放到后面查看 */ viewPager.setCurrentItem(viewPager.getCurrentItem() + 1 ); sendEmptyMessageDelayed( 1 , 2000 ); }; }; } |
邏輯代碼--自定義適配器
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
package com.example.week4_day4_viewpager2; import java.util.List; import android.content.Context; import android.support.v4.view.PagerAdapter; import android.view.View; import android.view.ViewGroup; import android.widget.ImageView; public class MyViewPagerAdapter extends PagerAdapter{ private Context context; private List<ImageView> list; public MyViewPagerAdapter(Context context, List<ImageView> list) { super (); this .context = context; this .list = list; } @Override public int getCount() { // TODO Auto-generated method stub return Integer.MAX_VALUE; //設置viewPager里有N條數據 //return list.size(); } @Override public Object instantiateItem(ViewGroup container, int position) { //假設有3張照片,走到id=2時,走id=0的,所以取余 container.addView(list.get(position%list.size())); return list.get(position%list.size()); //return list.get(position); } @Override public void destroyItem(ViewGroup container, int position, Object object) { // TODO Auto-generated method stub container.removeView(list.get(position%list.size())); //container.removeView(list.get(position)); //super.destroyItem(container, position, object); } @Override public boolean isViewFromObject(View arg0, Object arg1) { // TODO Auto-generated method stub return arg0==arg1; } } |
布局文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
< 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:paddingBottom = "@dimen/activity_vertical_margin" android:paddingLeft = "@dimen/activity_horizontal_margin" android:paddingRight = "@dimen/activity_horizontal_margin" android:paddingTop = "@dimen/activity_vertical_margin" tools:context = ".MainActivity" > < android.support.v4.view.ViewPager android:id = "@+id/viewpager" android:layout_width = "match_parent" android:layout_height = "match_parent" /> </ RelativeLayout > |
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:https://blog.csdn.net/huiling815/article/details/48711361