Android MVVM框架搭建(九)TabLayout、ViewPager、城市地图天气切换

在上一篇文章中完成了高德地图的使用及地图天气的显示,现在地图上可以查看当前的所在地天气,本文中将对国内其他城市进行切换,地图进行移动,天气查询。同时完成Fragment中再加载Fragment,通过TabLayout和ViewPager进行切换。

正文

===============================================================

从易到难,先完成Fragment中加载Fragment,现在HomeActivity中加载了三个Fragment,其中NewsFragment和VideoFragment的性质有一些相近,因此我们可以把这两个Fragment放到一个Fragment中去加载显示,这样做可以节省HomeActivity中空间。

一、父Fragment加载子Fragment


很简单,我们先在fragment包下创建一个InfoFragment,对应的布局info_fragment.xml,代码如下:

<?xml version="1.0" encoding="utf-8"?>

<layout xmlns:android=“http://schemas.android.com/apk/res/android”

xmlns:app=“http://schemas.android.com/apk/res-auto”

xmlns:tools=“http://schemas.android.com/tools”>

<RelativeLayout

android:layout_width=“match_parent”

android:layout_height=“match_parent”

tools:context=“.ui.fragment.InfoFragment”>

<com.google.android.material.tabs.TabLayout

android:id=“@+id/tab”

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

app:tabIndicatorColor=“@color/purple_500”

app:tabTextColor=“@color/purple_500” />

<androidx.viewpager.widget.ViewPager

android:id=“@+id/vp”

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:layout_below=“@+id/tab” />

① Fragment适配器

然后我们创建一个Fragment适配器,在adapter包创建InfoFragmentAdapter类,代码如下:

public class InfoFragmentAdapter extends FragmentPagerAdapter {

String titleArr[];

List mFragmentList;

public InfoFragmentAdapter(FragmentManager fm, List list, String[] titleArr) {

super(fm);

mFragmentList = list;

this.titleArr = titleArr;

}

@Override

public Fragment getItem(int i) {

return mFragmentList.get(i);

}

@Override

public int getCount() {

return mFragmentList != null ? mFragmentList.size() : 0;

}

@Nullable

@Override

public CharSequence getPageTitle(int position) {

return titleArr[position];

}

@Override

public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) {

// super.destroyItem(container, position, object);

}

}

② TabLayout组合ViewPager

下面在InfoFragment中进行两个控件的组合,InfoFragment中代码如下:

public class InfoFragment extends BaseFragment {

public static InfoFragment newInstance() {

return new InfoFragment();

}

private InfoFragmentBinding binding;

/**

  • 标题数组

*/

private final String[] titles = {“新闻”,“视频”};

private final List fragmentList = new ArrayList<>();

@Override

public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container,

@Nullable Bundle savedInstanceState) {

binding = DataBindingUtil.inflate(inflater,R.layout.info_fragment,container,false);

return binding.getRoot();

}

@Override

public void onActivi

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值