Fragment的整合使用,类似工厂模式
在初学Fragment的时候,许多小伙伴都会使用一个Fragment就创建一个Activity去管理,这样维护起来会很方便,但是会显得很冗杂,所以今天就来分享一个方法,也顺便记录下心得。以下就是我测试demo的结构,one…four是fragment的布局文件,另外两个啥也没有,还没写
不多BB,直接上代码
主类的
public class MainActivity extends AppCompatActivity {
ViewPager viewPager;
FragmentPagerAdapter fragmentPagerAdapter;
List<Fragment> mlist=new ArrayList<Fragment>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
viewPager=findViewById(R.id.viewPager);
adadFragment();
initView();
}
private void adadFragment()
{
mlist.add(MyBaseFragment.newInstance(R.layout.one));
mlist.add(MyBaseFragment.newInstance(R.layout.two));
mlist.add(MyBaseFragment.newInstance(R.layout.three));
mlist.add(MyBaseFragment.newInstance(R.layout.four));
}
public void initView()
{
fragmentPagerAdapter=new FragmentPagerAdapter(getSupportFragmentManager()) {
@Override
public Fragment getItem(int i) {
return mlist.get(i);
}
@Override
public int getCount() {
return mlist.size();
}
};
viewPager.setAdapter(fragmentPagerAdapter);
}
}
public class MyBaseFragment extends Fragment {
int layoutId;
@Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState)
{
layoutId=getArguments().getInt("layoutId");
View view=inflater.inflate(layoutId,null,false);
return view;
}
public static MyBaseFragment newInstance(int layoutId)
{
MyBaseFragment myBaseFragment=new MyBaseFragment();
Bundle bundle=new Bundle();
bundle.putInt("layoutId",layoutId);
myBaseFragment.setArguments(bundle);
return myBaseFragment;
}
}
或许有人会说这样不同页面的控件怎么绑定?ID不好绑定,点击事件怎么办?
这里我们可以使用tag标记方法来进行点击事件的触发,与这种使用模式非常契合
看图
想必大家看到这两行代码应该知道什什么意思了(src自行省略),在布局文件中使用onClick和tag是非常适合项目中有过多的点击事件的时候使用的,tag相当于一个标识符,可以在values/string中定义自己想要的字符串标识符,然后在到点击方法去判断点击了哪一个控件,根据那个控件的标识符来执行相应的逻辑
贴上最近维护的一个项目里面的一小行代码,第一行getID请自行忽略嘿嘿,
直接看下面的就知道什么意思了吧。
这种实现fragment的方式有好处也有坏处,好处就是代码清晰简洁,坏处就是如果页面存在多种业务处理,那业务处理的方法也会多到爆炸,比如说动画初始化,存储检查,更新应用列表,或许还要重写接收数据结果的方法啊比如onActivityResult等等等等,但是还是有解决办法的,不过我就不写出来了哈哈,毕竟个人思考探究也是很重要的嘛(懒)。也算是一种简单的工厂模式了吧,毕竟没有面向接口,只简单实现了面向对象~