前言
網(wǎng)上有很多使用ViewPager實(shí)現(xiàn)左右滑動(dòng)這一效果的資料,這些資料大多數(shù)都是將PagerAdapter中g(shù)etCount()方法的返回值設(shè)為Integer.MAX_VALUE使用戶看不到邊界,然后在instantiateItem()方法中通過position%(要循環(huán)顯示的數(shù)據(jù)集的長(zhǎng)度)的方式取得對(duì)應(yīng)的數(shù)據(jù)集。這樣雖然可以做到無限循環(huán),但是會(huì)有兩個(gè)弊端:首先會(huì)創(chuàng)建大量對(duì)象,容易引起內(nèi)存溢出(循環(huán)加載圖片)從而影響性能;其次從第一頁(yè)向右滑動(dòng)的時(shí)候是無法滑動(dòng)的。
今天給大家分享的是另一種實(shí)現(xiàn)方式:創(chuàng)建三個(gè)圖片視圖放入ViewPager中默認(rèn)選中第二頁(yè),在接下來的滑動(dòng)中每次滑動(dòng)結(jié)束之后都將當(dāng)前頁(yè)碼設(shè)置為第二頁(yè),然后通過判斷是向左向右滑動(dòng)來設(shè)置視圖中的數(shù)據(jù)集,這樣就可以實(shí)現(xiàn)無限循環(huán)了,而且只會(huì)創(chuàng)建三個(gè)圖片視圖對(duì)象。
示例源碼
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
|
package com.viewpager; import java.util.ArrayList; import java.util.List; import android.os.Bundle; import android.support.v4.view.PagerAdapter; import android.support.v4.view.ViewPager; import android.support.v4.view.ViewPager.OnPageChangeListener; import android.view.View; import android.view.ViewGroup; import android.widget.ImageView; import android.app.Activity; public class MainActivity01 extends Activity implements OnPageChangeListener { private ViewPager viewPager; static final int arrays[] = { R.drawable.guide1, R.drawable.guide2, R.drawable.guide3, R.drawable.guide4, R.drawable.guide5 }; private List<ImageView> views; private int currentPage = 0 ; private ImageView imageView; private MyViewPagerAdapter viewPagerAdapter; @Override protected void onCreate(Bundle savedInstanceState) { super .onCreate(savedInstanceState); setContentView(R.layout.activity_main); initWidget(); } private void initWidget() { viewPager = (ViewPager) findViewById(R.id.viewpager); views = new ArrayList<ImageView>(); for ( int i = 0 ; i < 3 ; i++) { imageView = new ImageView( this ); imageView.setLayoutParams( new ViewGroup.LayoutParams( ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT)); views.add(imageView); } initImageData(); viewPagerAdapter = new MyViewPagerAdapter(); viewPager.setAdapter(viewPagerAdapter); viewPager.setCurrentItem( 1 ); viewPager.setOnPageChangeListener( this ); } private void initImageData() { for ( int i = 0 ; i < 3 ; i++) { imageView = views.get(i); if (i == 0 ) { imageView.setImageResource(arrays[arrays.length - 1 ]); } else { imageView.setImageResource(arrays[i - 1 ]); } } } class MyViewPagerAdapter extends PagerAdapter { @Override public int getCount() { // TODO Auto-generated method stub return views.size(); } @Override public boolean isViewFromObject(View arg0, Object arg1) { // TODO Auto-generated method stub return arg0 == arg1; } @Override public Object instantiateItem(ViewGroup container, int position) { imageView = views.get(position); container.addView(imageView); return imageView; } @Override public void destroyItem(ViewGroup container, int position, Object object) { // TODO Auto-generated method stub container.removeView((View) object); } } // 當(dāng)滑動(dòng)狀態(tài)改變時(shí)調(diào)用 @Override public void onPageScrollStateChanged( int state) { // TODO Auto-generated method stub System.out.println( "--onPageScrollStateChanged--state--:" + state); switch (state) { // 在滾動(dòng)完成后 case ViewPager.SCROLL_STATE_IDLE: int currentItem = viewPager.getCurrentItem(); System.out.println( "--currentItem--00--:" + currentItem); System.out.println( "--currentPage--00--:" + currentPage); if (viewPager.getCurrentItem() == 1 ) { // 如果位置沒有變終止循環(huán) break ; } if (viewPager.getCurrentItem() > 1 ) { currentPage++; } else { currentPage--; } System.out.println( "--currentPage--11--:" + currentPage); if (currentPage == arrays.length) { currentPage = 0 ; } if (currentPage == - 1 ) { currentPage = arrays.length - 1 ; } System.out.println( "--currentPage--22--:" + currentPage); if (currentPage == 0 ) { views.get( 0 ).setImageResource(arrays[arrays.length - 1 ]); } else { views.get( 0 ).setImageResource(arrays[currentPage - 1 ]); } views.get( 1 ).setImageResource(arrays[currentPage]); if (currentPage == arrays.length - 1 ) { views.get( 2 ).setImageResource(arrays[ 0 ]); } else { views.get( 2 ).setImageResource(arrays[currentPage + 1 ]); } viewPager.setCurrentItem( 1 , false ); currentItem = viewPager.getCurrentItem(); System.out.println( "--currentItem--11--:" + currentItem); break ; } } // 當(dāng)當(dāng)前頁(yè)面被滑動(dòng)時(shí)調(diào)用 @Override public void onPageScrolled( int position, float positionOffset, int positionOffsetPixels) { // TODO Auto-generated method stub // System.out.println("--onPageScrolled--position--:" + position); } // 當(dāng)新的頁(yè)面被選中時(shí)調(diào)用 @Override public void onPageSelected( int position) { // TODO Auto-generated method stub System.out.println( "--onPageSelected--position--:" + position); } } |
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:https://blog.csdn.net/u013693649/article/details/52199729