Android無(wú)限輪播Banner的實(shí)現(xiàn)

概述


應(yīng)用首頁(yè)的廣告輪播Banner袁翁,一般都會(huì)使用ViewPager來(lái)實(shí)現(xiàn),但是ViewPager 沒(méi)有輪播效果秒拔。
現(xiàn)成有這么幾種實(shí)現(xiàn)方案:

1.使用Integer.MAX_VALUE ,理論上很難達(dá)到邊界莫矗。
2.裝飾adapter方式imbryk/LoopingViewPager@Github
3.擴(kuò)展ViewPager方式yanzm/LoopViewPager砂缩。

相關(guān)庫(kù)


輪播效果其實(shí)就是一個(gè)定時(shí)任務(wù)趣苏,可以用定時(shí)器,Handler等梯轻。

Trinea/Android Auto Scroll ViewPager@Github

此庫(kù)通過(guò)handler定時(shí)發(fā)送消息實(shí)現(xiàn)食磕,用的比較多,使用中感覺(jué)切換并非無(wú)縫喳挑。主要代碼如下:

    /**
     * scroll only once
     */
    public void scrollOnce() {
        PagerAdapter adapter = getAdapter();
        int currentItem = getCurrentItem();
        int totalCount;
        if (adapter == null || (totalCount = adapter.getCount()) <= 1) {
            return;
        }

        int nextItem = (direction == LEFT) ? --currentItem : ++currentItem;
        if (nextItem < 0) {
            if (isCycle) {
                setCurrentItem(totalCount - 1, isBorderAnimation);
            }
        } else if (nextItem == totalCount) {
            if (isCycle) {
                setCurrentItem(0, isBorderAnimation);
            }
        } else {
            setCurrentItem(nextItem, true);
        }
    }

這里是在最后或第一頁(yè)直接setCurrentItem(),因此彬伦,并非無(wú)縫輪播效果。

和本文開(kāi)頭的幾個(gè)控件整合一下伊诵,即可方便 的實(shí)現(xiàn)我們想要無(wú)縫 的效果单绑。

基本實(shí)現(xiàn)


1.修改Trinea/Android Auto Scroll ViewPager@Github

改變首頁(yè)和最后一頁(yè)的跳轉(zhuǎn)設(shè)置。

    /**
     * scroll only once
     */
    public void scrollOnce() {
        PagerAdapter adapter = getAdapter();
        int currentItem = getCurrentItem();
        if (adapter == null || adapter.getCount() <= 1) {
            return;
        }

        int nextItem = (direction == LEFT) ? --currentItem : ++currentItem;
        setCurrentItem(nextItem, true);
    }

2.實(shí)現(xiàn)方式選擇

第一種方式其實(shí)主要改變了adapter中的index曹宴,大體如下:

@Override  
public int getCount() {  
  return Integer.MAX_VALUE;  
}
@Override  
public Object instantiateItem(ViewGroup container, int position) {  
  position = position % listviews.size()  ;
  //....       
}  

只是理論上的無(wú)限搂橙,需要自己處理position

第二種裝飾了adapter笛坦,在前后各添加一個(gè)Item区转,當(dāng)?shù)搅宋覀兲砑拥呐R界item的時(shí)候,立即設(shè)置到正確的 position 版扩,主要方法如下:

LoopPagerAdapterWrapper

int toRealPosition(int position) {
        int realCount = getRealCount();
        if (realCount == 0)
            return 0;
        int realPosition = (position-1) % realCount;
        if (realPosition < 0)
            realPosition += realCount;

        return realPosition;
    }

這里废离,內(nèi)部封裝position映射,不需要自己處理position礁芦,和正常ViewPager使用方式一樣蜻韭。

第三種悼尾,重寫擴(kuò)展ViewPager 繼承 ViewGroup,使其item無(wú)限肖方。需要自己處理position闺魏,而且 和 JakeWharton/ViewPagerIndicator@Github搭配使用起來(lái)不是很方便,setViewPager方法需要額外處理俯画。

綜上舷胜,使用第二種方式 擴(kuò)展性和 易用性都比較好。

Indicator


JakeWharton/ViewPagerIndicator@Github
這是一個(gè)比較全面的indicator活翩,如果我們只需要簡(jiǎn)單的CircleIndicator,可以抽取來(lái)使用翻伺。

優(yōu)秀相關(guān)開(kāi)源庫(kù):

THEONE10211024/CircleIndicator@Github:一個(gè)輕量的圓形指示器

ongakuer/CircleIndicator@Github:才用Drawable寫的圓形指示器

也可以看看本人站在巨人肩膀上完成的DrawableIndicator@Github:可以實(shí)時(shí)偏移材泄,切換動(dòng)畫,drawable資源吨岭。

效果圖:

DrawableIndicator
DrawableIndicator

測(cè)試


my_banner.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">

    <com.bobomee.android.scrollloopviewpager.autoscrollviewpager.AutoScrollViewPager
        android:id="@+id/picslooper1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />

    <com.bobomee.android.drawableindicator.widget.DrawableIndicator
        android:id="@+id/pageIndexor1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_centerVertical="true"
        app:indicator_height="15dp"
        app:indicator_margin="15dp"
        app:indicator_select_src="@drawable/select_drawable"
        app:indicator_unselect_src="@drawable/unselect_drawable"
        app:indicator_width="15dp" />
</RelativeLayout>

MainActivity:

  AutoScrollViewPager viewPager = (AutoScrollViewPager) findViewById(R.id.picslooper1);
        viewPager.setFocusable(true);
        viewPager.setAdapter(new FragmentStateAdapter(getSupportFragmentManager()));

        BaseIndicator pageIndex = (BaseIndicator) findViewById(R.id.pageIndexor1);
        pageIndex.setViewPager(viewPager);

        viewPager.startAutoScroll();

最終效果圖


AutoScrollLoopViewPager
AutoScrollLoopViewPager

源碼:
AutoScrollLoopViewPager@Github

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末拉宗,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子辣辫,更是在濱河造成了極大的恐慌旦事,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,539評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件急灭,死亡現(xiàn)場(chǎng)離奇詭異姐浮,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)葬馋,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評(píng)論 3 396
  • 文/潘曉璐 我一進(jìn)店門卖鲤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人畴嘶,你說(shuō)我怎么就攤上這事蛋逾。” “怎么了窗悯?”我有些...
    開(kāi)封第一講書人閱讀 165,871評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵区匣,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我蒋院,道長(zhǎng)亏钩,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,963評(píng)論 1 295
  • 正文 為了忘掉前任欺旧,我火速辦了婚禮铸屉,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘切端。我一直安慰自己彻坛,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,984評(píng)論 6 393
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著昌屉,像睡著了一般钙蒙。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上间驮,一...
    開(kāi)封第一講書人閱讀 51,763評(píng)論 1 307
  • 那天躬厌,我揣著相機(jī)與錄音,去河邊找鬼竞帽。 笑死扛施,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的屹篓。 我是一名探鬼主播疙渣,決...
    沈念sama閱讀 40,468評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼堆巧!你這毒婦竟也來(lái)了妄荔?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤谍肤,失蹤者是張志新(化名)和其女友劉穎啦租,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體荒揣,經(jīng)...
    沈念sama閱讀 45,850評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡篷角,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,002評(píng)論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了系任。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片内地。...
    茶點(diǎn)故事閱讀 40,144評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖赋除,靈堂內(nèi)的尸體忽然破棺而出阱缓,到底是詐尸還是另有隱情,我是刑警寧澤举农,帶...
    沈念sama閱讀 35,823評(píng)論 5 346
  • 正文 年R本政府宣布荆针,位于F島的核電站,受9級(jí)特大地震影響颁糟,放射性物質(zhì)發(fā)生泄漏航背。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,483評(píng)論 3 331
  • 文/蒙蒙 一棱貌、第九天 我趴在偏房一處隱蔽的房頂上張望玖媚。 院中可真熱鬧,春花似錦婚脱、人聲如沸今魔。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,026評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)错森。三九已至吟宦,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間涩维,已是汗流浹背殃姓。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,150評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留瓦阐,地道東北人蜗侈。 一個(gè)月前我還...
    沈念sama閱讀 48,415評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像睡蟋,于是被迫代替她去往敵國(guó)和親踏幻。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,092評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容