日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

底部导航栏的几种实现方式

發布時間:2025/3/21 编程问答 50 豆豆
生活随笔 收集整理的這篇文章主要介紹了 底部导航栏的几种实现方式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

概述

Android底部導航欄實現方式真的是太多了~在這里僅介紹幾種實現方式~建議使用TabLayout +ViewPager ,TabLayout是Android Material Design中的控件,布局文件簡單。

LinearLayout + TextView方式

效果圖

分析


  • 根據效果圖,我們可以看出在選中的時候,文字 圖片 和背景都會發生改變,我們可以通過是否selected來判斷。
  • 首先來說下圖片:
    我們準備了如下的圖片

    分別是選中和未選中兩種狀態的圖片。

要處理這些不同狀態下展示什么的問題,就要用selector來實現了。

selector標簽,可以添加一個或多個item子標簽,而相應的狀態是在item標簽中定義的。定義的xml文件可以作為兩種資源使用:drawable和color。 更多詳細的細節 請參考Android樣式的開發:selector篇

android:state_selected: 設置是否選中狀態,true表示已選中,false表示未選中。

我們在這里使用的是圖片,選中時為黃色的圖標,未選中時為灰色的圖標,如下所示。

<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"><item android:drawable="@drawable/tab_better_pressed" android:state_selected="true"/><item android:drawable="@drawable/tab_better_normal"/> </selector>

因為我們的思路是 圖片在文字的上方
所以在TextView的xml屬性中設置

android:drawableTop="@drawable/tab_menu_channel"

即可。

其余的幾個同上,在這里就不一一列舉了。

  • 接著說下文字的處理:

選中的時候為黃色,未選中 灰色

<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"><item android:color="@color/text_yellow" android:state_selected="true"/><item android:color="@color/text_gray"/></selector>

然后在TextView的xml屬性中設置

android:textColor="@drawable/tab_menu_text"
  • 最后說下背景的處理:
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"><item android:state_selected="true"><!--形狀定義工具--><shape><!--設置形狀填充的顏色,只有android:color一個屬性--><solid android:color="#FFC4C4C4" /></shape></item><item><shape><solid android:color="@color/transparent" /></shape></item></selector>

然后在TextView的xml屬性中設置

android:background="@drawable/tab_menu_bg"

綜上所述,布局文件中TextView的屬性如下:

<TextViewandroid:id="@+id/txt_channel"android:layout_width="0dp"android:layout_height="wrap_content"android:layout_weight="1"android:background="@drawable/tab_menu_bg"android:drawablePadding="3dp"android:drawableTop="@drawable/tab_menu_channel"android:gravity="center"android:padding="5dp"android:text="@string/tab_menu_alert"android:textColor="@drawable/tab_menu_text"android:textSize="16sp" />

也可以將公共的屬性,提取到style中,然后設置給TextView。

  • 主Activity中要思考的問題:

1)Fragment什么時候初始化和add到容器中?
2)Fragment什么時候hide和show?
3)如何讓TextView被選中?選中一個TextView后,要做一些什么操作?
4)剛進入MainActivity怎么樣讓一個TextView處于Selected的狀態?

1)+2)我們選中TextView后對對應的Fragment進行判空,如果為空,初始化,并添加到容器中; 而hide的話,我們定義一個方法hide所有的Fragment,每次觸發點擊事件就先調用這個hideAll方法, 講所有Fragment隱藏起來,然后如果TextView對應的Fragment不為空,我們就將這個Fragment顯示出來;

3)這個我們通過點擊事件來實現,點擊TextView后先重置所有TextView的選中狀態為false,然后設置點擊的 TextView的選中狀態為true;
4)我們是通過點擊事件來設置選中的,那么在onCreate()方法里加個觸發點擊事件的方法模擬點擊就可以了~ txt_channel.performClick();


Code

BottomNvgWithTextView.java

package com.turing.base.activity.fragment.fragmentPractice1;import android.os.Bundle; import android.support.v4.app.FragmentManager; import android.support.v4.app.FragmentTransaction; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.widget.FrameLayout; import android.widget.TextView;import com.turing.base.R;public class BottomNvgWithTextView extends AppCompatActivity implements View.OnClickListener {//UI Objectprivate TextView txt_topbar;private TextView txt_channel;private TextView txt_message;private TextView txt_better;private TextView txt_setting;private FrameLayout ly_content;//Fragment Objectprivate Fragment_btm_nvg_tv_context fg1, fg2, fg3, fg4;private FragmentManager fManager;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_fragment__bottom_nvg_with_text_view);fManager = getSupportFragmentManager();bindViews();//模擬一次點擊,既進去后選擇第一項txt_channel.performClick();}/*** UI組件初始化與事件綁定*/private void bindViews() {txt_topbar = (TextView) findViewById(R.id.txt_topbar);txt_channel = (TextView) findViewById(R.id.txt_channel);txt_message = (TextView) findViewById(R.id.txt_message);txt_better = (TextView) findViewById(R.id.txt_better);txt_setting = (TextView) findViewById(R.id.txt_setting);ly_content = (FrameLayout) findViewById(R.id.ly_content);txt_channel.setOnClickListener(this);txt_message.setOnClickListener(this);txt_better.setOnClickListener(this);txt_setting.setOnClickListener(this);}/*** 重置所有文本的選中狀態*/private void setSelected() {txt_channel.setSelected(false);txt_message.setSelected(false);txt_better.setSelected(false);txt_setting.setSelected(false);}/*** 隱藏所有Fragment*/private void hideAllFragment(FragmentTransaction fragmentTransaction) {if (fg1 != null) fragmentTransaction.hide(fg1);if (fg2 != null) fragmentTransaction.hide(fg2);if (fg3 != null) fragmentTransaction.hide(fg3);if (fg4 != null) fragmentTransaction.hide(fg4);}@Overridepublic void onClick(View v) {FragmentTransaction fTransaction = fManager.beginTransaction();hideAllFragment(fTransaction);switch (v.getId()) {case R.id.txt_channel:setSelected();txt_channel.setSelected(true);if (fg1 == null) {fg1 = new Fragment_btm_nvg_tv_context("第一個Fragment");fTransaction.add(R.id.ly_content, fg1);} else {fTransaction.show(fg1);}break;case R.id.txt_message:setSelected();txt_message.setSelected(true);if (fg2 == null) {fg2 = new Fragment_btm_nvg_tv_context("第二個Fragment");fTransaction.add(R.id.ly_content, fg2);} else {fTransaction.show(fg2);}break;case R.id.txt_better:setSelected();txt_better.setSelected(true);if (fg3 == null) {fg3 = new Fragment_btm_nvg_tv_context("第三個Fragment");fTransaction.add(R.id.ly_content, fg3);} else {fTransaction.show(fg3);}break;case R.id.txt_setting:setSelected();txt_setting.setSelected(true);if (fg4 == null) {fg4 = new Fragment_btm_nvg_tv_context("第四個Fragment");fTransaction.add(R.id.ly_content, fg4);} else {fTransaction.show(fg4);}break;}fTransaction.commit();} }

activity_fragment__bottom_nvg_with_text_view.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"><RelativeLayoutandroid:id="@+id/ly_top_bar"android:layout_width="match_parent"android:layout_height="48dp"android:background="@color/bg_topbar"><TextViewandroid:id="@+id/txt_topbar"android:layout_width="match_parent"android:layout_height="match_parent"android:layout_centerInParent="true"android:gravity="center"android:text="Fragment練習+TextView制作底部導航"android:textColor="@color/text_topbar"android:textSize="18sp" /><Viewandroid:layout_width="match_parent"android:layout_height="2px"android:layout_alignParentBottom="true"android:background="@color/div_white" /></RelativeLayout><LinearLayoutandroid:id="@+id/ly_tab_bar"android:layout_width="match_parent"android:layout_height="80dp"android:layout_alignParentBottom="true"android:background="@color/bg_white"android:orientation="horizontal"><TextViewandroid:id="@+id/txt_channel"android:layout_width="0dp"android:layout_height="wrap_content"android:layout_weight="1"android:background="@drawable/tab_menu_bg"android:drawablePadding="3dp"android:drawableTop="@drawable/tab_menu_channel"android:gravity="center"android:padding="5dp"android:text="@string/tab_menu_alert"android:textColor="@drawable/tab_menu_text"android:textSize="16sp" /><TextViewandroid:id="@+id/txt_message"android:layout_width="0dp"android:layout_height="wrap_content"android:layout_weight="1"android:background="@drawable/tab_menu_bg"android:drawablePadding="3dp"android:drawableTop="@drawable/tab_menu_message"android:gravity="center"android:padding="5dp"android:text="@string/tab_menu_profile"android:textColor="@drawable/tab_menu_text"android:textSize="16sp" /><TextViewandroid:id="@+id/txt_better"android:layout_width="0dp"android:layout_height="wrap_content"android:layout_weight="1"android:background="@drawable/tab_menu_bg"android:drawablePadding="3dp"android:drawableTop="@drawable/tab_menu_my"android:gravity="center"android:padding="5dp"android:text="@string/tab_menu_pay"android:textColor="@drawable/tab_menu_text"android:textSize="16sp" /><TextViewandroid:id="@+id/txt_setting"android:layout_width="0dp"android:layout_height="wrap_content"android:layout_weight="1"android:background="@drawable/tab_menu_bg"android:drawablePadding="3dp"android:drawableTop="@drawable/tab_menu_better"android:gravity="center"android:padding="5dp"android:text="@string/tab_menu_setting"android:textColor="@drawable/tab_menu_text"android:textSize="16sp" /></LinearLayout><Viewandroid:id="@+id/div_tab_bar"android:layout_width="match_parent"android:layout_height="2px"android:layout_above="@id/ly_tab_bar"android:background="@color/div_white" /><FrameLayoutandroid:id="@+id/ly_content"android:layout_width="match_parent"android:layout_height="match_parent"android:layout_above="@id/div_tab_bar"android:layout_below="@id/ly_top_bar"></FrameLayout></RelativeLayout>

首先定義頂部標題欄的樣式,48dp的LinearLayout中間加上一個TextView作為標題!
接著定義一個大小為80dp的LinerLayout對其底部,在這個里面加入四個TextView,比例1:1:1:1, 并且設置相關屬性,接著在這個LinearLayout上加一條線段!
最后以標題欄和底部導航欄為邊界,寫一個FrameLayout,寬高match_parent,用做Fragment的容器!
PS:這里四個TextView屬性是重復的,你也可以自行抽取出來,編寫一個style,設置下~

隱藏頂部導航欄

如果繼承的是AppCompatActivity,以前在Activity中調用requestWindowFeature(Window.FEATURE_NO_TITLE);可以隱藏手機 自帶頂部導航欄,,即使這句話寫在了setContentView()之前,也會報錯的,我們可以在AndroidManifest.xml設置下theme屬性: NoActionBar

Fragment_btm_nvg_tv_context.java

package com.turing.base.activity.fragment.fragmentPractice1;import android.os.Bundle; import android.support.v4.app.Fragment; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.TextView;import com.turing.base.R;/*** A simple {@link Fragment} subclass.*/ public class Fragment_btm_nvg_tv_context extends Fragment {private String content;/*** 無參構造函數*/public Fragment_btm_nvg_tv_context() {}/*** 帶有參數的構造函數** @param content*/public Fragment_btm_nvg_tv_context(String content) {this.content = content;}@Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {// Inflate the layout for this fragmentView view = inflater.inflate(R.layout.fragment_btm_nvg_tv_context, container, false);TextView txt_content = (TextView) view.findViewById(R.id.txt_content);txt_content.setText(content);return view;}}

重寫了一個onCreateView()方法,其他方法可以按需重寫!

fragment_btm_nvg_tv_context.xml

<FrameLayout 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"tools:context=".activity.fragment.fragmentPractice1.Fragment_btm_nvg_tv_context"><TextView android:id="@+id/txt_content"android:layout_width="match_parent"android:layout_height="match_parent"android:gravity="center"android:text="@string/hello_blank_fragment" /></FrameLayout>

RadioGroup + RadioButton

上個方法使用LinearLayout + TextView實現了底部導航欄的效果,每次點擊我們都要重置 所有TextView的狀態,然后選中點擊的TextView,有點麻煩是吧,接下來我們用另一種方法: RadioGroup + RadioButton實現相同的效果

效果圖

分析

簡單來說 ,一個RadioGroup包著四個RadioButton,和前面的一樣用比例來劃分:1:1:1:1;
另外我們只需重寫RadioGroup的onCheckedChange,判斷checkid即可知道點擊的是哪個RadioButton。

drawable類的資源都是將selected 狀態修改成checked

Code

Step 1:編寫底部選項的一些資源文件

圖片:tab_menu_channel_radiobutton.xml

android:state_checked=”true”

<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"><item android:drawable="@drawable/tab_channel_pressed" android:state_checked="true"/><item android:drawable="@drawable/tab_channel_normal"/> </selector>

其他三個同上,只需替換對應的圖片資源即可。

文字:tab_menu_text_radiobutton.xml

android:state_checked=”true”

<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"><item android:color="@color/text_yellow" android:state_checked="true"/><item android:color="@color/text_gray"/></selector>

背景資源:tab_menu_bg_radiobutton.xml

同TextView的

<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"><item android:state_checked="true"><!--形狀定義工具--><shape><!--設置形狀填充的顏色,只有android:color一個屬性--><solid android:color="#FFC4C4C4" /></shape></item><item><shape><solid android:color="@color/transparent" /></shape></item></selector>

Step 2:主Activity布局

在前面用TextView實現底部導航欄我們就發現了一個問題,每個TextView的屬性都幾乎是差不多 的,而在建議那里我們也說讓大家把相同的屬性抽取出來寫到Style中

首先我們取出其中一個RadioGroup的標簽:

<RadioButtonandroid:id="@+id/rb_channel"android:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:background="@drawable/tab_menu_bg"android:button="@null"android:drawableTop="@drawable/tab_menu_channel"android:gravity="center"android:paddingTop="3dp"android:text="@string/tab_menu_alert"android:textColor="@drawable/tab_menu_text"android:textSize="18sp" />

我們可以把每個RadioButton都相同的屬性抽取出來,寫到style.xml文件中:

<style name="tab_menu_item"><item name="android:layout_width">0dp</item><item name="android:layout_weight">1</item><item name="android:layout_height">match_parent</item><item name="android:background">@drawable/tab_menu_bg</item><item name="android:button">@null</item><item name="android:gravity">center</item><item name="android:paddingTop">3dp</item><item name="android:textColor">@drawable/tab_menu_text</item><item name="android:textSize">18sp</item> </style>

然后我們的主布局文件中的RadioButton就用不著每個都編寫相同的代碼了, 只需讓RadioButton的style=”@style/tab_menu_item”就可以了!

activity_bottom_nvg_with_radio_button.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:background="@color/bg_gray"><RelativeLayoutandroid:id="@+id/ly_top_bar"android:layout_width="match_parent"android:layout_height="48dp"android:background="@color/bg_topbar"><TextViewandroid:id="@+id/txt_topbar"android:layout_width="match_parent"android:layout_height="match_parent"android:layout_centerInParent="true"android:gravity="center"android:text="信息"android:textColor="@color/text_topbar"android:textSize="18sp" /><Viewandroid:layout_width="match_parent"android:layout_height="2px"android:layout_alignParentBottom="true"android:background="@color/div_white" /></RelativeLayout><RadioGroupandroid:id="@+id/rg_tab_bar"android:layout_width="match_parent"android:layout_height="80dp"android:layout_alignParentBottom="true"android:background="@color/bg_white"android:orientation="horizontal"><RadioButtonandroid:id="@+id/rb_channel"style="@style/tab_menu_item"android:drawableTop="@drawable/tab_menu_channel_radiobutton"android:text="@string/tab_menu_alert" /><RadioButtonandroid:id="@+id/rb_message"style="@style/tab_menu_item"android:drawableTop="@drawable/tab_menu_message_radiobutton"android:text="@string/tab_menu_profile" /><RadioButtonandroid:id="@+id/rb_better"style="@style/tab_menu_item"android:drawableTop="@drawable/tab_menu_better_radiobutton"android:text="@string/tab_menu_pay" /><RadioButtonandroid:id="@+id/rb_setting"style="@style/tab_menu_item"android:drawableTop="@drawable/tab_menu_my_radiobutton"android:text="@string/tab_menu_setting"/></RadioGroup><Viewandroid:id="@+id/div_tab_bar"android:layout_width="match_parent"android:layout_height="2px"android:layout_above="@id/rg_tab_bar"android:background="@color/div_white" /><FrameLayoutandroid:id="@+id/ly_content"android:layout_width="match_parent"android:layout_height="match_parent"android:layout_above="@id/div_tab_bar"android:layout_below="@id/ly_top_bar"></FrameLayout></RelativeLayout>

Step 3:隱藏頂部導航欄 同TextView的方式

Step 4:創建一個Fragment的簡單布局與類 ,直接使用TextView中的~

Step 5: 主布局Activity的編寫

package com.turing.base.activity.fragment.fragmentPractice2;import android.os.Bundle; import android.support.v4.app.FragmentManager; import android.support.v4.app.FragmentTransaction; import android.support.v7.app.AppCompatActivity; import android.widget.RadioButton; import android.widget.RadioGroup;import com.turing.base.R;/*** 我們使用LinearLayout + TextView實現了底部導航欄的效果,每次點擊我們都要重置 所有TextView的狀態,* 然后選中點擊的TextView,有點麻煩是吧,* 接下來我們用另一種方法: RadioGroup + RadioButton來實現同樣的效果*/ public class BottomNvgWithRadioButton extends AppCompatActivity implements RadioGroup.OnCheckedChangeListener{private RadioGroup rg_tab_bar;private RadioButton rb_channel;//Fragment Objectprivate Fragment_btm_nvg_rb_context fg1,fg2,fg3,fg4;private FragmentManager fManager;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_bottom_nvg_with_radio_button);fManager = getSupportFragmentManager();rg_tab_bar = (RadioGroup) findViewById(R.id.rg_tab_bar);rg_tab_bar.setOnCheckedChangeListener(this);//獲取第一個單選按鈕,并設置其為選中狀態rb_channel = (RadioButton) findViewById(R.id.rb_channel);rb_channel.setChecked(true);}@Overridepublic void onCheckedChanged(RadioGroup group, int checkedId) {// FragmentTransaction只能使用一次,// 每次使用都要調用FragmentManager 的beginTransaction()方法獲得FragmentTransaction事務對象FragmentTransaction fTransaction = fManager.beginTransaction();hideAllFragment(fTransaction);switch (checkedId){case R.id.rb_channel:if(fg1 == null){fg1 = new Fragment_btm_nvg_rb_context("第一個Fragment");fTransaction.add(R.id.ly_content,fg1);}else{fTransaction.show(fg1);}break;case R.id.rb_message:if(fg2 == null){fg2 = new Fragment_btm_nvg_rb_context("第二個Fragment");fTransaction.add(R.id.ly_content,fg2);}else{fTransaction.show(fg2);}break;case R.id.rb_better:if(fg3 == null){fg3 = new Fragment_btm_nvg_rb_context("第三個Fragment");fTransaction.add(R.id.ly_content,fg3);}else{fTransaction.show(fg3);}break;case R.id.rb_setting:if(fg4 == null){fg4 = new Fragment_btm_nvg_rb_context("第四個Fragment");fTransaction.add(R.id.ly_content,fg4);}else{fTransaction.show(fg4);}break;}fTransaction.commit();}//隱藏所有Fragmentprivate void hideAllFragment(FragmentTransaction fragmentTransaction){if(fg1 != null)fragmentTransaction.hide(fg1);if(fg2 != null)fragmentTransaction.hide(fg2);if(fg3 != null)fragmentTransaction.hide(fg3);if(fg4 != null)fragmentTransaction.hide(fg4);} }

RadioGroup + RadioButton +ViewPager

效果圖

分析

我們在第二個實例的基礎上(RadioButton方式) 加上ViewPager來實現滑動切換頁面的效果。

ViewPager概念

一個頁面切換的組件,我們可以往里面填充多個View,然后我們可以通過觸摸屏幕左右滑動 切換不同的View,和前面學習的ListView一樣,我們需要一個Adapter(適配器),將要顯示的View和 我們的ViewPager進行綁定,而ViewPager有他自己特定的Adapter——PagerAdapter!另外,Google 官方是建議我們使用Fragment來填充ViewPager的,這樣可以更加方便的生成每個Page以及管理 每個Page的生命周期!當然它給我們提供了兩個不同的Adapter,他們分別是: FragmentPageAdapter和FragmentStatePagerAdapter! 而我們本節用到的則是前者:FragmentPageAdapter! 另外要說一點的是ViewPager的緩存機制: ViewPager會緩存當前頁,前一頁,以及后一頁,比如有1,2,3,4這四個頁面:
——>當我們處于第一頁:緩存1,2
——> 處于第二頁:緩存 1,2,3
——> 處于第三頁:緩存2,3,4 ——> 處于第四頁緩存3,4這樣!

使用PagerAdapter要重寫相關方法

  • getCount( ):獲得viewpager中有多少個view
  • destroyItem( ):移除一個給定位置的頁面。適配器有責任從容器中刪除這個視圖。這是為了確保 在finishUpdate(viewGroup)返回時視圖能夠被移除。
  • instantiateItem( ):①將給定位置的view添加到ViewGroup(容器)中,創建并顯示出來 ②返回一個代表新增頁面的Object(key),通常都是直接返回view本身就可以了, 當然你也可以自定義自己的key,但是key和每個view要一一對應的關系
  • isViewFromObject( ):判斷instantiateItem(ViewGroup, int)函數所返回來的Key與一個頁面視圖是否是 代表的同一個視圖(即它倆是否是對應的,對應的表示同一個View),通常我們直接寫 return view == object;就可以了,至于為什么要這樣講起來比較復雜,后面有機會進行了解吧 貌似是ViewPager中有個存儲view狀態信息的ArrayList,根據View取出對應信息的吧!

PS:不一定要重寫所有方法~

Code

Step 1:相關資源文件的準備:

同方法2

Step 2:編寫主Activity的布局文件:

只是把前面的FrameLayout替換成了:android.support.v4.view.ViewPager而已:

.....<android.support.v4.view.ViewPagerandroid:id="@+id/vpager"android:layout_width="match_parent"android:layout_height="match_parent"android:layout_above="@id/div_tab_bar"android:layout_below="@id/ly_top_bar"></android.support.v4.view.ViewPager>

Step 3:編寫Fragment的布局以及代碼:

Fragment1.java

package com.turing.base.activity.fragment.fragmentPractice4;import android.os.Bundle; import android.support.v4.app.Fragment; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.TextView;import com.apkfuns.logutils.LogUtils; import com.turing.base.R;/*** 為了順便演示ViewPager的機制,* 特意寫成了四個Fragment!在onCreateView中打印創建Log!*/ public class Fragment1 extends Fragment {public Fragment1() {// Required empty public constructor}@Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {// Inflate the layout for this fragmentView view = inflater.inflate(R.layout.fragment_fragment1, container, false);TextView txt_content = (TextView) view.findViewById(R.id.txt_content);txt_content.setText("第一個Fragment");LogUtils.e("Fragment1 onCreateView");return view;}}

布局文件

<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:background="@color/bg_white"android:orientation="vertical"><TextView android:id="@+id/txt_content"android:layout_width="match_parent"android:layout_height="match_parent"android:gravity="center"android:text="XXX"android:textColor="@color/text_yellow"android:textSize="20sp" /></LinearLayout>

Step 4:自定義FragmentPagerAdapter類:

MyFragmentPagerAdapter.java

package com.turing.base.activity.fragment.fragmentPractice4;import android.support.v4.app.Fragment; import android.support.v4.app.FragmentManager; import android.support.v4.app.FragmentPagerAdapter;/*** MyApp** @author Mr.Yang on 2016-03-16 22:50.* @version 1.0* @desc*/ public class MyFragmentPagerAdapter extends FragmentPagerAdapter {private final int PAGER_COUNT = 4;private Fragment1 myFragment1 = null;private Fragment2 myFragment2 = null;private Fragment3 myFragment3 = null;private Fragment4 myFragment4 = null;public MyFragmentPagerAdapter(FragmentManager fm) {super(fm);myFragment1 = new Fragment1();myFragment2 = new Fragment2();myFragment3 = new Fragment3();myFragment4 = new Fragment4();}@Overridepublic Fragment getItem(int position) {Fragment fragment = null;switch (position) {case BottomNvgViewPageAct.PAGE_ONE:fragment = myFragment1;break;case BottomNvgViewPageAct.PAGE_TWO:fragment = myFragment2;break;case BottomNvgViewPageAct.PAGE_THREE:fragment = myFragment3;break;case BottomNvgViewPageAct.PAGE_FOUR:fragment = myFragment4;break;}return fragment;}@Overridepublic int getCount() {return PAGER_COUNT;} }

Step 5:BottomNvgViewPageAct的編寫:

package com.turing.base.activity.fragment.fragmentPractice4;import android.os.Bundle; import android.support.v4.view.ViewPager; import android.support.v7.app.AppCompatActivity; import android.widget.RadioButton; import android.widget.RadioGroup; import android.widget.TextView;import com.turing.base.R;public class BottomNvgViewPageAct extends AppCompatActivity implements RadioGroup.OnCheckedChangeListener,ViewPager.OnPageChangeListener {//UI Objectsprivate TextView txt_topbar;private RadioGroup rg_tab_bar;private RadioButton rb_channel;private RadioButton rb_message;private RadioButton rb_better;private RadioButton rb_setting;private ViewPager vpager;private MyFragmentPagerAdapter mAdapter;//幾個代表頁面的常量public static final int PAGE_ONE = 0;public static final int PAGE_TWO = 1;public static final int PAGE_THREE = 2;public static final int PAGE_FOUR = 3;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_bottom_nvg_view_page);mAdapter = new MyFragmentPagerAdapter(getSupportFragmentManager());bindViews();rb_channel.setChecked(true);}private void bindViews() {txt_topbar = (TextView) findViewById(R.id.txt_topbar);rg_tab_bar = (RadioGroup) findViewById(R.id.rg_tab_bar);rb_channel = (RadioButton) findViewById(R.id.rb_channel);rb_message = (RadioButton) findViewById(R.id.rb_message);rb_better = (RadioButton) findViewById(R.id.rb_better);rb_setting = (RadioButton) findViewById(R.id.rb_setting);rg_tab_bar.setOnCheckedChangeListener(this);vpager = (ViewPager) findViewById(R.id.vpager);vpager.setAdapter(mAdapter);vpager.setCurrentItem(0);vpager.addOnPageChangeListener(this);}@Overridepublic void onCheckedChanged(RadioGroup group, int checkedId) {switch (checkedId) {case R.id.rb_channel:vpager.setCurrentItem(PAGE_ONE);break;case R.id.rb_message:vpager.setCurrentItem(PAGE_TWO);break;case R.id.rb_better:vpager.setCurrentItem(PAGE_THREE);break;case R.id.rb_setting:vpager.setCurrentItem(PAGE_FOUR);break;}}//重寫ViewPager頁面切換的處理方法@Overridepublic void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {}@Overridepublic void onPageSelected(int position) {}@Overridepublic void onPageScrollStateChanged(int state) {//state的狀態有三個,0表示什么都沒做,1正在滑動,2滑動完畢if (state == 2) {switch (vpager.getCurrentItem()) {case PAGE_ONE:rb_channel.setChecked(true);break;case PAGE_TWO:rb_message.setChecked(true);break;case PAGE_THREE:rb_better.setChecked(true);break;case PAGE_FOUR:rb_setting.setChecked(true);break;}}} }

TabLayout +ViewPager

關于TabLayout的使用,請查看本人博客TabLayout-Android M新控件

效果圖

分析

  • 導航欄顯示的圖片 和 導航TAB下的橫線顏色 ,可以在自定義的style中設置tabIndicatorColor來決定,如果要顯示TAB,textAllCaps需要設置為false。如下所示
<!--修改默認的TabLayout取的 tab indicator color chosen is the accent color defined for your Material Design theme--><style name="MyCustomTabLayout" parent="Widget.Design.TabLayout"><item name="tabIndicatorColor">#0000FF</item><!--必須設置textAllCapsfalse,否則圖片不顯示--><item name="tabTextAppearance">@style/MyCustomTextAppearance</item></style><!--By default, the tab created by TabLayout sets the textAllCaps property to be true, which prevents ImageSpans from being rendered.You can override this behavior by changing the tabTextAppearance property.--><style name="MyCustomTextAppearance" parent="TextAppearance.Design.Tab"><item name="textAllCaps">false</item></style>
  • 如果要將TAB放在底部,只需要在主布局文件LinearLayout中將TabLayout放在下面即可

  • ViewPager 我們引用的是V4包下的,以實現更好地兼容,這樣的話 就需要使用getSupportFragmentManager來獲取FragmentManager

  • TabLayout設置TabMode為TabLayout.MODE_FIXED,防止TAB擠在一起

  • FragmentPageAdapter子類中,我們的標題是帶有圖片的,因此可以重寫getPageTitle方法,通過SpannableString+ImageSpan來設置

Code

TabLayoutAct.java

package demo.turing.com.materialdesignwidget.tabLayout;import android.os.Bundle; import android.support.design.widget.TabLayout; import android.support.v4.view.ViewPager; import android.support.v7.app.AppCompatActivity;import demo.turing.com.materialdesignwidget.R;public class TabLayoutAct extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_tab_layout);// Get the ViewPager and set it's PagerAdapter so that it can display itemsViewPager viewPager = (ViewPager) findViewById(R.id.viewpager);viewPager.setAdapter(new SimpleFragmentPagerAdapter(getSupportFragmentManager(), TabLayoutAct.this));// Give the TabLayout the ViewPagerTabLayout tabLayout = (TabLayout) findViewById(R.id.sliding_tabs);tabLayout.setupWithViewPager(viewPager);// 設置MODE_FIXED避免TabLayout擠到一塊去tabLayout.setTabMode(TabLayout.MODE_FIXED);} }

activity_tab_layout.xml

style見分析中的第一條

<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><android.support.design.widget.TabLayout android:id="@+id/sliding_tabs"android:layout_width="match_parent"android:layout_height="wrap_content"style="@style/MyCustomTabLayout"/><android.support.v4.view.ViewPager android:id="@+id/viewpager"android:layout_width="match_parent"android:layout_height="0px"android:layout_weight="1"android:background="@android:color/white" /></LinearLayout>

SimpleFragmentPagerAdapter.java

package demo.turing.com.materialdesignwidget.tabLayout;import android.content.Context; import android.graphics.drawable.Drawable; import android.support.v4.app.Fragment; import android.support.v4.app.FragmentManager; import android.support.v4.app.FragmentPagerAdapter; import android.text.Spannable; import android.text.SpannableString; import android.text.style.ImageSpan; import android.util.Log; import android.view.LayoutInflater; import android.view.View;import demo.turing.com.materialdesignwidget.R;/*** MyApp** @author Mr.Yang on 2016-03-08 09:58.* @version 1.0* @desc*/ public class SimpleFragmentPagerAdapter extends FragmentPagerAdapter {/*** Add Icons to TabLayout ,在getPageTitle獲取*/private int[] imageResId = {R.drawable.tag_blue,R.drawable.flag_mark_violet,R.drawable.flag_mark_yellow};final int PAGE_COUNT = 3;private String tabTitles[] = new String[]{"TAB_1", "TAB_2", "TAB_3"};private Context context;/*** 構造函數** @param fm* @param context*/public SimpleFragmentPagerAdapter(FragmentManager fm, Context context) {super(fm);this.context = context;}@Overridepublic Fragment getItem(int position) {return PageFragment.newInstance(position + 1);}@Overridepublic int getCount() {return PAGE_COUNT;}@Overridepublic CharSequence getPageTitle(int position) {// Generate title based on item position 設置文字// return tabTitles[position];// 設置圖片 // Drawable image = ContextCompat.getDrawable(context, imageResId[position]); // image.setBounds(0, 0, image.getIntrinsicWidth(), image.getIntrinsicHeight()); // SpannableString sb = new SpannableString(" "); // ImageSpan imageSpan = new ImageSpan(image, ImageSpan.ALIGN_BOTTOM); // sb.setSpan(imageSpan, 0, 1, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); // return sb;// 設置文字和圖片// Generate title based on item positionDrawable image = context.getResources().getDrawable(imageResId[position]);image.setBounds(0, 0, image.getIntrinsicWidth(), image.getIntrinsicHeight());// Replace blank spaces with image iconSpannableString sb = new SpannableString(" " + tabTitles[position]);ImageSpan imageSpan = new ImageSpan(image, ImageSpan.ALIGN_BOTTOM);sb.setSpan(imageSpan, 0, 1, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);return sb;}/*** 自定義tab* 如果需要每個TAB都需要指定成單獨的布局,switch即可,如果是相同的,寫一個即可* 這里自定義的不是Fragment的布局,不要搞混了,僅僅是TAB的樣式* @param* @return*/public View getTabView(int position) {View view = null;Log.d("getTabView", String.valueOf(position));switch (position) {case 0:// Given you have a custom layout in `res/layout/custom_tab.xml` with a TextView and ImageViewview = LayoutInflater.from(context).inflate(R.layout.custom_tab, null); // TextView tv = (TextView) view.findViewById(R.id.textView); // tv.setText(tabTitles[position]); // ImageView img = (ImageView) view.findViewById(R.id.imageView); // img.setImageResource(imageResId[position]);break;case 1:// Given you have a custom layout in `res/layout/custom_tab1.xml` with a TextView and ImageViewview = LayoutInflater.from(context).inflate(R.layout.custom_tab1, null); // TextView tv2 = (TextView) view.findViewById(R.id.textView); // tv2.setText(tabTitles[position]); // ImageView img2 = (ImageView) view.findViewById(R.id.imageView); // img2.setImageResource(imageResId[position]);break;case 2:// Given you have a custom layout in `res/layout/custom_tab2.xml` with a TextView and ImageViewview = LayoutInflater.from(context).inflate(R.layout.custom_tab2, null); // TextView tv3 = (TextView) view.findViewById(R.id.textView); // tv3.setText(tabTitles[position]); // ImageView img3 = (ImageView) view.findViewById(R.id.imageView); // img3.setImageResource(imageResId[position]);break;default:break;}return view;} }

PageFragment.java

package demo.turing.com.materialdesignwidget.tabLayout;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 demo.turing.com.materialdesignwidget.R;/*** MyApp** @author Mr.Yang on 2016-03-08 09:43.* @version 1.0* @desc*/ public class PageFragment extends Fragment {public static final String ARG_PAGE = "ARG_PAGE";private int mPage;public static PageFragment newInstance(int page) {Bundle args = new Bundle();args.putInt(ARG_PAGE, page);PageFragment fragment = new PageFragment();// 傳遞參數fragment.setArguments(args);return fragment;}@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);// 獲取參數mPage = getArguments().getInt(ARG_PAGE);}@Nullable@Overridepublic 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

僅作為演示,fragment的布局文件只有一個TextView~

<?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"android:text="fragment~"/>

總結

以上是生活随笔為你收集整理的底部导航栏的几种实现方式的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

国产精品四虎 | 成年免费在线视频 | 久久久免费av | 精品国产一区二区三区久久久蜜月 | 中文字幕av有码 | 国产涩涩在线观看 | www.色在线| 久久久久欠精品国产毛片国产毛生 | 午夜成人免费影院 | 麻豆国产网站入口 | 久久久久99999 | 国产美女网 | 福利一区在线视频 | 久久激情片| 国产精品一区二区精品视频免费看 | 九九热在线精品 | 操操爽 | 韩日精品中文字幕 | 尤物97国产精品久久精品国产 | av高清免费在线 | 激情av综合 | 91av在线视频免费观看 | 在线观看亚洲a | 激情综合网婷婷 | 中文字幕欧美三区 | 亚洲国产99 | 免费在线观看a v | 久久成人综合视频 | 国产精品欧美日韩 | 99精品视频99 | 日韩色高清| 成人久久精品 | 麻豆免费看片 | 久草在线综合 | 成年人黄色大片在线 | 成人亚洲精品久久久久 | 美女久久99 | 香蕉视频在线看 | 亚洲天堂网在线视频 | 午夜狠狠干 | 在线播放 亚洲 | 97热在线观看 | 五月婷久久 | 国产一级视屏 | 欧美日韩性| av在线a| 亚洲免费在线视频 | 精品国产99 | 天天干天天操天天 | 92中文资源在线 | 操少妇视频 | 黄色软件在线观看视频 | 1000部国产精品成人观看 | 天天干天天操av | 久久久久一区二区三区 | 三级黄色三级 | 久久久久亚洲最大xxxx | 午夜视频在线观看欧美 | 国产又粗又猛又黄又爽的视频 | 国产日韩一区在线 | 97影视 | 亚洲精品在线一区二区三区 | 99热9| 99视频精品全国免费 | 8x8x在线观看视频 | 久久久免费观看视频 | 波多野结衣综合网 | 日韩久久精品一区二区 | 成人在线视频在线观看 | 国产精品字幕 | 久久国产系列 | 欧美精品网站 | 中文字幕一区二区三区四区 | 免费电影播放 | 亚洲欧美成人 | 99视频精品 | 在线观看中文字幕亚洲 | 久久这里只有精品视频99 | 亚洲aⅴ免费在线观看 | 国产高清在线视频 | 欧美一区二视频在线免费观看 | 天天爽夜夜爽人人爽曰av | 国产精品一区二区在线 | 久久久网| 8x成人免费视频 | 91精品在线观看入口 | 91视频免费 | 97在线观看免费高清完整版在线观看 | 日日碰狠狠添天天爽超碰97久久 | 精品一区二区在线免费观看 | 日韩欧美一级二级 | 免费观看黄 | 亚洲天堂网在线视频 | 国产精品免费不卡 | 波多野结衣在线观看视频 | 亚洲国产网站 | 国产涩涩在线观看 | 一区二区三区四区在线免费观看 | 国产成人精品一区二区三区免费 | 久久综合福利 | 久99视频| 久草精品视频在线看网站免费 | 免费成人av在线看 | 久久综合欧美 | 五月天婷亚洲天综合网鲁鲁鲁 | 国产一区二区三区 在线 | 久久国产精品视频观看 | 99麻豆视频 | 天天天操操操 | 国产69久久精品成人看 | 99热在线国产精品 | 婷婷在线网站 | 久久久久久久久黄色 | 久久久久久久久久网站 | 精品免费观看视频 | 久久99久久99精品免观看软件 | 亚洲欧美视频在线观看 | 狠狠色丁香久久婷婷综合五月 | 免费网址你懂的 | 91成人亚洲| 日韩免费视频网站 | 欧美精品免费在线观看 | 激情深爱.com| 亚洲美女精品视频 | 精品播放 | 91久久奴性调教 | 在线免费视频 你懂得 | 亚洲精品白浆高清久久久久久 | 中文字幕精品一区久久久久 | 探花视频在线观看+在线播放 | 国产精品99久久久久久小说 | 国产精品久久免费看 | 免费a视频在线观看 | 日韩精品一区在线观看 | 成人免费观看大片 | 亚洲精品白浆高清久久久久久 | 99精品国产福利在线观看免费 | 日韩欧美电影网 | 日韩精品在线一区 | 伊人国产视频 | 国产亚洲精品久久久久动 | 日韩高清在线观看 | 午夜手机电影 | 久久午夜精品视频 | 探花视频在线版播放免费观看 | 狠狠操狠狠插 | 国产高清黄色 | 亚洲免费视频在线观看 | 日韩精品一区二区三区视频播放 | 超碰在线97观看 | 激情大尺度视频 | 成人国产亚洲 | 国产精品久久久久久影院 | 国产日韩欧美在线一区 | 久av电影 | 中文字幕资源网 | www婷婷| 日韩在线激情 | 欧美日韩亚洲一 | 天天天天天天天操 | 久久国产精品视频观看 | 亚洲综合激情五月 | 黄色毛片大全 | 久久艹久久| 免费的国产精品 | 91久久人澡人人添人人爽欧美 | www欧美日韩 | 91在线入口| 国产精品99久久免费黑人 | 丰满少妇久久久 | 一区二区三区 亚洲 | 三级午夜片 | 国产免费不卡av | 最近中文字幕免费大全 | 午夜精品久久久久99热app | 成人国产网址 | 91成人看片 | 国产视频在线一区二区 | 欧美午夜理伦三级在线观看 | 国产在线色视频 | 亚洲国产精品va在线 | 午夜狠狠干 | 亚洲一区二区三区91 | 激情丁香 | 久久久国产在线视频 | 久久国产精品精品国产色婷婷 | 成 人 黄 色 视频 免费观看 | 日韩特黄一级欧美毛片特黄 | 亚洲日本一区二区在线 | 日韩精品一区二区在线观看视频 | 欧美日韩视频一区二区三区 | 欧美精品在线观看免费 | 亚洲精品成人av在线 | 亚洲国产高清在线观看视频 | 久久亚洲视频 | 成人精品一区二区三区中文字幕 | 国产一区视频在线 | 最新超碰| 成人国产精品免费观看 | 99热精品国产一区二区在线观看 | 午夜精品久久久久久久久久久久久久 | 狠狠的干狠狠的操 | www.天天干 | 91丨九色丨国产女 | 日本性生活一级片 | 中文字幕人成不卡一区 | 奇米影视在线99精品 | 欧美激情综合色 | 开心婷婷色 | 国产91在线观 | 色综合久久综合中文综合网 | 在线观看91| 蜜臀av性久久久久蜜臀aⅴ流畅 | 激情五月在线视频 | 在线亚洲天堂网 | 日本亚洲国产 | 天天干,天天干 | 97精品国产97久久久久久粉红 | 国内久久久 | 久久综合操 | 久草免费色站 | 日韩伦理片一区二区三区 | 国产91免费在线 | 综合天天久久 | 一级黄网 | 午夜久久影院 | 午夜av不卡 | 亚洲国产精品va在线 | 亚洲jizzjizz日本少妇 | aa级黄色大片| 国产精品丝袜久久久久久久不卡 | 欧美国产日韩久久 | 日韩精品一区二区三区免费视频观看 | 国产伦精品一区二区三区在线 | 婷婷深爱五月 | 免费碰碰 | 高清av免费看 | 九九视频精品免费 | 国产精品视频最多的网站 | 97电院网手机版 | 国产精品美女视频网站 | 一区二区电影网 | 天天操婷婷 | 在线а√天堂中文官网 | 亚洲观看黄色网 | 国产精品久久久久国产精品日日 | 97夜夜澡人人双人人人喊 | 欧美在线视频一区二区三区 | 成人av网址大全 | 欧美另类xxxx | 精品久久五月天 | 国产亚洲精品久久久久久久久久 | 91人人澡 | 欧美99久久 | 国产伦精品一区二区三区免费 | 久久国色夜色精品国产 | 亚洲在线高清 | 99视频精品 | 国产香蕉久久 | 最新久久免费视频 | 国产精品九九九九九九 | 久久久久久久综合色一本 | 欧美激情视频一区二区三区免费 | 狠狠躁日日躁狂躁夜夜躁av | 亚洲在线视频免费观看 | 日本 在线 视频 中文 有码 | 在线精品观看 | 久草在线视频首页 | 一级黄色片在线播放 | 爱情影院aqdy鲁丝片二区 | 国产美女视频免费观看的网站 | 日韩av电影手机在线观看 | 婷婷九九 | 伊人五月天婷婷 | 一区二区三区三区在线 | 日韩免费在线观看视频 | 免费中午字幕无吗 | 国产精品久久久久久一二三四五 | 国产精品久久人 | 国产精品毛片一区二区 | 亚洲欧美日本一区二区三区 | 日本免费久久高清视频 | 亚洲精品88欧美一区二区 | www.av在线.com | 久久系列 | 日韩精品亚洲专区在线观看 | 国产小视频在线看 | 日韩av电影中文字幕在线观看 | 亚洲国产视频在线 | 免费a视频在线 | 五月天久久激情 | 99精品视频免费 | 欧美一级视频免费 | 中文字幕乱在线伦视频中文字幕乱码在线 | 99视频在线精品国自产拍免费观看 | 一区二区三区四区精品视频 | 欧美在线视频一区二区三区 | 麻豆va一区二区三区久久浪 | 黄色毛片视频免费观看中文 | 视频一区二区免费 | 黄网站色欧美视频 | 久久8| 国产视频91在线 | 欧美日韩国产一二三区 | 91久草视频 | 亚洲成av人片在线观看www | 久久国产区 | 亚洲欧美少妇 | 91精品欧美 | 超碰国产在线 | 狠狠色丁香婷婷综合久久片 | 亚洲精品av中文字幕在线在线 | 最新日韩精品 | av软件在线观看 | se视频网址 | 精品久久久久久国产 | 亚洲国产日韩在线 | 国产视频在线看 | 日韩中文字| 国产中文字幕在线视频 | 久久婷亚洲五月一区天天躁 | 天天天天天天干 | 国产精品18久久久久久久久久久久 | 国产美女在线观看 | 少妇bbbb揉bbbb日本 | 色婷婷导航 | 久久久麻豆 | 在线观看激情av | 九月婷婷人人澡人人添人人爽 | 最新日韩在线观看 | 日韩黄色网络 | 久艹在线免费观看 | 天天视频亚洲 | 国产精品女教师 | 国产日韩中文字幕在线 | 国产精品不卡 | 色老板在线 | 日韩av专区| 97在线影院 | 亚洲天堂精品视频在线观看 | 国产精品久久在线观看 | 亚洲精品国产自产拍在线观看 | 五月综合色 | 国产精品99久久久久久有的能看 | 狠狠插天天干 | 最近2019好看的中文字幕免费 | 毛片网站在线 | 国产片免费在线观看视频 | 久久午夜国产精品 | 久草精品视频在线观看 | 激情欧美xxxx | 97香蕉久久国产在线观看 | 成人av中文字幕在线观看 | 制服丝袜欧美 | 91新人在线观看 | 中文字幕二区三区 | www久| 在线导航av| 天天色天天操天天爽 | 久久激情五月丁香伊人 | 九九在线高清精品视频 | 日韩精品一区二区三区三炮视频 | 亚洲伊人婷婷 | 视频国产在线 | 黄色福利网站 | 国产亚洲精品成人av久久ww | 国产高清不卡一区二区三区 | 九色91在线 | 日韩精品一区二区三区电影 | 中文字幕在线视频网站 | 国产成人精品午夜在线播放 | 欧美三级高清 | 精品国产一区二区三区免费 | 中文字幕日韩精品有码视频 | www.天天成人国产电影 | 成人av在线播放网站 | 亚洲视频在线观看免费 | 黄色大片免费网站 | 天天天天天天操 | 超碰在线公开免费 | 丁香婷婷久久久综合精品国产 | 五月天婷婷在线视频 | 一区二区精 | 日本公妇在线观看 | 日本性高潮视频 | 人人干在线 | 天天操夜| 97精品国产97久久久久久春色 | 在线观看香蕉视频 | 92中文资源在线 | 中文字幕在线观看视频一区二区三区 | 婷久久| 一区二区三区在线视频111 | 欧美日韩不卡一区二区三区 | 黄色一级大片在线免费看国产一 | 亚洲激情综合 | 色综合久久久久久久久五月 | 精品999久久久 | 狠狠亚洲 | 最近最新mv字幕免费观看 | 国产老太婆免费交性大片 | 精品999 | 国产麻豆视频免费观看 | 亚洲视频 一区 | 韩国av电影网 | 日韩四虎| 精品国内自产拍在线观看视频 | 午夜少妇av | 国产精品视频永久免费播放 | 久久久亚洲精华液 | 日韩av免费一区二区 | 久久久久久久久久久久电影 | 成人91免费视频 | 日韩精品一区二区久久 | 日韩丝袜视频 | 亚洲 综合 精品 | 欧美日韩国产一区二区三区 | 久草在线官网 | 免费高清av在线看 | 夜添久久精品亚洲国产精品 | 精品国内自产拍在线观看视频 | 九九九电影免费看 | 国产精品免费观看网站 | 三级免费黄 | 激情综合五月天 | 黄色一及电影 | 日日夜夜爱 | 一区免费视频 | 久久精品视频免费 | 久久精彩视频 | 日韩| 日韩精品一区二区三区免费观看 | 麻豆一精品传二传媒短视频 | 人人澡人人草 | 正在播放亚洲精品 | 涩涩网站在线 | 91av在| 欧美久久久久久久久中文字幕 | 伊人永久在线 | 久久理论电影 | 欧美男同网站 | 91精品国产自产老师啪 | 五月婷婷视频在线 | 国产中文字幕国产 | 中文字幕免费在线 | 日韩av电影免费观看 | 久久精品女人毛片国产 | 成人小视频免费在线观看 | 日韩欧美大片免费观看 | 日批在线看 | 黄色国产在线 | 欧美性生活免费看 | 激情一区二区三区欧美 | 国产精品一区一区三区 | 日韩高清精品免费观看 | 夜夜躁狠狠燥 | 麻豆免费视频观看 | 中文av在线免费观看 | 色婷婷狠狠五月综合天色拍 | 久久国产精品色婷婷 | 久久不卡视频 | 99 精品 在线 | 欧美a√大片 | 久久99精品国产麻豆宅宅 | 精品成人a区在线观看 | 麻豆果冻剧传媒在线播放 | 久久久精品久久日韩一区综合 | 亚洲一片黄 | 国产一区国产精品 | 日本午夜在线观看 | 午夜久久久精品 | 久久久影视 | 丁香九月婷婷 | 日韩在线视频看看 | 91九色免费视频 | 久草在线视频在线观看 | 久久午夜网 | 久久蜜臀一区二区三区av | 91激情视频在线播放 | 国产高清视频在线播放一区 | 亚洲国产精品一区二区尤物区 | 麻豆国产在线视频 | 中文字幕在线视频网站 | 久久久久免费观看 | 激情五月婷婷激情 | 99久久久国产精品免费99 | 免费色视频 | 精品国偷自产国产一区 | 久久福利影视 | 这里只有精品视频在线 | 人人舔人人爱 | 爱爱一区 | 不卡的av在线播放 | 色综合天天射 | 亚洲资源在线网 | 亚洲国产精品500在线观看 | 91在线porny国产在线看 | 国产一级黄大片 | 国产精品麻豆视频 | 亚洲精品一区二区在线观看 | 亚洲自拍偷拍色图 | 色综合久久久久综合体 | 激情喷水 | 操高跟美女 | 美腿丝袜一区二区三区 | 国产在线传媒 | 亚洲黄色免费在线 | www久久 | 久久躁日日躁aaaaxxxx | 国产成人一区二区精品非洲 | 国产精品不卡在线观看 | 欧美 日韩 性 | 国产三级视频在线 | 99在线看| 天天操天天操天天操天天操天天操天天操 | 色久五月| 四虎在线视频 | 国产高清视频在线播放 | 久久国产精品成人免费浪潮 | 99久久婷婷国产 | 91九色最新地址 | 五月天精品视频 | 在线激情网 | 日本黄色一级电影 | 天天av在线播放 | 精品国自产在线观看 | 久久电影国产免费久久电影 | 国产永久网站 | 精品国产一区二区在线 | 九九久久国产 | 国色综合 | av成人免费 | 国产免费国产 | 狠狠干天天操 | 亚洲精品女人 | 天天操天天干天天爽 | 亚洲免费观看在线视频 | 激情综合色播五月 | www.夜色321.com| 久久国产亚洲视频 | 国产 欧美 日产久久 | 最近更新的中文字幕 | www.日韩免费 | 久久精精品 | 日韩精品综合在线 | 啪啪免费观看网站 | 一级α片 | 日日干av| 亚洲精品tv久久久久久久久久 | 国产中文字幕视频在线 | 亚洲精品视频在线观看网站 | 成人一级黄色片 | 色婷婷综合久色 | 热久久视久久精品18亚洲精品 | 精品久久久久久亚洲综合网站 | 综合色影院 | 国产精品久久伊人 | 久久精国产 | 在线欧美小视频 | 欧美福利片在线观看 | 亚洲欧洲视频 | 亚洲精品国产精品久久99 | 国产精品不卡一区 | 久久国产免 | 国产精品一区二区在线 | 日韩高清精品免费观看 | 一区二区三区日韩视频在线观看 | 欧美激情视频在线免费观看 | 午夜精品视频免费在线观看 | 国产69精品久久久久久久久久 | 国产精品乱码久久久久 | 日韩免费在线观看网站 | 天天干天天搞天天射 | 最近高清中文在线字幕在线观看 | 欧美最猛性xxxxx(亚洲精品) | 99热手机在线 | 免费不卡中文字幕视频 | 97人人模人人爽人人喊中文字 | 国产va精品免费观看 | 精品超碰 | 美女网站在线免费观看 | 亚洲欧美日韩在线一区二区 | 美女视频a美女大全免费下载蜜臀 | 婷婷国产一区二区三区 | 国产亚洲精品久久久久久大师 | 高清不卡毛片 | 国产黄色片久久 | 国产福利av | 日韩久久久久久久久 | 国产成人福利在线观看 | 亚洲日本中文字幕在线观看 | 亚洲精品麻豆 | 日韩在线视 | 日韩精品视频网站 | 色爱区综合激月婷婷 | 日韩在线字幕 | 婷五月天激情 | 日韩黄色软件 | 97在线观看免费高清 | 久久综合天天 | 五月婷婷中文字幕 | av在线官网| 亚洲精品久久激情国产片 | 久久久伦理 | 国产看片网站 | 日韩精品免费在线 | 正在播放日韩 | 久久亚洲在线 | 玖玖爱免费视频 | 国产中文字幕精品 | 黄色www免费 | 日韩美女久久 | 91精品办公室少妇高潮对白 | 97免费在线视频 | 麻豆手机在线 | 中文字幕 国产 一区 | 国产超碰在线观看 | 成年人电影毛片 | 国产精品中文字幕av | 亚洲精品资源 | 久久综合婷婷综合 | 一区二区三区视频在线 | 中文字幕专区高清在线观看 | 日韩av免费观看网站 | 国产在线一卡 | 六月婷色 | 亚洲免费成人 | a在线播放 | 91丨九色丨首页 | 香蕉视频啪啪 | 91在线免费视频观看 | 久久91久久久久麻豆精品 | 久久久成人精品 | 久久视频在线看 | 91chinesexxx| 黄网站免费看 | 久久精品99国产精品日本 | 国产精品成人一区二区 | 在线观看免费日韩 | 免费三及片 | 国产 精品 资源 | 激情开心| 亚洲黄色在线免费观看 | 国产午夜三级一区二区三 | 国产亚洲精品电影 | 久久精品一二三区白丝高潮 | 日本h在线播放 | 国产精品av电影 | 久久99网 | 一区 二区电影免费在线观看 | 久久久免费毛片 | 色香天天| 久久久视屏| 日韩欧美精品一区二区 | 波多野结衣精品在线 | 亚洲综合成人av | 91探花在线视频 | 亚洲一区二区三区在线看 | 欧美性生交大片免网 | 亚洲国产精品一区二区久久,亚洲午夜 | 最新国产中文字幕 | 日韩三级不卡 | 黄色大片免费播放 | 久久99热精品这里久久精品 | 在线观看黄色免费视频 | 美女黄频网站 | 一二区电影 | 在线视频 日韩 | 月丁香婷婷 | 99在线高清视频在线播放 | 精品国自产在线观看 | av资源网在线播放 | 在线观看黄网站 | 中文字幕中文字幕 | 国产亚洲资源 | 久热只有精品 | 国产色就色 | www.日韩免费| 亚洲va综合va国产va中文 | 91精品久久久久久综合乱菊 | 天天操天天草 | 99九九99九九九视频精品 | 西西人体www444 | 久久精品久久综合 | 99视频久 | 看av免费 | 色a4yy| 一级黄色a视频 | 青青河边草免费观看完整版高清 | 亚洲电影第一页av | 99视频在线精品国自产拍免费观看 | 在线观看91精品国产网站 | 在线电影 你懂得 | www91在线| 91在线精品播放 | 高清久久久久久 | 国产色视频一区二区三区qq号 | 一区二区三区在线观看免费视频 | 成年人视频在线观看免费 | 色插综合 | 色综合久久88色综合天天人守婷 | 国产精品久久久久aaaa | 精品999在线观看 | 久久免费视频网 | 国产亚州精品视频 | 六月色婷婷 | 91免费在线 | 日韩高清一 | 午夜精品久久久久久久久久久久久久 | 久草免费新视频 | 亚洲精品视频在线观看免费视频 | 五月天,com| 日本电影久久 | 亚洲天堂网在线视频观看 | 亚洲欧美成人网 | 国产一区二区三区高清播放 | 成人资源在线播放 | 久草a在线 | 中文字幕亚洲综合久久五月天色无吗'' | 国产精品日韩欧美一区二区 | 日韩网站在线看片你懂的 | 在线观看中文字幕dvd播放 | 在线看免费 | 欧美日韩不卡在线 | 久久精品8 | 久久午夜网 | 日韩大片在线免费观看 | 天天在线视频色 | 91av在线视频免费观看 | 在线亚洲人成电影网站色www | 激情黄色av | 成人a级免费视频 | 国产精品久久久一区二区 | 中文字幕亚洲综合久久五月天色无吗'' | 天天操狠狠操 | 国产欧美在线一区二区三区 | 中文字幕国产精品 | 精品字幕在线 | 免费成人在线电影 | 开心色婷婷 | 日本91在线 | 日韩理论在线 | 久久久精品日本 | 久久永久免费视频 | 91九色最新 | 女人18精品一区二区三区 | 国内精品久久久久久久久久久久 | 久久久久成人精品免费播放动漫 | 国产精品久久久久免费a∨ 欧美一级性生活片 | 久久久久久蜜av免费网站 | 色资源网免费观看视频 | 91女子私密保健养生少妇 | 成人免费看电影 | 亚洲精品九九 | 国产精品久久久久久久久久久久午夜 | 国产精品video | 黄色天堂在线观看 | 国产精品久久久久久久久久久久 | 激情综合国产 | www.国产高清 | 国产精品黄色 | 免费在线观看av不卡 | 欧美日韩在线免费观看视频 | 在线视频国产区 | 久草在线免费看视频 | 97超碰色| 欧美一级网站 | 麻豆影视在线观看 | 精品 激情 | 久草在线免 | 在线黄频 | 99久久久久免费精品国产 | 超碰在线cao | 亚洲二区精品 | 综合婷婷久久 | 又大又硬又黄又爽视频在线观看 | 国产精品com| 国产白浆视频 | 欧美日韩视频在线一区 | 黄色网www | 国产精品高潮呻吟久久久久 | 一级α片免费看 | 日日操日日操 | 久草在线资源观看 | 99久久婷婷国产一区二区三区 | 字幕网av| 欧美日韩一二三四区 | 国产亚洲视频中文字幕视频 | 九九九九精品九九九九 | 亚洲精品乱码久久久久久写真 | 免费大片黄在线 | 这里只有精品视频在线观看 | 国产啊v在线 | 中文字幕在线观看第一页 | 福利一区二区在线 | 欧美日韩久 | 在线视频一区二区 | 久久公开视频 | 97精品在线视频 | 97精品国产97久久久久久免费 | 日韩欧美v| 成年人视频免费在线 | 96亚洲精品久久 | 国产在线免费 | 久久成年人视频 | 亚洲少妇自拍 | 蜜臀av性久久久久av蜜臀妖精 | 亚洲日本色 | 色噜噜狠狠狠狠色综合 | 97电影在线看视频 | 99久久久久成人国产免费 | 在线色亚洲 | 中文字幕日韩在线播放 | 97成人在线| 五月婷婷六月丁香激情 | 亚洲涩涩网站 | 伊人影院99 | 亚洲最新av在线 | 99久久久免费视频 | 中日韩三级视频 | 中文av免费 | 操夜夜操 | 特黄特黄的视频 | 国产无套精品久久久久久 | 日韩精品最新在线观看 | 亚洲欧洲中文日韩久久av乱码 | 激情久久久久久久久久久久久久久久 | 国产精品毛片一区视频播不卡 | 麻豆国产露脸在线观看 | 一级一片免费观看 | 人人澡超碰碰97碰碰碰软件 | 国产在线观看黄 | 91在线视频观看免费 | 在线免费黄 | 91成品视频 | 超级碰碰碰视频 | 国产一级免费电影 | 91爱爱视频| 四虎影视8848dvd| 久久99爱视频 | 成人av av在线 | 欧美一级欧美一级 | 黄色av电影免费观看 | 91女人18片女毛片60分钟 | 欧美日韩中文字幕在线视频 | 日韩网站免费观看 | 在线观看日韩av | 一区二区三区 亚洲 | 精品视频123区在线观看 | 国产一区二区三区四区大秀 | 亚洲欧洲日韩 | 在线视频日韩精品 | 国产青春久久久国产毛片 | 中文字幕国产精品一区二区 | 麻豆视频在线观看免费 | 伊人色**天天综合婷婷 | 国产精品九九久久99视频 | 国产精品一二三 | 日韩精品亚洲专区在线观看 | 免费网站污 | 99性视频 | 网址你懂的在线观看 | 综合网av | 中文有码在线 | 亚洲精品乱码久久久久久蜜桃91 | 在线国产福利 | 成 人 黄 色 片 在线播放 | 久久久久久久久久久免费 | 国产女人免费看a级丨片 | 国产 中文 日韩 欧美 | 人人爽夜夜爽 | 美女免费视频一区二区 | 综合网婷婷 | 91福利专区 | 欧美精品免费在线 | 精品国产精品一区二区夜夜嗨 | www.久久精品视频 | 久久久久久久久久久精 | 国产成人精品av | 国产最新视频在线观看 | 国产一线在线 | 日韩精品一区二区免费视频 | 久久久久亚洲精品中文字幕 | 99成人免费视频 | 日韩高清二区 | 四虎在线视频 | 免费成人av| 欧美91在线| 欧美日韩视频免费看 | 国产美女免费看 | 999成人国产 | 久久精品日本啪啪涩涩 | 在线精品在线 | 黄网站免费久久 | 91av免费看 | 国产成人精品一二三区 | 国产一区二区在线免费播放 | 久久中文欧美 | 欧美日韩精品区 | 国产在线超碰 | 啪啪凸凸 | 国产特级毛片aaaaaaa高清 | 国产精品一区二区久久精品爱微奶 | 中文字幕免费观看全部电影 | 天堂av在线网 | 999男人的天堂 | 五月色丁香 | 亚洲v欧美v国产v在线观看 | 久久字幕精品一区 | 国产一级精品视频 | 在线观看第一页 | 天天综合中文 | 三级小视频在线观看 | 欧美日韩高清一区二区三区 | av黄网站 | 天天做天天爱夜夜爽 | 久久99久久99精品中文字幕 | 超碰97网站 | 看黄色.com| 国产一级黄 | 免费观看一区 | 久久高清毛片 | 中文字幕免费一区 | 中文字幕高清在线播放 | 337p日本欧洲亚洲大胆裸体艺术 | 黄网站app在线观看免费视频 | 欧美少妇xxx| 99精品视频在线观看视频 | bbbb操bbbb| 亚洲精品中文字幕在线 | 中文字幕av在线 | 日韩电影在线一区二区 | 最近最新最好看中文视频 | 少妇bbbb搡bbbb桶 | 香蕉视频免费看 | 色com| 九九精品视频在线看 | 91精品国产99久久久久久久 | 精品国产一区二区三区蜜臀 | 成年人免费av | 国产v在线观看 | www.久久免费视频 | 国内精品久久天天躁人人爽 | 久久久久女教师免费一区 | 中文在线字幕免费观 | 中文字幕免费观看视频 | 国产精品av在线免费观看 | 国产精品视频99 | 中文字幕二区在线观看 | 国产一区免费在线 | 在线免费观看视频你懂的 | 久久艹艹| 亚洲精品乱码久久久久久9色 | 久久精品美女视频网站 | av一级片在线观看 | 免费观看久久久 | 日韩精品免费一区二区三区 | 欧美色插 | 国产无区一区二区三麻豆 | 美女视频一区二区 | 国内成人av | 精品专区| 欧美精品亚洲二区 | 国产人成一区二区三区影院 | 欧美日韩国产精品一区二区 | 中文在线资源 | 在线观看免费 | 狠狠干美女 | 四虎在线免费 | 亚洲国产成人av网 | 亚洲成人午夜av | 久久综合五月婷婷 | 免费观看丰满少妇做爰 | 色综合久久久久久中文网 | 日韩一区二区免费播放 | 久久草在线视频国产 | 日韩电影一区二区三区 | 久久综合操 | 国内精品99 | 欧美日本三级 | 97视频免费在线看 | 91色在线观看视频 | 久草视频在线看 | 午夜免费视频网站 | 久久经典国产视频 | 国产视频在线观看一区 | 久久久久国产免费免费 | 亚洲成人家庭影院 | 69国产成人综合久久精品欧美 | 精品一二三四五区 | www久久九 | 国产视频69 | 国产原创91| 香蕉91视频| 久久不卡电影 | 狠狠干狠狠久久 | 成人av中文字幕 | 中文字幕 欧美性 |