版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
【移動(dòng)應(yīng)用開發(fā)技術(shù)】怎么在Fragment中使用ViewPager實(shí)現(xiàn)一個(gè)底部導(dǎo)航欄
本篇文章為大家展示了怎么在Fragment中使用ViewPager實(shí)現(xiàn)一個(gè)底部導(dǎo)航欄,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。<RelativeLayout
xmlns:android="/apk/res/android"
xmlns:tools="/tools"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="@color/theme_color"
android:clipToPadding="true"
android:fitsSystemWindows="true"
>
<include
android:id="@+id/actionbar_activity_main"
layout="@layout/actionbar"
/>
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_below="@id/actionbar_activity_main"
android:background="@color/white"
>
<RadioGroup
android:id="@+id/rg_menu_activity_main"
android:layout_width="fill_parent"
android:layout_height="55dp"
android:layout_alignParentBottom="true"
android:background="@color/theme_color"
android:gravity="center"
android:orientation="horizontal"
android:weightSum="3"
>
<RadioButton
android:id="@+id/rb_main_tab_menu1"
android:checked="true"
android:drawableTop="@drawable/radiobt_main_home"
android:gravity="center"
android:paddingTop="12dp"
android:text="@string/home_text"
android:textColor="@color/white"
/>
<RadioButton
android:id="@+id/rb_main_tab_menu2"
android:checked="false"
android:drawableTop="@drawable/radiobt_main_my"
android:gravity="center"
android:paddingTop="12dp"
android:text="@string/my_text"
android:textColor="@color/white"
/>
<RadioButton
android:id="@+id/rb_main_tab_menu3"
android:checked="false"
android:drawableTop="@drawable/radiobt_main_setting"
android:gravity="center"
android:paddingTop="12dp"
android:text="@string/setting_text"
android:textColor="@color/white"
/>
</RadioGroup>
<android.support.v4.view.ViewPager
android:id="@+id/vp_activity_main"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_above="@id/rg_menu_activity_main"
/>
</RelativeLayout>
</RelativeLayout>這個(gè)布局實(shí)現(xiàn)的效果如下:只看效果,大家覺(jué)得挺好的,但是重要的問(wèn)題來(lái)了。下面的radioButton點(diǎn)了沒(méi)反應(yīng),我檢查了一下xml文件,再檢查了一下java代碼,沒(méi)有問(wèn)題啊,我開始方了,,,然后網(wǎng)上搜,好像沒(méi)有人遇到這個(gè)問(wèn)題,,檢查好幾遍之后,問(wèn)旁邊的同學(xué),他說(shuō)既然設(shè)置了監(jiān)聽(tīng),但是沒(méi)有反應(yīng),那肯定是有一個(gè)東西把這個(gè)事件消費(fèi)掉了,我想起來(lái)了之前看的事件分發(fā)機(jī)制,,建議大家對(duì)事件分發(fā)機(jī)制不懂的小伙伴趕緊看看,面試和日常寫代碼都要用到,特別是面試,面試官特別喜歡問(wèn)?;貧w正題,大家看我的xml文件,我把viewpager寫在了Radiogroup的下面,并且,layout_height="fill_parent"
這樣我的viewpager就消費(fèi)掉了我的radiobutton的點(diǎn)擊事件,其實(shí)之后我覺(jué)得,是我的邏輯不正確,我應(yīng)該順序的寫下來(lái),而不是只實(shí)現(xiàn)功能,這樣我看自己的代碼可以看懂,可是給別人可能會(huì)造成誤解。好了,開始說(shuō)一下,實(shí)現(xiàn)底部導(dǎo)航的整個(gè)流程,實(shí)現(xiàn)的界面還如上:(在studio中寫的)actionbar.xml
上面自定義的actionbar
系統(tǒng)自帶的actionbar在java代碼中去掉了代碼功能:
左邊返回鍵
中間顯示的文字右邊的更多鍵
上圖中沒(méi)有顯示出來(lái),是因?yàn)槲覜](méi)有讓左右的鍵顯示出來(lái)<?xml
version="1.0"
encoding="utf-8"?>
<RelativeLayout
xmlns:android="/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="@dimen/actionBar_height"
android:background="@color/theme_color"
>
<RelativeLayout
android:id="@+id/rl_back_actionbar"
android:layout_width="@dimen/actionBar_back"
android:layout_height="fill_parent"
android:visibility="invisible">
<ImageView
android:layout_width="22dp"
android:layout_height="20dp"
android:layout_centerVertical="true"
android:layout_marginLeft="12dp"
android:background="@drawable/back"
android:contentDescription="@string/app_name"/>
</RelativeLayout>
<TextView
android:id="@+id/tv_title_actionbar"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:text="@string/TimeRobot"
android:textColor="#ffffff"
android:textSize="@dimen/actionBar_title_text_size"
/>
<RelativeLayout
android:id="@+id/rl_more_actionbar"
android:layout_width="wrap_content"
android:layout_height="fill_parent"
android:layout_alignParentRight="true"
android:visibility="invisible">
<ImageView
android:layout_width="25dp"
android:layout_height="25dp"
android:layout_centerVertical="true"
android:layout_marginRight="12dp"
android:background="@drawable/more"
android:contentDescription="@string/app_name"/>
</RelativeLayout>
</RelativeLayout>activity_main.xml文件
中間的部分color資源,是我引用的自動(dòng)的,大家可以自己選擇<?xml
version="1.0"
encoding="utf-8"?>
<RelativeLayout
xmlns:android="/apk/res/android"
xmlns:tools="/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/theme_color"
android:clipToPadding="true"
tools:context=".MainActivity">
<!--
引入
actionbar-->
<include
android:id="@+id/actionbar_activity_main"
layout=
"@layout/actionbar"/>
<android.support.v4.view.ViewPager
android:id="@+id/vp_activity_main"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_below="@+id/actionbar_activity_main"
android:layout_alignParentRight="true"
android:layout_alignParentEnd="true"
android:background="@color/white"/>
<RadioGroup
android:id="@+id/rg_main_radioGroup"
android:layout_width="fill_parent"
android:layout_height="58dp"
android:layout_alignParentBottom="true"
android:background="@color/theme_color"
android:gravity="center"
android:orientation="horizontal"
android:weightSum="3">
<RadioButton
android:id="@+id/rb_main_tab_menu1"
android:layout_weight="1"
android:layout_width="0dp"
android:layout_height="fill_parent"
android:checked="true"
android:drawableTop="@drawable/radio_bt_plan"
android:gravity="center"
android:button="@null"
android:paddingTop="8dp"
android:text="@string/home_text"
android:textColor="@color/white"/>
<RadioButton
android:id="@+id/rb_main_tab_menu2"
android:layout_weight="1"
android:layout_width="0dp"
android:layout_height="fill_parent"
android:checked="false"
android:drawableTop="@drawable/radio_bt_time"
android:gravity="center"
android:button="@null"
android:paddingTop="8dp"
android:text="@string/timeGroup"
android:textColor="@color/white"/>
<RadioButton
android:id="@+id/rb_main_tab_menu3"
android:layout_weight="1"
android:layout_width="0dp"
android:layout_height="fill_parent"
android:checked="false"
android:drawableTop="@drawable/radio_bt_my"
android:gravity="center"
android:button="@null"
android:paddingTop="8dp"
android:textColor="@color/white"
android:text="@string/My"/>
</RadioGroup>
</RelativeLayout>注意一下,radiobutton中的一個(gè)屬性是
drawableTop屬性,這個(gè)后面引用的drawable資源是實(shí)現(xiàn)點(diǎn)擊改變r(jià)adiobutton狀態(tài)的布局文件,我給大家貼出來(lái)radio_bt_plan.xml文件的代碼,其他的只要新建,copy代碼,改顯示的圖片即可。還有,對(duì)于初次用studio的伙伴,這里要注意了,new的時(shí)候,drawable>右鍵
>
new>newresourcefile
(即出來(lái)的第一個(gè))而不是XMLradio_bt_plan.xml<?xml
version="1.0"
encoding="utf-8"?>
<selector
xmlns:android="/apk/res/android">
<item
android:drawable="@drawable/planning_press"
android:state_enabled="true"
android:state_focused="true"
android:state_pressed="false"/>
<item
android:drawable="@drawable/planning_press"
android:state_enabled="true"
android:state_pressed="true"
/>
<item
android:drawable="@drawable/planning_press"
android:state_checked="true"
android:state_enabled="true"
/>
<item
android:drawable="@drawable/planning"/>
</selector>接下來(lái)就是
MainActivity.java文件了public
class
MainActivity
extends
FragmentActivity
{
private
TextView
title_text;
private
ViewPager
vp_main_tab;
private
List<Fragment>
fragmentList
=
null;
private
FragmentPagerAdapter
mAdapter
=
null;
private
MyFragment
myFragment;
private
TimeGroupFragment
timeGroupFragment;
private
PlanningFragment
planningFragment;
private
RadioButton
rb_main_tab_menu1;
private
RadioButton
rb_main_tab_menu2;
private
RadioButton
rb_main_tab_menu3;
private
RadioGroup
rg_main_group;
@Override
protected
void
onCreate(Bundle
savedInstanceState)
{
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.activity_main);
init();
rg_main_group.setOnCheckedChangeListener(new
RadioGroup.OnCheckedChangeListener()
{
@Override
public
void
onCheckedChanged(RadioGroup
group,
int
checkedId)
{
switch
(checkedId)
{
case
R.id.rb_main_tab_menu1:
vp_main_tab.setCurrentItem(0);
initActionbar(0);
break;
case
R.id.rb_main_tab_menu2:
vp_main_tab.setCurrentItem(1);
initActionbar(1);
break;
case
R.id.rb_main_tab_menu3:
vp_main_tab.setCurrentItem(2);
initActionbar(2);
break;
default:
break;
}
}
});
initViewPage();
}
private
void
initActionbar(int
currentPage)
{
switch
(currentPage)
{
case
0:
title_text.setText(getResources().getString(R.string.TimeRobot));
break;
case
1:
title_text.setText(getResources().getString(R.string.timeGroup));
break;
case
2:
title_text.setText(getResources().getString(R.string.My));
break;
default:
break;
}
}
private
void
init()
{
title_text
=
(TextView)
findViewById(R.id.tv_title_actionbar);
vp_main_tab
=
(ViewPager)
findViewById(R.id.vp_activity_main);
fragmentList
=
new
ArrayList<Fragment>();
rg_main_group
=
(RadioGroup)
findViewById(R.id.rg_main_radioGroup);
rb_main_tab_menu1
=
(RadioButton)
findViewById(R.id.rb_main_tab_menu1);
rb_main_tab_menu2
=
(RadioButton)
findViewById(R.id.rb_main_tab_menu2);
rb_main_tab_menu3
=
(RadioButton)
findViewById(R.id.rb_main_tab_menu3);
myFragment
=
new
MyFragment();
timeGroupFragment
=
new
TimeGroupFragment();
planningFragment
=
new
PlanningFragment();
fragmentList.add(myFragment);
fragmentList.add(timeGroupFragment);
fragmentList.add(plannin
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 橡膠行業(yè)煙氣處理方案
- 二零二五年度國(guó)際貨運(yùn)司機(jī)聘用勞動(dòng)合同模板3篇
- 貨物運(yùn)輸代理合同
- 房地產(chǎn)公司正式職工勞動(dòng)合同
- 交通事故協(xié)議書
- 單位車輛租賃合同書
- 全新房屋產(chǎn)權(quán)確認(rèn)協(xié)議下載
- 借款分期還款合同范本
- 陽(yáng)光房合同簽時(shí)要注意的細(xì)節(jié)
- 協(xié)議離婚的辦理流程
- 學(xué)校對(duì)口幫扶工作計(jì)劃
- 做投標(biāo)文件培訓(xùn)
- 9.4+跨學(xué)科實(shí)踐:制作簡(jiǎn)易活塞式抽水機(jī)課件+-2024-2025學(xué)年人教版物理八年級(jí)下冊(cè)
- 建筑工程工作計(jì)劃
- 2014新PEP小學(xué)英語(yǔ)六年級(jí)上冊(cè)-Unit5-What-does-he-do復(fù)習(xí)課件
- 外科護(hù)理課程思政課程標(biāo)準(zhǔn)
- 9.2溶解度(第1課時(shí)飽和溶液不飽和溶液)+教學(xué)設(shè)計(jì)-2024-2025學(xué)年九年級(jí)化學(xué)人教版(2024)下冊(cè)
- 2024年審計(jì)局公務(wù)員招錄事業(yè)單位招聘考試招錄139人完整版附答案【研優(yōu)卷】
- 礦山隱蔽致災(zāi)普查治理報(bào)告
- 2017年江蘇南京中考滿分作文《無(wú)情歲月有味詩(shī)》5
- 副總經(jīng)理招聘面試題與參考回答(某大型國(guó)企)2024年
評(píng)論
0/150
提交評(píng)論