Android實(shí)現(xiàn)輪播圖無(wú)限循環(huán)效果
本文實(shí)例為大家分享了Android輪播圖無(wú)限循環(huán)的具體代碼,供大家參考,具體內(nèi)容如下
實(shí)現(xiàn)無(wú)限循環(huán)
在getCount()方法中,返回一個(gè)很大的值,Integer.MAX_VALUE
在instantiateItem()方法中,獲取當(dāng)前View的索引時(shí),進(jìn)行取于操作,傳遞進(jìn)來(lái)的int position是個(gè)非常大的數(shù),對(duì)他進(jìn)行求余數(shù)
在destroyItem()方法中,同樣
在onPageSelected()監(jiān)聽(tīng)方法中,對(duì)傳遞進(jìn)來(lái)的索引進(jìn)行取于
反向的無(wú)限循環(huán)
調(diào)用ViewPager對(duì)象的setCurrentItem()方法,設(shè)置第一次進(jìn)來(lái)時(shí)候的當(dāng)前頁(yè),參數(shù):int數(shù)字,我們把它定位到Integer.MAX_VALUE的中間,并且保證第一條是當(dāng)前位置,Integer.MAX_VALUE/2-((Integer.MAX_VALUE/2)%banners.size())
目前有個(gè)左劃空白頁(yè)的問(wèn)題沒(méi)解決
package com.tsh.myviewpager;
import java.util.ArrayList;
import java.util.List;
import android.app.Activity;
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.widget.LinearLayout;
import android.widget.TextView;
public class MainActivity extends Activity {
private ViewPager vp_banner;
private LinearLayout ll_points;
private TextView tv_title;
private List<View> banners;
private String[] titles=new String[]{
"新聞標(biāo)題1",
"新聞標(biāo)題2",
"新聞標(biāo)題3"
};
private List<ImageView> points=new ArrayList<ImageView>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// 初始化
vp_banner = (ViewPager) findViewById(R.id.vp_banner);
ll_points = (LinearLayout) findViewById(R.id.ll_points);
tv_title = (TextView) findViewById(R.id.tv_title);
// banner部分
banners = new ArrayList<>();
ImageView img1 = new ImageView(this);
img1.setImageResource(R.drawable.a);
banners.add(img1);
ImageView img2 = new ImageView(this);
img2.setImageResource(R.drawable.b);
banners.add(img2);
ImageView img3 = new ImageView(this);
img3.setImageResource(R.drawable.c);
banners.add(img3);
//小圖標(biāo)
ll_points=(LinearLayout) findViewById(R.id.ll_points);
for(int i=0;i<banners.size();i++){
ImageView image=new ImageView(this);
image.setImageResource(R.drawable.point_selector);
LinearLayout.LayoutParams params=new LinearLayout.LayoutParams(5, 5);
params.rightMargin=4;
image.setLayoutParams(params);
if(i==0){
image.setEnabled(true);
}else{
image.setEnabled(false);
}
points.add(image);
ll_points.addView(image);
}
// 設(shè)置適配器
vp_banner.setAdapter(new MyPagerAdapter());
vp_banner.setCurrentItem(Integer.MAX_VALUE/2-((Integer.MAX_VALUE/2)%banners.size()));
vp_banner.setOnPageChangeListener(new OnPageChangeListener() {
@Override
public void onPageSelected(int arg0) {
tv_title.setText(titles[arg0%banners.size()]);
//小圖標(biāo)處理
for(ImageView point:points){
point.setEnabled(false);
}
points.get(arg0%banners.size()).setEnabled(true);
}
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
// TODO Auto-generated method stub
}
@Override
public void onPageScrollStateChanged(int arg0) {
// TODO Auto-generated method stub
}
});
}
private class MyPagerAdapter extends PagerAdapter {
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
System.out.println("銷(xiāo)毀:"+position);
container.removeView((View)object);
object=null;
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
System.out.println("初始化:"+position);
position=position%banners.size();
//解決右劃出錯(cuò)
if(banners.get(position).getParent()!=null){
//container.removeView(banners.get(position));
}else{
container.addView(banners.get(position));
}
return banners.get(position);
}
@Override
public int getCount() {
return Integer.MAX_VALUE;
}
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
return arg0 == arg1;
}
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android ViewPager實(shí)現(xiàn)輪播圖效果
- Android自定義控件實(shí)現(xiàn)簡(jiǎn)單的輪播圖控件
- Android自定義控件實(shí)現(xiàn)優(yōu)雅的廣告輪播圖
- Android實(shí)現(xiàn)ViewPage輪播圖效果
- Android實(shí)現(xiàn)炫酷輪播圖效果
- Android實(shí)現(xiàn)基于ViewPager的無(wú)限循環(huán)自動(dòng)播放帶指示器的輪播圖CarouselFigureView控件
- 簡(jiǎn)單實(shí)現(xiàn)android輪播圖
- Android如何使用RecyclerView打造首頁(yè)輪播圖
- Android開(kāi)發(fā)在輪播圖片上加入點(diǎn)擊事件的方法
- flutter實(shí)現(xiàn)輪播圖效果
相關(guān)文章
月下載量上千次Android實(shí)現(xiàn)二維碼生成器app源碼分享
既然是二維碼生成器那么我們?nèi)绾沃谱鞫S碼呢?這篇文章為大家分享了月下載量上千次Android實(shí)現(xiàn)二維碼生成器app源碼,希望大家喜歡2015-12-12
高仿網(wǎng)易新聞頂部滑動(dòng)條效果實(shí)現(xiàn)代碼
網(wǎng)易新聞的主界面頂部的滑動(dòng)條個(gè)人感覺(jué)還是比較漂亮的所以今天也模仿了下,網(wǎng)易頂部滑動(dòng)條的效果,由于初次模仿這種效果,可能有些地方還不夠完美,不過(guò)基本已經(jīng)實(shí)現(xiàn),希望大家能夠喜歡2013-01-01
Android Retrofit的簡(jiǎn)單介紹和使用
這篇文章主要介紹了Android Retrofit的簡(jiǎn)單介紹和使用2017-03-03
Android快速實(shí)現(xiàn)發(fā)送郵件實(shí)例
本篇文章主要介紹了Android快速實(shí)現(xiàn)發(fā)送郵件實(shí)例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-04-04
Android支付寶支付設(shè)計(jì)開(kāi)發(fā)
這篇文章主要為大家詳細(xì)介紹了Android支付寶支付設(shè)計(jì)開(kāi)發(fā),設(shè)計(jì)支付寶支付開(kāi)發(fā)方案,感興趣的小伙伴們可以參考一下2016-02-02
Android Studio實(shí)現(xiàn)發(fā)短信功能
這篇文章主要介紹了Android Studio實(shí)現(xiàn)發(fā)短信功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-06-06
強(qiáng)制Android應(yīng)用使用某個(gè)Locale的方法
這篇文章主要介紹了強(qiáng)制Android應(yīng)用使用某個(gè)Locale的方法,涉及Android基于Locale進(jìn)行語(yǔ)言設(shè)置的相關(guān)技巧,需要的朋友可以參考下2015-10-10
android開(kāi)發(fā)環(huán)境搭建詳解(eclipse + android sdk)
這篇文章主要介紹了android開(kāi)發(fā)環(huán)境搭建詳解(eclipse + android sdk),需要的朋友可以參考下2014-05-05

