TabLayout + ViewPager

来源:http://www.cnblogs.com/xiongwo/archive/2016/12/28/6223880.html
-Advertisement-
Play Games

一、實現思路 1、在build.gradle中添加依賴,例如: 也可以將support-v4替換為appcompat-v7,例如: 因為appcompat-v7是依賴於support-v4的。 更多說明可參考官方文檔support library部分。 2、在xml中添加TabLayout和View ...


一、實現思路

1、在build.gradle中添加依賴,例如:

compile 'com.android.support:support-v4:23.4.0'
compile 'com.android.support:design:23.4.0'

也可以將support-v4替換為appcompat-v7,例如:

compile 'com.android.support:appcompat-v7:23.4.0'

因為appcompat-v7是依賴於support-v4的。

更多說明可參考官方文檔support library部分。

2、在xml中添加TabLayout和ViewPager,例如:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              xmlns:tool="http://schemas.android.com/tools"
              xmlns:app="http://schemas.android.com/apk/res-auto"
              tool:context=".TabViewActivity"
              android:orientation="vertical"
              android:layout_width="match_parent"
              android:layout_height="match_parent">

    <android.support.design.widget.TabLayout
        android:id="@+id/tab_layout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@color/tabLayoutBackground"
        app:tabMode="scrollable"
        app:tabTextColor="@color/color_white"
        app:tabSelectedTextColor="@color/tabSelectedText"
        app:tabIndicatorHeight="3dp"
        app:tabIndicatorColor="@color/color_white"/>

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

</LinearLayout>

TabLayout:

(1)tabMode有兩個屬性,一個是"scrollable",用於多標簽;另一個是"fixed",用於少標簽,它會讓全部標簽平均分佈在屏幕上,所以標簽不能多,而且名稱也不能長,否則會顯示不完整。

(2)tabIndicator是指文本下的指示條。當選中一個tab時,指示條才會出現,出現在文本下麵。

3、獲取View對象

        TabLayout tabLayout = (TabLayout) findViewById(R.id.tab_layout);
        ViewPager viewPager = (ViewPager) findViewById(R.id.view_pager);

4、創建FragmentStatePagerAdaper的子類,並實現構造方法

    public class ViewPagerAdapter extends FragmentStatePagerAdapter {
        public ViewPagerAdapter(FragmentManager fm) {
            super(fm);
        }
  }

 創建該類的一個實例對象

        ViewPagerAdapter viewPagerAdapter = new ViewPagerAdapter(getSupportFragmentManager());

 在這一步中,你可以選擇是實現FragmentPagerAdapter的子類,或者是FragmentStatePagerAdapter的子類。

FragmentPagerAdapter用於頁數較少的,也就Fragment的數量較少的,因為只要用戶還停留在當前的Activity中,其中的Fragment都不會被銷毀,所以記憶體消耗會比較大。

而FragmentStatePagerAdapter的工作原理類似於ListView,只要用戶不可見的Fragment,都會被銷毀,只保留它的狀態。

因為我用的是v4相容包下的Fragment,所以需要用getSupportFragmentManager()去獲取FragmentManager。

5、設置ViewPager和TabLayout

        viewPager.setAdapter(viewPagerAdapter);
        tabLayout.setupWithViewPager(viewPager);

 

二、完善Adapter

1、重寫三個方法

    public class ViewPagerAdapter extends FragmentStatePagerAdapter {

......
@Override
public Fragment getItem(int position) { return null; } @Override public int getCount() { return 0; } @Override public CharSequence getPageTitle(int position) { return super.getPageTitle(position); } }

2、創建tab的標題數據:

 private String[] mTitles = new String[]{"語文", "英語", "數學", "物理", "生物", "化學", "地理", "政治", "歷史"};

創建Fragment的子類:

public class ViewPagerFragment extends Fragment {

    private static final String KEY = "extra";
    private String mMessage;

    public ViewPagerFragment() {
    }

    public static ViewPagerFragment newInstance(String extra) {
        Bundle args = new Bundle();
        args.putString(KEY, extra);
        ViewPagerFragment fragment = new ViewPagerFragment();
        fragment.setArguments(args);
        return fragment;
    }
}

創建Fragment的集合對象,並添加實例對象到集合里:

    private ArrayList<ViewPagerFragment> mViewPagerFragments = new ArrayList<>();

        ......

        for (int i = 0; i < mTitles.length; i++) {
            mViewPagerFragments.add(ViewPagerFragment.newInstance(mTitles[i]));
        }

 3、修改Adapter中的方法

    public class ViewPagerAdapter extends FragmentStatePagerAdapter {

        private String[] titles;
        private ArrayList<ViewPagerFragment> viewPagerFragments;

        public ViewPagerAdapter(FragmentManager fm) {
            super(fm);
        }

        public void setTitles(String[] titles) {
            this.titles = titles;
        }

        public void setFragments(ArrayList<ViewPagerFragment> viewPagerFragments) {
            this.viewPagerFragments = viewPagerFragments;
        }

        @Override
        public Fragment getItem(int position) {
            return viewPagerFragments.get(position);
        }

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

        @Override
        public CharSequence getPageTitle(int position) {
            return titles[position];
        }
    }

 4、將數據傳給Adapter

        viewPagerAdapter.setTitles(mTitles);
        viewPagerAdapter.setFragments(mViewPagerFragments);

 

三、完善Fragment

1、fragment_view_pager_item.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:orientation="vertical"
              android:layout_width="match_parent"
              android:layout_height="match_parent">

    <TextView
        android:id="@+id/fragment_text"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:gravity="center"/>

</LinearLayout>

2、完善Fragment的方法

public class ViewPagerFragment extends Fragment {

...... @Override public void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); Bundle bundle = getArguments(); if (bundle != null) { mMessage = bundle.getString(KEY); } } @Nullable @Override public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_view_pager_item, container, false); TextView textView = (TextView) view.findViewById(R.id.fragment_text); textView.setText(mMessage); return view; } }

在創建Fragment時,會調用onCreate方法,在其中執行一些狀態信息的初始化,用於暫停或停止後的恢復所用。

在Fragment首次載入視圖時,會調用onCreateView方法,在其中執行視圖的載入和初始化,返回的應該是該Fragment佈局的根視圖。其中inflate方法的第三個參數代表的意思是,是否要將載入進來的佈局(R.layout.fragment_view_pager_item)添加進container這個ViewGroup里。根據官方文檔的說明,上例那樣做的話,系統已經將這個佈局添加進container了,所以這裡為false。

 

靜態效果圖:

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 個人建議同時寫背景圖片和 img 標簽,兼顧SEO 的同時在高對比度模式下也可以正常顯示圖片。具體代碼晚些補上… 使用<img> 還有一個好處是,用戶可以很方便的右鍵保存 Logo 或者複製 Logo 圖片的鏈接。 <h1 class="logo"> <!-- 註意 a 標簽不要加 title,會造 ...
  • 1.向右(橫向)合併: 2.向下(縱向)合併: 3.合併邊框線(為表格設置合併邊框模型): 4.在table中的td中讓文字底部對齊和頂部對齊 ...
  • 設置或獲取對象指定的文件名或路徑。 window.location.pathname例:http://localhost:8086/topic/index?topicId=361alert(window.location.pathname); 則輸出:/topic/index設置或獲取整個 URL ...
  • 1、Node:節點元素節點->HTML標簽文本節點->文字 但是在標準瀏覽器(除了IE6~8)中會把空格和換行都當做文本節點來處理註釋節點->註釋document2、節點的特征元素節點:nodeType->1 nodeName->大寫的標簽名 nodeValue->null文本節點:nodeType ...
  • 昨天工作時候發現一個bug,是關於a標簽的,在安卓客戶端中,如果是a標簽的話,長按會出現一個彈框,如圖所示 是因為安卓客戶端的長按觸發機制,以後進行wap端開發的時候,如果用到跳轉頁面儘量不要用a標簽,取而代之可以用別的標簽+onclick=“window.location.href='';”的方式 ...
  • UIWebView是iOS最常用的SDK之一,它有一個stringByEvaluatingJavaScriptFromString方法可以將javascript嵌 入頁面中,通過這個方法我們可以在iOS中與UIWebView中的網頁元素交互。 stringByEvaluatingJavaScript ...
  • 幀動畫> 一張張圖片不斷的切換,形成動畫效果* 在drawable目錄下定義xml文件,子節點為animation-list,在這裡定義要顯示的圖片和每張圖片的顯示時長 <animation-list xmlns:android="http://schemas.android.com/apk/res ...
  • iOS開發小技巧 - 中文排序NSString 與 UnicodeObjective-C 中文 按拼音全排序 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...