前一篇主要是布局的编写,这篇就时java代码的编写
界面编写:学习笔记之---RadioButton+Fragment制作简单框架(一)
为了实现点击按钮出现不同的界面,这里所用到Fragmnet(碎片)
一:准备工作:先创建4个java文件 4个布局文件 这里我用HomePageFragment.java fragment_homepage.xml
在java文件HomePageFragment 继承自v4包下的Fragment 然后重写onCreateView(),,返回一个View
在方法中我们关联我们想要展现的布局View view = inflater.inflate(R.layout.fragment_homepage,container,false);
三个参数,第一个是布局文件,第二个是ViewGroup,第三个写flase就行
public class HomePageFragment extends Fragment {
@Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_homepage,container,false);
return view;
}
}
这样的java文件和布局总共创建4个,分别对应我们的按钮:
二:接下来回到主布局代码文件中去设置点击切换效果MainActivity.java
public class MainActivity extends AppCompatActivity implements RadioGroup.OnCheckedChangeListener {
Fragment[] fragments;//一个成员变量数组
Fragment homeFragment;
Fragment shopCartFragment;
Fragment mapFragment;
Fragment mineFragment;
//主布局中的控件
private FrameLayout frameLayout;
private RadioGroup radioGroup;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
isFragment(0);//表示默认显示界面是HomePage
}
/*
* 初始化视图和组件
* */
private void initView() {
frameLayout = findViewById(R.id.frameLayout);
radioGroup = findViewById(R.id.radioGroup);
radioGroup.setOnCheckedChangeListener(this);
//获取Fragment实例
homeFragment = new HomePageFragment();
shopCartFragment = new ShoppingCartFragment();
mapFragment = new MapFragment();
mineFragment = new MineFragment();
fragments = new Fragment[]{homeFragment,shopCartFragment,mapFragment,mineFragment};
}
/*
* Fragment事务管理,
*先获取管理者,开启管理器,然后添加Fragment对象到FrameLyout中,最后提交
* */
public void isFragment(int fm){
FragmentManager fragmentManager = getSupportFragmentManager();
FragmentTransaction ft = fragmentManager.beginTransaction();
ft.replace(R.id.frameLayout,fragments[fm]).commit();
}
/*
* RadioGroup中RadioButton的点击监听
* */
@Override
public void onCheckedChanged(RadioGroup group, int checkedId) {
switch (checkedId){
case R.id.radioButton_homepage:
isFragment(0);
break;
case R.id.radioButton_shoppingCart:
isFragment(1);
break;
case R.id.radioButton_map:
isFragment(2);
break;
case R.id.radioButton_mine:
isFragment(3);
break;
}
}
}
首先我们在onCreate()中调用initView()方法和isFragment()方法
initView(): 先初始化控件,然后获取4个Fragment的实例,将这些实例添加到Fragment的数组里面,
isFragment(): FragmentManager fragmentManager = getSupportFragmentManager();//获取管理者
FragmentTransaction ft = fragmentManager.beginTransaction();//开启事务管理器
ft.replace(R.id.frameLayout,fragments[fm]);//第一个参数:FrameLayout布局id 第二个参数:Fragment实例
最后看看效果图