這篇文章將為大家詳細(xì)講解有關(guān)RollViewPager如何實(shí)現(xiàn)圖片輪播效果,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創(chuàng)新互聯(lián)公司是專業(yè)的寧強(qiáng)網(wǎng)站建設(shè)公司,寧強(qiáng)接單;提供網(wǎng)站設(shè)計(jì)、成都網(wǎng)站設(shè)計(jì),網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行寧強(qiáng)網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!
RollViewPager是一個(gè)自動(dòng)輪播的Viewpager,支持無(wú)限循環(huán)。 觸摸時(shí)會(huì)暫停播放,直到結(jié)束觸摸一個(gè)延遲周期以后繼續(xù)播放。 看起來(lái)就像這樣。指示器可以為點(diǎn)可以為數(shù)字還可以自定義,位置也可以變。
附上RollViewPager Github地址:https://github.com/Jude95/RollViewPager
使用Android Studio開(kāi)發(fā)在gradle添加依賴:
compile 'com.jude:rollviewpager:1.4.5'
在布局文件當(dāng)中使用:
<com.jude.rollviewpager.RollPagerView android:layout_width="match_parent" android:layout_height="180dp" app:rollviewpager_play_delay="3000"/>
要使用到RollViewPager自定義屬性的時(shí)候,在布局文件當(dāng)中我們必須添加:
xmlns:app="http://schemas.android.com/apk/res-auto
RollPagerView自定義屬性:
app:rollviewpager_play_delay="3000" 播放間隔時(shí)間,單位ms。填0則不播放。默認(rèn)為0 app:rollviewpager_hint_gravity="center" 指示器位置,提供left,center,right。默認(rèn)center
app:rollviewpager_hint_color="#7c7c7c" 指示器背景顏色.默認(rèn)黑色
app:rollviewpager_hint_alpha="80" 指示器背景透明度。0全透明,255不透明。默認(rèn)0.
app:rollviewpager_hint_paddingLeft="16dp" 指示器左邊距
app:rollviewpager_hint_paddingRight="16dp" 指示器右邊距
app:rollviewpager_hint_paddingTop="16dp" 指示器上邊距
app:rollviewpager_hint_paddingBottom="16dp" 指示器下邊距
一般指定一下間隔時(shí)間。
RollViewPager提供了自定義指示器的類:HintView 用法:
參數(shù)說(shuō)明:上下文,當(dāng)前輪播圖指示器圖片 默認(rèn)指示器圖片
mRollViewPager.setHintView(new IconHintView(this,R.drawable.point_focus,R.drawable.point_normal));
mRollViewPager.setHintView(new ColorPointHintView(this, Color.YELLOW,Color.WHITE));
mRollViewPager.setHintView(new TextHintView(this));
mRollViewPager.setHintView(null);//隱藏指示器
設(shè)置點(diǎn)擊事件:
pagerView.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(int position) { Toast.makeText(MainActivity.this,""+position,Toast.LENGTH_SHORT).show(); } });
提供以下三種種方便的PagerAdapter供使用。
本ViewPager也可以使用其他任意PagerAdapter。
StaticPagerAdapter:
存儲(chǔ)頁(yè)面的Adapter。view添加進(jìn)去就存儲(chǔ)不會(huì)再次getView,減少頁(yè)面創(chuàng)建消耗,消耗內(nèi)存。一般自動(dòng)播放的情況這種方案比較好。不然會(huì)大量構(gòu)造View。 概念參照FragmentPagerAdapter??梢杂糜谄渌鸙iewPager。
class MyPagerAdapter extends StaticPagerAdapter { private int[] image = {R.mipmap.one, R.mipmap.two, R.mipmap.three, R.mipmap.four}; // SetScaleType(ImageView.ScaleType.CENTER_CROP); // 按比例擴(kuò)大圖片的size居中顯示,使得圖片長(zhǎng)(寬)等于或大于View的長(zhǎng)(寬) @Override public View getView(ViewGroup container, int position) { ImageView imageView = new ImageView(container.getContext()); imageView.setImageResource(image[position]); imageView.setScaleType(ImageView.ScaleType.CENTER_CROP); imageView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT)); return imageView; } @Override public int getCount() { return image.length; } }
DynamicPagerAdapter(跟以上Adapter用法一樣)
動(dòng)態(tài)的Adapter。當(dāng)創(chuàng)建3號(hào)view時(shí)會(huì)銷毀1號(hào)view(遞推),會(huì)時(shí)常調(diào)用getView。增加頁(yè)面創(chuàng)建消耗,減小內(nèi)存消耗。 概念參照FragmentStatePagerAdapter。可以用于其他ViewPager。
LoopPagerAdapter
無(wú)限循環(huán)的Adapter。無(wú)限循環(huán)上采用的是getCount返回int大數(shù)的方法(并沒(méi)有什么缺點(diǎn),另外估計(jì)1s的間隔時(shí)間你在有生之年看不到他播放到底)。實(shí)測(cè)比第N頁(yè)跳轉(zhuǎn)到第1頁(yè)的效果好。
數(shù)據(jù)采用StaticPagerAdapter的方案。節(jié)省創(chuàng)建View開(kāi)銷。 本Adapter只能用于本RollViewPager;
無(wú)需其他設(shè)置,很簡(jiǎn)單。
mRollViewPager.setAdapter(new TestLoopAdapter(mRollViewPager)); private class TestLoopAdapter extends LoopPagerAdapter{ private int[] imgs = { R.drawable.img1, R.drawable.img2, R.drawable.img3, R.drawable.img4, }; public TestLoopAdapter(RollPagerView viewPager) { super(viewPager); } @Override public View getView(ViewGroup container, int position) { ImageView view = new ImageView(container.getContext()); view.setImageResource(imgs[position]); view.setScaleType(ImageView.ScaleType.CENTER_CROP); view.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT)); return view; } @Override public int getRealCount() { return imgs.length; } }
播放控制
rollViewPager.pause() rollViewPager.resume() rollViewPager.isPlaying()
MainActivity代碼:
public class MainActivity extends AppCompatActivity { private RollPagerView pagerView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); pagerView = (RollPagerView) findViewById(R.id.rollPagerView); //設(shè)置適配器 pagerView.setAdapter(new MyPagerAdapter()); pagerView.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(int position) { Toast.makeText(MainActivity.this,""+position,Toast.LENGTH_SHORT).show(); } }); //對(duì)指示器的自定義 參數(shù)說(shuō)明:上下文,當(dāng)前輪播圖指示器圖片 默認(rèn)指示器圖片 // pagerView.setHintView(new IconHintView(this,R.mipmap.ic_launcher,R.mipmap.fouse)); } class MyPagerAdapter extends StaticPagerAdapter { private int[] image = {R.mipmap.one, R.mipmap.two, R.mipmap.three, R.mipmap.four}; // SetScaleType(ImageView.ScaleType.CENTER_CROP); // 按比例擴(kuò)大圖片的size居中顯示,使得圖片長(zhǎng)(寬)等于或大于View的長(zhǎng)(寬) @Override public View getView(ViewGroup container, int position) { ImageView imageView = new ImageView(container.getContext()); imageView.setImageResource(image[position]); imageView.setScaleType(ImageView.ScaleType.CENTER_CROP); imageView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT)); return imageView; } @Override public int getCount() { return image.length; } } }
xml代碼:
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent"> <!--rollviewpager_play_delay 播放時(shí)間間隔默認(rèn)為0--> <com.jude.rollviewpager.RollPagerView android:layout_width="match_parent" android:layout_height="150dp" android:id="@+id/rollPagerView" app:rollviewpager_play_delay="3000" > </com.jude.rollviewpager.RollPagerView> </RelativeLayout>
附上效果圖:
關(guān)于“RollViewPager如何實(shí)現(xiàn)圖片輪播效果”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。
本文題目:RollViewPager如何實(shí)現(xiàn)圖片輪播效果
分享網(wǎng)址:http://m.rwnh.cn/article26/igjjjg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、全網(wǎng)營(yíng)銷推廣、外貿(mào)網(wǎng)站建設(shè)、靜態(tài)網(wǎng)站、虛擬主機(jī)、ChatGPT
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)