利用ViewPager+TabLayout實(shí)現(xiàn)界面左右滑動(dòng)

TabLayout

tabLayout

上圖是一個(gè)關(guān)于TabLayout的Demo梦碗,TabLayout提供了一個(gè)水平的布局用來展示Tabs就缆。與viewpager涎永、fragment(或者view)搭配使用涯保,實(shí)現(xiàn)點(diǎn)擊屏幕標(biāo)簽或左右滑動(dòng)可以切換頁面的效果晒来。

viewpager

viewpager是谷歌官方提供的控件钞诡,它相當(dāng)于一個(gè)容器,儲(chǔ)存fragment或者view湃崩,通過左右滑動(dòng)的方式將容器中的頁面進(jìn)行切換荧降,常用于app首頁的歡迎頁與滾動(dòng)欄。

1.tabLayout的基本使用方法

在布局中加入該控件:

<android.support.design.widget.TabLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:id="@+id/tab_layout">
            </android.support.design.widget.TabLayout>

在代碼中動(dòng)態(tài)添加Item:

tabLayout= (TabLayout) findViewById(R.id.tabLayout);

tabLayout.addTab(tabLayout.newTab().setText("Tab 1"));

tabLayout.addTab(tabLayout.newTab().setText("Tab 2"));

tabLayout.addTab(tabLayout.newTab().setText("Tab 3"));

方式二靜態(tài)添加Item:

<android.support.design.widget.TabLayout

android:layout_width="wrap_content"

android:layout_height="wrap_content">

<android.support.design.widget.TabItem

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="Tab1"/>

...

</android.support.design.widget.TabLayout>

附:
tabLayout的其他常用屬性
1.改變選中字體的顏色

app:tabSelectedTextColor="@android:color/holo_orange_light"

2.改變未選中字體的顏色

app:tabTextColor="@color/colorPrimary"

3.改變指示器下標(biāo)的顏色

app:tabIndicatorColor="@android:color/holo_orange_light"

4.改變整個(gè)TabLayout的顏色

app:tabBackground="color"

5.改變TabLayout內(nèi)部字體大小

app:tabTextAppearance="@android:style/TextAppearance.Holo.Large"http://使文字的外貌變大

6.改變指示器下標(biāo)的高度

app:tabIndicatorHeight="4dp"

7.添加圖標(biāo)

android:icon="@drawable/icon"

//tabLayout.addTab(tabLayout.newTab().setText("Tab 1").setIcon(R.mipmap.ic_launcher));動(dòng)態(tài)

8.設(shè)置tabMode

app:tabMode="scrollable"
//默認(rèn)是fixed:固定的攒读,標(biāo)簽很多時(shí)候會(huì)被擠壓朵诫,不能滑動(dòng)。

9.內(nèi)容的顯示模式

app:tabGravity="center"http://居中整陌,如果是fill拗窃,則是充滿

10.Tab的寬度限制

設(shè)置最大的tab寬度:

app:tabMaxWidth="xxdp"

設(shè)置最小的tab寬度:

app:tabMinWidth="xxdp"

11.Tab的“Margin”

TabLayout開始位置的偏移量:

app:tabContentStart="100dp"

12.加入Padding

設(shè)置Tab內(nèi)部的子控件的Padding:

app:tabPadding="xxdp"

app:tabPaddingTop="xxdp"

app:tabPaddingStart="xxdp"

app:tabPaddingEnd="xxdp"

app:tabPaddingBottom="xxdp"

設(shè)置整個(gè)TabLayout的Padding:

app:paddingEnd="xxdp"

app:paddingStart="xxdp"

2.viewPager的使用方法

布局:

<android.support.v4.view.ViewPager
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:id="@+id/pager"
            />

新建ViewPagerAdapter
viewpager的使用方法中比較關(guān)鍵的就是adapter,因?yàn)関iewpager是一個(gè)容器泌辫,我們把view看作數(shù)據(jù)的話随夸,我們則必須有一個(gè)adapter將數(shù)據(jù)有順序有調(diào)理地放入我們的容器中,這時(shí)我們需要新建一個(gè)類繼承自pagerAdapter震放,代碼如下:

package com.example.peek_mapdemotest.materialdesign;

import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;

import java.util.List;

/**
 * Created by Administrator on 2017/8/5.
 */

public class ViewPagerAdapter extends PagerAdapter {

    private List<View> viewList;
    private List<String> titleList;

    public ViewPagerAdapter(List<View> viewList,List<String> titleList) {
        this.viewList=viewList;
        this.titleList=titleList;
    }

    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
        container.removeView(viewList.get(position));
    }

    @Override
    public Object instantiateItem(ViewGroup container, int position) {
        container.addView(viewList.get(position));
        return viewList.get(position);
    }

    @Override
    public CharSequence getPageTitle(int position) {
        return titleList.get(position);
    }

    @Override
    public int getCount() {
        return titleList.size();
    }

    @Override
    public boolean isViewFromObject(View view, Object object) {
        return view==object;
    }


}

ViewPager viewPager = (ViewPager) findViewById(R.id.view_pager);
List<View> viewList = new ArrayList<>();
        List<String> titleList = new ArrayList<>();

        titleList.add("頁面1");
        titleList.add("頁面2");
        titleList.add("頁面3");


        LayoutInflater inflater = LayoutInflater.from(this);
        View tab01 = inflater.inflate(R.layout.fragment_fragment1, null);
        View tab02 = inflater.inflate(R.layout.fragment_fragment2, null);
        View tab03 = inflater.inflate(R.layout.fragment_fragment3, null);

        viewList.add(tab01);
        viewList.add(tab02);
        viewList.add(tab03);

        mViewPager = (ViewPager)findViewById(R.id.pager);
        ViewPagerAdapter mViewPagerAdapter=new ViewPagerAdapter(viewList,titleList);
        tabLayout.setupWithViewPager(mViewPager);
        mViewPager.setAdapter(mViewPagerAdapter);

最后直接用一句代碼 tabLayout.setupWithViewPager(viewPager);即可很方便的將tabLayout與viewpager搭配起來宾毒。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市殿遂,隨后出現(xiàn)的幾起案子诈铛,更是在濱河造成了極大的恐慌,老刑警劉巖墨礁,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件幢竹,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡恩静,警方通過查閱死者的電腦和手機(jī)焕毫,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門蹲坷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人邑飒,你說我怎么就攤上這事循签。” “怎么了疙咸?”我有些...
    開封第一講書人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵县匠,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我撒轮,道長(zhǎng)乞旦,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任题山,我火速辦了婚禮杆查,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘臀蛛。我一直安慰自己亲桦,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開白布浊仆。 她就那樣靜靜地躺著客峭,像睡著了一般。 火紅的嫁衣襯著肌膚如雪抡柿。 梳的紋絲不亂的頭發(fā)上舔琅,一...
    開封第一講書人閱讀 51,679評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音洲劣,去河邊找鬼备蚓。 笑死,一個(gè)胖子當(dāng)著我的面吹牛囱稽,可吹牛的內(nèi)容都是我干的郊尝。 我是一名探鬼主播,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼战惊,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼流昏!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起吞获,我...
    開封第一講書人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤况凉,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后各拷,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體刁绒,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年烤黍,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了知市。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片粮坞。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖初狰,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情互例,我是刑警寧澤奢入,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站媳叨,受9級(jí)特大地震影響腥光,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜糊秆,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一武福、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧痘番,春花似錦捉片、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至昂芜,卻和暖如春莹规,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背泌神。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來泰國打工良漱, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人欢际。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓母市,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親损趋。 傳聞我的和親對(duì)象是個(gè)殘疾皇子窒篱,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355

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

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,163評(píng)論 25 707
  • 序 上圖是簡(jiǎn)書Android端的主頁Tab,在其他的App中Tab也是很常見的,它的實(shí)現(xiàn)方式也有很多:TabHos...
    積木Blocks閱讀 165,487評(píng)論 109 326
  • 序 上圖是簡(jiǎn)書Android端的主頁Tab,在其他的App中Tab也是很常見的舶沿,它的實(shí)現(xiàn)方式也有很多:TabHos...
    小莊bb閱讀 1,804評(píng)論 0 8
  • 揣江濤海浪注入人生壯烈括荡,是生命的壯美高镐,懷明月光輝拾于鄉(xiāng)間野語,是自然之時(shí)尚畸冲。
    悅圖文閱讀 464評(píng)論 1 2
  • 小學(xué)的時(shí)候你哭 全班同學(xué)都會(huì)來哄你 中學(xué)的時(shí)候你哭 幾個(gè)要好的朋友來哄你 大學(xué)的時(shí)候你哭 身邊只有一個(gè)朋友來哄你 ...
    96d6e44e065d閱讀 193評(píng)論 0 1