前言:
正在做一个资讯类app,打算一边做一边整理,供自己学习与巩固。用到的知识复杂度不高,仅适于新手。经验不多,如果写出来的代码有不好的地方欢迎讨论。
该系列的其他文章
第二章 retrofit获取网络数据
第一章 滑动顶部导航栏
本章内容最终效果:
知识点:ViewPager,TabLayout,FragmentPagerAdapter,Fragment
学习目标:
1、掌握ViewPager、TabLayout的结合使用。
2、运用TabLayout与ViewPager、FragmentPagerAdapter的相关知识实现可滑动的顶部导航栏。
可滑动的顶部导航栏在国内的很多app中经常出现(最典型的例子:网易云音乐),使用者只需左右滑动屏幕即可切换到自己想要的页面,非常方便。本章内容将仿照网易云音乐ui来实现顶部导航栏的效果。
项目实战:
本章用到的drawable资源、values资源皆存放在百度网盘
(请将values文件夹中的style.xml或color.xml更新一致后再运行,如有后续更新自行修改)
1.1 主页面布局
主页面布局代码不多,仅仅是include了主体布局main_content。
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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="com.example.administrator.idlereader.MainActivity">
<include layout="@layout/main_content" />
</LinearLayout>
新建布局文件main_content.xml,代码:
main_content.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
android:orientation="vertical">
<View
android:id="@+id/view_status"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:visibility="gone"></View>
<android.support.v7.widget.Toolbar
android:id="@+id/toolbars"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="@color/colorTheme"
app:contentInsetStart="0dp"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="center"
android:orientation="horizontal">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:orientation="horizontal">
<ImageView
android:id="@+id/iv_title_news"
android:layout_width="55dp"
android:layout_height="match_parent"
android:padding="15dp"
android:src="@drawable/titlebar_news" />
<ImageView
android:id="@+id/iv_title_movie"
android:layout_width="55dp"
android:layout_height="match_parent"
android:layout_gravity="center"
android:padding="13dp"
android:src="@drawable/titlebar_movie" />
<ImageView
android:id="@+id/iv_title_video"
android:layout_width="55dp"
android:layout_height="match_parent"
android:padding="15dp"
android:src="@drawable/titlebar_video" />
</LinearLayout>
</LinearLayout>
</android.support.v7.widget.Toolbar>
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v4.view.ViewPager
android:id="@+id/vp_content"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:descendantFocusability="blocksDescendants" />
</FrameLayout>
</LinearLayout>
在该布局中,我们使用到了Toolbar和ViewPager,ViewPager的作用是存放fragment,Toolbar做为顶部导航栏。
1.2 主页面逻辑代码
在写主页面代码前,我们先建3个fragment,用来放进我们的FragmentPagerAdapter里。
新建3个Fragment,分别命名为FgNewsFragment、FgMovieFragment、FgVideoFragment(这个命名方式是因为我习惯用第三方插件Code Generate生成fragment文件或activity文件)。
data:image/s3,"s3://crabby-images/5acd3/5acd371f1658ffaccda9b9e3b8345ed50b03f3e4" alt=""
data:image/s3,"s3://crabby-images/7197a/7197afb2a019457ae6137d75db3327e97d3ba53e" alt=""
这3个Fragment的不需要写什么东西,显示一个TextView就好了
data:image/s3,"s3://crabby-images/dff16/dff1640ef6dded8f329f6355aa7d923e803f3a5e" alt=""
data:image/s3,"s3://crabby-images/cee46/cee4651b344528d042bbcbd78c3d41f4a02cb830" alt=""
有了这三个Fragment后,我们来给ViewPager写一个Adapter]
新建java文件,命名为MyFragmentAdapter.java
data:image/s3,"s3://crabby-images/448c0/448c0e183c2ef35a00245d4c659b33d272a06ec1" alt=""
data:image/s3,"s3://crabby-images/d4c49/d4c4947cc474796b197bd27f58ede5b1b04ac4f1" alt=""
写完了适配器,再来完善MainActivity的代码:
data:image/s3,"s3://crabby-images/b956c/b956c2c65e875f9690836f0e0e042a448b2b54d0" alt=""
完成后的效果:
data:image/s3,"s3://crabby-images/cee4a/cee4a43a38005dd6a700134df4218e94fc2939b0" alt=""
2.1 新闻页面导航栏
在新闻页面导航栏要用到TabLayout,这需要我们导一下库:
data:image/s3,"s3://crabby-images/f3cb0/f3cb051dbae38d9ea2ec0cd2851d72a2b05f56e5" alt=""
首先还是布局,把上面创建的fg_news.xml的代码修改一下。
fg_news.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<android.support.design.widget.TabLayout
android:id="@+id/tl_news"
android:layout_width="match_parent"
android:layout_height="40dp"
android:background="@color/colorTheme"
app:tabIndicatorColor="@color/colorWhite"
app:tabSelectedTextColor="@color/colorWhite"
app:tabTextColor="@color/colorTabTextNormal" />
<android.support.v4.view.ViewPager
android:id="@+id/vp_news"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</LinearLayout>
加了个TabLayout,我把选择状态和自然状态的设置都写进布局文件里了。
2.2 新闻页面导航栏逻辑代码
建一个Fragment,命名为FgNewsListFragment
data:image/s3,"s3://crabby-images/40c39/40c399d5c784a226ec43ae59477f6c2fbfcbe90c" alt=""
data:image/s3,"s3://crabby-images/0b035/0b03592256f931e10949c7addb6a0848ff90ae2e" alt=""
布局代码也是只显示个TextView
<?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">
<TextView
android:id="@+id/tv_news"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="top"
android:textSize="100dp" />
</LinearLayout>
FgNewsListFragment的代码:
data:image/s3,"s3://crabby-images/d93e6/d93e63868428ef0e5dcba573214ec2590ad02cff" alt=""
接下来是修改FgNewsFragment的代码:
data:image/s3,"s3://crabby-images/5c629/5c6295597fcba0c4ee33c289278a7209d0e8b672" alt=""
最后效果:
需要注意的是在主页面adapter的实例化中,FragmentManager用的是getSupportFragmentManager()。
MyFragmentAdapter adapter = new MyFragmentAdapter(getSupportFragmentManager(),
mFragmentList);
而新闻页面用的是getChildFragmentManager(),
MyFragmentAdapter adapter=new MyFragmentAdapter(getChildFragmentManager(),
fragments,fragmentTitles);
这是因为新闻页面里的fragment是嵌套于新闻fragment的,如果继续用getSupportFragmentManager()的话,getFragmentManager到的是activity对所包含fragment的Manager,所以要使用getChildFragmentManager()。
以上就是实现顶部导航栏的所有内容。
下一章:
第二章 retrofit获取网络数据
网友评论