Android使用ViewPager實現(xiàn)左右無限滑動
前言
網(wǎng)上有很多使用ViewPager實現(xiàn)左右滑動這一效果的資料,這些資料大多數(shù)都是將PagerAdapter中g(shù)etCount()方法的返回值設(shè)為Integer.MAX_VALUE使用戶看不到邊界,然后在instantiateItem()方法中通過position%(要循環(huán)顯示的數(shù)據(jù)集的長度)的方式取得對應(yīng)的數(shù)據(jù)集。這樣雖然可以做到無限循環(huán),但是會有兩個弊端:首先會創(chuàng)建大量對象,容易引起內(nèi)存溢出(循環(huán)加載圖片)從而影響性能;其次從第一頁向右滑動的時候是無法滑動的。
今天給大家分享的是另一種實現(xiàn)方式:創(chuàng)建三個圖片視圖放入ViewPager中默認選中第二頁,在接下來的滑動中每次滑動結(jié)束之后都將當前頁碼設(shè)置為第二頁,然后通過判斷是向左向右滑動來設(shè)置視圖中的數(shù)據(jù)集,這樣就可以實現(xiàn)無限循環(huán)了,而且只會創(chuàng)建三個圖片視圖對象。
示例源碼
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);
}
}
// 當滑動狀態(tài)改變時調(diào)用
@Override
public void onPageScrollStateChanged(int state) {
// TODO Auto-generated method stub
System.out.println("--onPageScrollStateChanged--state--:" + state);
switch (state) {
// 在滾動完成后
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;
}
}
// 當當前頁面被滑動時調(diào)用
@Override
public void onPageScrolled(int position, float positionOffset,
int positionOffsetPixels) {
// TODO Auto-generated method stub
// System.out.println("--onPageScrolled--position--:" + position);
}
// 當新的頁面被選中時調(diào)用
@Override
public void onPageSelected(int position) {
// TODO Auto-generated method stub
System.out.println("--onPageSelected--position--:" + position);
}
}
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- Android利用ViewPager實現(xiàn)滑動廣告板實例源碼
- Android App中ViewPager所帶來的滑動沖突問題解決方法
- Android App中使用ViewPager+Fragment實現(xiàn)滑動切換效果
- Android中ViewPager帶來的滑動卡頓問題解決要點解析
- Android開發(fā)之使用ViewPager實現(xiàn)圖片左右滑動切換效果
- Android ViewPager無限循環(huán)實現(xiàn)底部小圓點動態(tài)滑動
- android配合viewpager實現(xiàn)可滑動的標簽欄示例分享
- Android利用ViewPager實現(xiàn)可滑動放大縮小畫廊效果
- Android編程實現(xiàn)ViewPager多頁面滑動切換及動畫效果的方法
- Android 利用ViewPager實現(xiàn)圖片可以左右循環(huán)滑動效果附代碼下載
相關(guān)文章
Android Rreact Native 常見錯誤總結(jié)
這篇文章主要介紹了Android Rreact Native 常見錯誤總結(jié)的相關(guān)資料,需要的朋友可以參考下2017-06-06
Android網(wǎng)絡(luò)狀態(tài)實時監(jiān)聽實例代碼(二)
這篇文章主要介紹了Android網(wǎng)絡(luò)狀態(tài)實時監(jiān)聽實例代碼(2)的相關(guān)資料,需要的朋友可以參考下2016-03-03
Flutter學習之創(chuàng)建一個內(nèi)嵌的navigation詳解
我們在flutter中可以使用Navigator.push或者Navigator.pushNamed方法來向Navigator中添加不同的頁面,從而達到頁面調(diào)整的目的。本文就來聊聊如何創(chuàng)建一個內(nèi)嵌的navigation吧2023-03-03
Android+Flutter實現(xiàn)彩虹圖案的繪制
彩虹,是氣象中的一種光學現(xiàn)象,當太陽光照射到半空中的水滴,光線被折射及反射,在天空上形成拱形的七彩光譜。接下來,我們就自己手動繪制一下彩虹圖案吧2022-11-11
Android啟動頁廣告(騰訊廣告聯(lián)盟)解決方法及源碼下載
這篇文章主要介紹了Android啟動頁廣告(騰訊廣告聯(lián)盟)解決方法的相關(guān)資料,啟動頁幾乎成為了每個app的標配,有些商家在啟動頁中增加了開屏廣告以此帶來更多的收入,需要的朋友可以參考下2017-03-03
Android下拉刷新ListView——RTPullListView(demo)
下拉刷新已經(jīng)形成一種默認的用戶習慣,今天主要介紹下在Android上實現(xiàn)下拉刷新的Demo,感興趣的朋友可以參考下哈,希望可以幫助到你2013-04-04
Android使用OKhttp3實現(xiàn)登錄注冊功能+springboot搭建后端的詳細過程
這篇教程主要實現(xiàn)Android使用OKhttp3實現(xiàn)登錄注冊的功能,后端使用SSM框架,本文通過實例圖文相結(jié)合給大家介紹的非常詳細,需要的朋友參考下吧2021-07-07

