矽谷新聞8--TabLayout替換ViewPagerIndicator

来源:http://www.cnblogs.com/ganchuanpu/archive/2016/10/30/6014456.html
-Advertisement-
Play Games

1.關聯庫 compile 'com.android.support:design:23.3.0' 2.佈局寫上TabLayout 3.TabLayout和ViewPager關聯 4.解決TabLayout和ViewPagerIndicator的相容問題 4.1 <activity android: ...


1.關聯庫

compile 'com.android.support:design:23.3.0'

 

2.佈局寫上TabLayout

 <android.support.design.widget.TabLayout
    android:id="@+id/tabLayout"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_gravity="center_vertical"
    android:layout_weight="1" />

 

3.TabLayout和ViewPager關聯  

tabLayout.setupWithViewPager(viewPager);
//註意以後監聽頁面的變化 ,TabPageIndicator監聽頁面的變化
// tabPagerIndicator.setOnPageChangeListener(new MyOnPageChangeListener()); 
viewPager.addOnPageChangeListener(new MyOnPageChangeListener()); 
tabLayout.setTabMode(TabLayout.MODE_SCROLLABLE)

  

4.解決TabLayout和ViewPagerIndicator的相容問題  

4.1 <activity android:name=".activity.MainActivity" android:theme="@style/Theme.PageIndicatorDefaults" />

4.2 ViewPagerIndicator庫修改成如下

<style name="Theme.PageIndicatorDefaults" parent="Theme.AppCompat.Light.NoActionBar">
    <item name="vpiIconPageIndicatorStyle">@style/Widget.IconPageIndicator</item>
    <item name="vpiTabPageIndicatorStyle">@style/Widget.TabPageIndicator</item>
</style>

4.3添加V7包 compile 'com.android.support:appcompat-v7:23.3.0'  

 

5.TabLayout設置指針顏色和高度&文字顏色

5.1.添加樣式

<android.support.design.widget.TabLayout
        android:id="@+id/tabLayout"
        android:layout_width="wrap_content"
        style="@style/MyCustomTabLayout"
        android:layout_height="wrap_content"
        android:layout_weight="1" />

5.2. values目錄下styles.xml裡面

 <style name="MyCustomTabLayout" parent="Widget.Design.TabLayout">

        <item name="tabMaxWidth">72dp</item>
        <item name="tabMinWidth">72dp</item>
        <item name="tabIndicatorColor">#ff0000</item>
        <item name="tabIndicatorHeight">2dp</item>
        <item name="tabTextAppearance">@style/MyCustomTabTextAppearance</item>
        <item name="tabSelectedTextColor">@android:color/holo_red_light</item>

    </style>

    <style name="MyCustomTabTextAppearance" parent="TextAppearance.Design.Tab">
        <item name="android:textSize">16sp</item>
        <item name="android:textColor">@android:color/black</item>
        <item name="textAllCaps">false</item>
    </style>

 

6.TabLayout自定義樣式

1.設置的樣式

vp_news_menu_detailpager.setAdapter(adapter);
tabLayout.setupWithViewPager(vp_news_menu_detailpager);
//設置滾動模式
tabLayout.setTabMode(TabLayout.MODE_SCROLLABLE);

for (int i = 0; i < tabLayout.getTabCount(); i++) {
	TabLayout.Tab tab = tabLayout.getTabAt(i);
	tab.setCustomView(getTabView(i));
}
//註意了setupWithViewPager必須在ViewPager.setAdapter()之後調用

2.在適配器中添加getTabView()方法

public View getTabView(int position){
	View view = LayoutInflater.from(context).inflate(R.layout.tab_item, null);
	TextView tv= (TextView) view.findViewById(R.id.textView);
	tv.setText(childrenDatas.get(position).getTitle());
	ImageView img = (ImageView) view.findViewById(R.id.imageView);
	img.setImageResource(R.drawable.dot_focus);
	return view;
}

佈局文件tab_item.xml文件

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

	<TextView
		android:text="text"
		android:id="@+id/textView"
		android:textColor="#000000"
		android:layout_width="wrap_content"
		android:layout_height="wrap_content"
		android:layout_marginLeft="3dp" />

	<ImageView
		android:src="@drawable/dot_focus"
		android:id="@+id/imageView"
		android:layout_width="wrap_content"
		android:layout_height="wrap_content"
		android:layout_centerVertical="true" />
	
</LinearLayout>

  

  

 

  

  


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

-Advertisement-
Play Games
更多相關文章
  • 偽元素是一個好東西,但是很多人都沒怎麼用,因為他們覺得偽元素太詭異了。其實使用偽元素有很多好處,最大的好處是它可以簡化頁面的html標簽,同時用起來也很方便,善於使用偽元素可以讓你的頁面更加地簡潔優雅。 更好的閱讀體驗移步:http://yincheng.site/using-before-afte ...
  • 項目 (移動的廣告牌) 要求: 1,實現圖片一次以移動的方式出現,到最後一張完全出現時,回彈到第一張 2,滑鼠放在圖片上面圖片移動,滑鼠離開,圖片停止移動 *{ padding: 0; margin: 0;}/*添加背景圖片,個人愛好*/body{ background: url(../img/qu ...
  • 引言 webix.js被壓縮後很多字母不清楚是什麼用處,看源碼整理了部分出來,以button為例 1、button代碼 效果 2、以下代碼在F12的console中測試 define:方法(可以定義對象屬性的值) refresh:方法(刷新控制項) 效果 D 和 C:兩個都是定義屬性值的,define ...
  • 看到一些曾經只會灌水的網友,在學習了前端之後,已經能寫出下載量幾千幾萬的腳本、樣式,幫助大眾,成為受歡迎的人,感覺滿羡慕的。我也想學會前端技術,變得受歡迎呀。於是心血來潮,開始學習前端知識,並寫下了這個小練習。 基本思路是這樣的: 效果圖: 代碼如下: 點我進入線上版 這算是自己學習Javascri ...
  • 一:時間轉時間戳:javascript獲得時間戳的方法有四種,都是通過實例化時間對象 new Date() 來進一步獲取當前的時間戳 1.var timestamp1 = Date.parse(new Date()); // 結果:1477808630000 不推薦這種辦法,毫秒級別的數值被轉化為0 ...
  • 2016-10-30 13:11:56 引言 最近做項目,發現ajax請求不能在伺服器中直接重定向到登錄頁面。查了些資料發現jquery的ajax請求有人給出了方法。但是webix的ajax請求和jquery的有些區別。這裡模仿jquery的處理方式實現webix的ajax請求session超時跳轉 ...
  • 前言 啦啦啦~博主又來騷擾大家啦~大家是不是感覺上次的Android開發博文有點長呢~主要是因為博主也是小白,在做實驗的過程中查詢了很多很多概念,努力去理解每一個知識點,才完成了最終的實驗。還有就是隨著我們的實驗的進行,代碼量也會越來越多,所以在接下來的博文中會對源碼進行取捨,而不會把全部的實驗代碼 ...
  • 1.三級緩存設計步驟: * 從記憶體中取圖片 * 從本地文件中取圖片 向記憶體中保持一份 * 請求網路圖片,獲取圖片,顯示到控制項上 * 向記憶體存一份 * 向本地文件中存一份 2.網路緩存 線程池類Executors的使用 public static ExecutorService newCachedTh ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...