(二)用TabLayout搭建首屏介面
學生時代DO他的年代,Android上是有一個App的,後來作者就沒更新了。那個年代就有用Tab的了,非常方便快捷,食堂吃飯的時候能拿出來滑兩下看看,到宿舍就實踐起來_。所以就決定了,用Tab
走的彎路
一開始是在github找的第三方開源庫SmartLayout 圍觀地址
嚴格意義上來說並不是彎路,是因為 我不會啊!技術不到家不會用啊!我表示很無奈啊!
懟來懟去半天,發現了TabLayout這個東西,是Google官方的東西,資料比較多一點,所以選擇了這個,其實按我的審美,還是SmartLayout好看啊T T
開始擼程式碼咯
1. 新增依賴
TabLayout是Android Support Design裡面的新東西,需要在Android Studio的SDK Manager——SDK Tools中勾選Android Support Library下載,截止到今天2016.3.14,最新版本為23.2.1,接下來還要在Project工程檔案下的build.gradle中的dependency中新增一行程式碼compile 'com.android.support:design:23.2.1'
2.正式開始寫程式碼
首先需要建立一個佈局,直接修改activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin"
tools:context=".MainActivity">
<android.support.design.widget.TabLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/tabs"/>
<android.support.v4.view.ViewPager
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/viewpager"
android:layout_below="@id/tabs"/>
</RelativeLayout>```
接下來建立一個PageFragment.java
```Java
package com.noisay.dota2guide.fragment;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import com.noisay.dota2guide.R;
public class PageFragment extends Fragment {
public static final String ARG_PAGE = "ARG_PAGE";
private int mPage;//此變數純粹用來做Fragment內容的展示編號,後期會刪除
public static PageFragment newInstance(int page) {
Bundle args = new Bundle();
args.putInt(ARG_PAGE, page);
PageFragment pageFragment = new PageFragment();
pageFragment.setArguments(args);
return pageFragment;
}
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mPage = getArguments().getInt(ARG_PAGE);
}
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_page, container, false);
TextView textView = (TextView) view;
textView.setText("Fragment #" + mPage);
return view;
}
}```
然後新建一個fragment_page.xml,程式碼如下
```Java
<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center" />
再新建一個SimpleFragmentPagerAdapter.java來適配
package com.noisay.dota2guide.adapter;
import android.content.Context;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import com.noisay.dota2guide.fragment.PageFragment;
/**
* Created by noisa on 2016/3/14.
*/
public class SimpleFragmentPagerAdapter extends FragmentPagerAdapter{
final int PAGE_COUNT = 4;
private String tabTitles[] = new String[]{"敏捷英雄", "智力英雄", "力量英雄", "裝備"};
private Context context;
public SimpleFragmentPagerAdapter(FragmentManager fm, Context context) {
super(fm);
this.context = context;
}
@Override
public Fragment getItem(int position) {
return PageFragment.newInstance(position+1);//加1是因為position是從0開始
}
@Override
public int getCount() {
return PAGE_COUNT;
}
@Override
public CharSequence getPageTitle(int position) {
return tabTitles[position];
}
}
最後一步,修改MainActivity.java
package com.noisay.dota2guide;
import android.os.Bundle;
import android.support.design.widget.TabLayout;
import android.support.v4.app.FragmentActivity;
import android.support.v4.view.ViewPager;
import com.noisay.dota2guide.adapter.SimpleFragmentPagerAdapter;
/**
* Created by noisa on 2016/3/14.
*/
public class MainActivity extends FragmentActivity {
private SimpleFragmentPagerAdapter pagerAdapter;
private ViewPager viewPager;
private TabLayout tabLayout;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
pagerAdapter = new SimpleFragmentPagerAdapter(getSupportFragmentManager(), this);
viewPager = (ViewPager) findViewById(R.id.viewpager);
viewPager.setAdapter(pagerAdapter);
tabLayout = (TabLayout) findViewById(R.id.tabs);
tabLayout.setupWithViewPager(viewPager);
tabLayout.setTabMode(TabLayout.MODE_FIXED);
}
}
最終呈現出來的效果,沒有真機錄不了視訊轉Gif,簡直血崩一波。。。。。看個PNG湊合一下吧
![1433738-688e66f98b5168e8.PNG](https://i.iter01.com/images/050ff916cf851e88aa79569cd9c5bf12a5024299d3cef477bd8aa19dbafe2b71.png)
捕獲.PNG
本人現在還是超級菜鳥一枚,此文中部分程式碼來自於Chenfuduo的《TabLayout of design support library 》一問,結合App的需要有做修改,原文連結
相關文章
- 首屏優化系列(二)優化
- 首屏優化優化
- TabLayoutTabLayout
- 首屏預渲染方案
- 首屏優化系列(一)優化
- 關於首屏優化優化
- 前端優化首屏載入前端優化
- Vue首屏效能優化元件Vue優化元件
- 怎麼去掉win10鎖屏介面 win10取消鎖屏介面Win10
- 移動端首屏優化策略優化
- 優化 SPA 首屏載入速度優化
- 短視訊商城系統,首屏載入loading動畫介面和路由跳轉動畫動畫路由
- 怎麼關閉win10鎖屏介面 windows關閉鎖屏介面的方法Win10Windows
- 模仿Google News的TabLayoutGoTabLayout
- 探索瀏覽器錄屏Web API 介面的應用前景與限制瀏覽器WebAPI
- 如何在我的應用啟動介面實現「開屏廣告」?
- win10如何取消鎖屏介面 win10怎麼關閉顯示鎖屏介面Win10
- 用 Flutter 水一個可醜的漸變首頁(二)Flutter
- Win10系統下鎖屏介面啟用小娜功能的方法Win10
- Vue 服務端渲染實踐 ——Web應用首屏耗時最優化方案Vue服務端Web優化
- 從零開始搭建React應用(二)——React應用架構React應用架構
- Android中TabLayout修改字型大小AndroidTabLayout
- H5首屏時間的計算H5
- vue客戶端渲染首屏優化之道Vue客戶端優化
- 如何在Koa整合Bigpipe首屏渲染服務
- PC版Xbox雲遊戲首曝:介面類似移動端應用遊戲
- win10怎麼取消開機鎖屏介面_win10如何關閉開機鎖屏介面Win10
- 基於 SSR 的預渲染首屏直出方案
- Android中TabLayout新增小紅點AndroidTabLayout
- MaterialDesign系列文章(八)TabLayout的使用TabLayout
- 如何理解以太坊ABI - 應用程式二進位制介面
- win10系統下在鎖屏介面上啟用Cortana小娜功能的方法Win10
- Mac使用技巧_蘋果鎖屏介面如何自定義鎖屏訊息?Mac蘋果
- win10藍屏介面不顯示藍屏錯誤資訊怎麼解決_讓Win10藍屏介面顯示藍屏錯誤資訊的步驟Win10
- luffy04-首頁輪播圖介面
- android使用TabLayout+NestedScrollView 實現詳情介面tab頁 關聯 上下滑動檢視的效果AndroidTabLayoutView
- MVVM框架的搭建(二)——專案搭建MVVM框架
- 一中頌二首
- 詳解 CRP:如何最大化提升首屏渲染速度