




版權(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)用開(kāi)發(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)題啊,我開(kāi)始方了,,,然后網(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ì)造成誤解。好了,開(kāi)始說(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 華東師范大學(xué)《風(fēng)景園林設(shè)計(jì)實(shí)驗(yàn)古典園林景觀設(shè)計(jì)》2023-2024學(xué)年第二學(xué)期期末試卷
- 武漢工程大學(xué)郵電與信息工程學(xué)院《立體設(shè)計(jì)》2023-2024學(xué)年第二學(xué)期期末試卷
- 南京師范大學(xué)泰州學(xué)院《大學(xué)美育》2023-2024學(xué)年第二學(xué)期期末試卷
- 南昌航空大學(xué)《電路(下)》2023-2024學(xué)年第二學(xué)期期末試卷
- 河南檢察職業(yè)學(xué)院《造型基礎(chǔ)(工設(shè))》2023-2024學(xué)年第二學(xué)期期末試卷
- 河源廣東河源紫金縣專門學(xué)校駐校教官招聘7人筆試歷年參考題庫(kù)附帶答案詳解
- 山東農(nóng)業(yè)大學(xué)《組成原理與接口技術(shù)》2023-2024學(xué)年第二學(xué)期期末試卷
- 山西體育職業(yè)學(xué)院《聯(lián)合創(chuàng)作預(yù)案》2023-2024學(xué)年第二學(xué)期期末試卷
- 中國(guó)礦業(yè)大學(xué)(北京)《基礎(chǔ)造型》2023-2024學(xué)年第二學(xué)期期末試卷
- 河南2025年河南省工業(yè)學(xué)校招聘20人筆試歷年參考題庫(kù)附帶答案詳解-1
- 市政工程監(jiān)理規(guī)劃范本(完整版)
- 幼兒園小班語(yǔ)言:《我上幼兒園》 PPT課件
- 高標(biāo)準(zhǔn)農(nóng)田項(xiàng)目規(guī)劃設(shè)計(jì)和評(píng)審要點(diǎn)
- 小學(xué)三年級(jí)下冊(cè)綜合實(shí)踐活動(dòng).水果拼盤-(14張)ppt
- 部編版二年級(jí)語(yǔ)文下冊(cè)第三單元課文《傳統(tǒng)節(jié)日》PPT課件
- 北京市城市建設(shè)節(jié)約用地標(biāo)準(zhǔn)
- 開(kāi)學(xué)第一課我們開(kāi)學(xué)啦主題班會(huì)PPT課件(帶內(nèi)容)
- 電源線檢驗(yàn)報(bào)告RVV
- 體育訓(xùn)練隊(duì)隊(duì)規(guī)
- 八字命理漫畫版
- 電梯工程開(kāi)工報(bào)告(直梯)(共1頁(yè))
評(píng)論
0/150
提交評(píng)論