Fragment+RadioGroup经典的主界面布局,方便实用;


1、使用replace方式:

直接上代码,先是布局文件;

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"> <RelativeLayout
android:id="@+id/rl"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:background="#ffffff"> <RadioGroup
android:id="@+id/rg"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#ffffff"
android:orientation="horizontal"> <RadioButton
android:id="@+id/rb_home"
style="@style/main_tab_button"
android:drawableTop="@drawable/rgbtn_home_select"
android:text="主页"/> <RadioButton
android:id="@+id/rb_shoppingcart"
style="@style/main_tab_button"
android:drawableTop="@drawable/rgbtn_gouwuche_select"
android:text="购物车"/> <RadioButton
android:id="@+id/rb_orderfrom"
style="@style/main_tab_button"
android:drawableTop="@drawable/rgbtn_orderfrom_select"
android:text="分类"/> <RadioButton
android:id="@+id/rb_my"
style="@style/main_tab_button"
android:drawableTop="@drawable/rgbtn_my_select"
android:text="个人"/>
</RadioGroup>
<View
style="@style/Line_e0e0e0_Horizontal"/>
</RelativeLayout>
<FrameLayout
android:id="@+id/fl"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_above="@id/rl"
></FrameLayout>
</RelativeLayout>

Radiogroup的style:

<style name="main_tab_button">
<item name="android:textSize">12dp</item>
<item name="android:textColor">@drawable/rgbtn_select</item>
<item name="android:ellipsize">marquee</item>
<item name="android:gravity">center</item>
<item name="android:paddingBottom">2dp</item>
<item name="android:background">#ffffff</item>
<item name="android:layout_width">0dp</item>
<item name="android:layout_weight">1.0</item>
<item name="android:layout_height">wrap_content</item>
<item name="android:button">@null</item>
<item name="android:singleLine">true</item>
<item name="android:drawablePadding">2dp</item>
</style>

文字的状态选择器:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:color="#666666" android:state_checked="false"/>
<item android:color="#424242" android:state_checked="true"/>
</selector>

图片状态选择器:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/datahui_def" android:state_checked="false"/>
<item android:drawable="@drawable/datahui_sel" android:state_checked="true"/>
</selector>

好了,核心代码:

public class FragmentReplaceActivity extends AppCompatActivity {

    @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(getContentViewResource());
initView();
initData();
initList();
}
private RadioGroup rg;
private Fragment HomeFm = null,SpcFm = null, OrderFm = null, MyFm = null; private final class RadioGroupOnCheckedChangeListener implements RadioGroup.OnCheckedChangeListener {
@Override
public void onCheckedChanged(RadioGroup radioGroup, int checkedId) {
/**
* 替换fragment
*/
switch (checkedId) {
case R.id.rb_home:
getSupportFragmentManager().beginTransaction().replace(R.id.fl, HomeFm).commit();
break;
case R.id.rb_shoppingcart:
getSupportFragmentManager().beginTransaction().replace(R.id.fl, SpcFm).commit();
break;
case R.id.rb_orderfrom:
getSupportFragmentManager().beginTransaction().replace(R.id.fl, OrderFm).commit();
break;
case R.id.rb_my:
getSupportFragmentManager().beginTransaction().replace(R.id.fl, MyFm).commit();
break;
}
}
} public int getContentViewResource() {
return R.layout.activity_fragment;
} protected void initView() {
rg = findViewById(R.id.rg);
} protected void initData() {
HomeFm = new Fragment1();
SpcFm = new Fragment2();
OrderFm = new Fragment3();
MyFm = new Fragment4();
} protected void initList() {
rg.setOnCheckedChangeListener(new RadioGroupOnCheckedChangeListener());
rg.check(R.id.rb_home);
}
}

这样,一个简单的使用replace点击切换界面就好了;不过这样的方式不太好,每次切换都要走一遍fragment中所有的方法,好来介绍下一种:

2、Add,Show,Hide;隐藏和显示fragment;

public class FragmentShowHideActivity extends AppCompatActivity {

    @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(getContentViewResource());
initView();
initData();
initList();
} private FrameLayout fl;
private RadioGroup rg;
private Fragment HomeFm = null,SpcFm = null, OrderFm = null, MyFm = null; private final class RadioGroupOnCheckedChangeListener implements RadioGroup.OnCheckedChangeListener {
@Override
public void onCheckedChanged(RadioGroup radioGroup, int checkedId) {
if (HomeFm != null) {
getSupportFragmentManager().beginTransaction().hide(HomeFm).commit();
}
if (SpcFm != null) {
getSupportFragmentManager().beginTransaction().hide(SpcFm).commit();
}
if (OrderFm != null) {
getSupportFragmentManager().beginTransaction().hide(OrderFm).commit();
}
if (MyFm != null) {
getSupportFragmentManager().beginTransaction().hide(MyFm).commit();
}
switch (checkedId) {
case R.id.rb_home:
if (HomeFm == null) {
HomeFm = new Fragment1();
getSupportFragmentManager().beginTransaction().add(R.id.fl, HomeFm).commit();
} else {
getSupportFragmentManager().beginTransaction().show(HomeFm).commit();
}
break;
case R.id.rb_shoppingcart:
if (SpcFm == null) {
SpcFm = new Fragment2();
getSupportFragmentManager().beginTransaction().add(R.id.fl, SpcFm).commit();
} else {
getSupportFragmentManager().beginTransaction().show(SpcFm).commit();
}
break; case R.id.rb_orderfrom:
if (OrderFm == null) {
OrderFm = new Fragment3();
getSupportFragmentManager().beginTransaction().add(R.id.fl, OrderFm).commit();
} else {
getSupportFragmentManager().beginTransaction().show(OrderFm).commit();
}
break;
case R.id.rb_my:
if (MyFm == null) {
MyFm = new Fragment4();
getSupportFragmentManager().beginTransaction().add(R.id.fl, MyFm).commit();
} else {
getSupportFragmentManager().beginTransaction().show(MyFm).commit();
}
break;
}
}
} public int getContentViewResource() {
return R.layout.activity_fragment;
} protected void initView() {
fl = findViewById(R.id.fl);
rg = findViewById(R.id.rg); } protected void initData() {
} protected void initList() {
rg.setOnCheckedChangeListener(new RadioGroupOnCheckedChangeListener());
rg.check(R.id.rb_home);
}
}

简化一下是这样的:使用isAdded方法判断是否添加过;

public class FragmentShowHide2Activity extends AppCompatActivity {

    @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(getContentViewResource());
initView();
initData();
initList();
} private RadioGroup rg;
private Fragment HomeFm = null,SpcFm = null, OrderFm = null, MyFm = null; private final class RgOnCheckedChangeListener implements RadioGroup.OnCheckedChangeListener {
@Override
public void onCheckedChanged(RadioGroup radioGroup, int checkedId) {
switch (checkedId) {
case R.id.rb_home:
switchFragment(showFragment,HomeFm);
break;
case R.id.rb_shoppingcart:
switchFragment(showFragment,SpcFm);
break;
case R.id.rb_orderfrom:
switchFragment(showFragment,OrderFm);
break;
case R.id.rb_my:
switchFragment(showFragment,MyFm);
break;
}
}
} public int getContentViewResource() {
return R.layout.activity_fragment;
} protected void initView() {
rg = findViewById(R.id.rg); } protected void initData() {
HomeFm = new Fragment1();
SpcFm = new Fragment2();
OrderFm = new Fragment3();
MyFm = new Fragment4();
} protected void initList() {
rg.setOnCheckedChangeListener(new RgOnCheckedChangeListener());
rg.check(R.id.rb_home);
} private Fragment showFragment; //当前显示的fragment private void switchFragment(Fragment hide,Fragment show){
FragmentTransaction ft = getSupportFragmentManager().beginTransaction();
if (hide == show)return;
if (hide != null){
if (!show.isAdded()){
ft.hide(hide).add(R.id.fl, show).commit();
}else{
ft.hide(hide).show(show).commit();
}
}else {
if (!show.isAdded()){
ft.add(R.id.fl, show).commit();
}else{
ft.show(show).commit();
}
}
showFragment = show;
}
}

下载Demo:FragmentDemo

github:Github

附:使用show和hide的方式显示Fragment,在Activity回收后重叠的问题;

随意门:https://blog.csdn.net/qq_35605213/article/details/79713871

Fragment与Radiogroup联动,经典的主界面布局。使用show和hide的方式实现;的更多相关文章

  1. 基于easyUI实现经典系统主界面

    此文章是基于 EasyUI+Knockout实现经典表单的查看.编辑 一. 相关文件介绍 1. home.jsp:系统主界面 <!DOCTYPE html PUBLIC "-//W3C ...

  2. android actionbar viewpager 实现类微信主界面布局

    1 Activity public class MainActivity extends FragmentActivity { private ViewPager pager; private Act ...

  3. Swift实战-小QQ(第3章):QQ主界面布局

    1.导航栏外观设定*在AppDelegate.swift文件中的didFinishLaunchingWithOptions方法添加以下代码 func application(application: ...

  4. jquery+easyui主界面布局一例

    <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="workbench.aspx ...

  5. Android学习系列(22)--App主界面比较

    本文算是一篇漫谈,谈一谈当前几个流行应用的主界面布局,找个经典的布局我们自己也来实现一个.不是为了追求到底有多难,而是为了明白我们确实需要这么做. 走个题,android的UI差异化市场依然很大,依然 ...

  6. Android学习系列(23)--App主界面实现

    在上篇文章<Android学习系列(22)--App主界面比较>中我们浅略的分析了几个主界面布局,选了一个最大众化的经典布局.今天我们就这个经典布局,用代码具体的实现它. 1.预览图先看下 ...

  7. 看过《大湿教我写.net通用权限框架(1)之菜单导航篇》之后发生的事(续)——主界面

    引言 在UML系列学习中的小插曲:看过<大湿教我写.net通用权限框架(1)之菜单导航篇>之后发生的事 在上篇中只拿登录界面练练手,不把主界面抠出来,实在难受,严重的强迫症啊.之前一直在总 ...

  8. Android应用经典主界面框架之中的一个:仿QQ (使用Fragment, 附源代码)

    备注:代码已传至https://github.com/yanzi1225627/FragmentProject_QQ 欢迎fork,如今来审视这份代码,非常多地方写的不太好,欢迎大家指正.有时间我会继 ...

  9. Android应用经典主界面框架之二:仿网易新闻client、CSDN client (Fragment ViewPager)

    另外一种主界面风格则是以网易新闻.凤凰新闻以及新推出的新浪博客(阅读版)为代表.使用ViewPager+Fragment,即ViewPager里适配器里放的不是一般的View.而是Fragment.所 ...

随机推荐

  1. [转]Serializable接口与Externalizable接口区别

    被Serializable接口声明的类的对象的内容都将被序列化,如果现在用户希望自己指定序列化的内容,则可以让一个类实现Externalizable接口,此接口定义如下: public interfa ...

  2. webpack 4 升级点

    webpack 4 升级点: 默认entry为./src,默认output为/dist sideEffects 在webapck2开始支持ESModule后,webpack提出了tree-shakin ...

  3. Python random模块sample、randint、shuffle、choice随机函数

    一.random模块简介 Python标准库中的random函数,可以生成随机浮点数.整数.字符串,甚至帮助你随机选择列表序列中的一个元素,打乱一组数据等. 二.random模块重要函数 1 ).ra ...

  4. nginx下js文件修改后访问不更新问题解决

    今天遇到一个问题,nginx下js修改后不更新,加版本号,刷新浏览器缓存都不行,重启服务器才行,修改后又不更新了而且加载的js文件会有乱码或者文件加载不全的问题. 解决办法:修改nginx.conf, ...

  5. 代码阅读笔记:【C-COT】

    [C-COT]:Danelljan M, Robinson A, Khan F S, et al. Beyond correlation filters: Learning continuous co ...

  6. Spring Boot 配置详解

    Spring Boot 针对常用的开发场景提供了一系列自动化配置来减少原本复杂而又几乎很少改动的模板配置内容,但是,我们还是需要了解如何在Spring Boot中修改这些自动化的配置,以应对一些特殊场 ...

  7. Star Schema and Snowflake Schema

    在设计数据仓库模型的时候,最常见的两种是星型模型与雪花模型.选择哪一种需要根据业务需求以及性能的多重考量来定. 星型模型 在星型模型当中,一张事实表被若干张维度表所包围.每一个维度代表了一张表,有主键 ...

  8. GetClass与RegisterClass的应用一例

    利用GetClass与RegisterClass可以实现根据字符串来实例化具体的子类,这对于某些需要动态配置程序的场合是很有用的.其他的应用如子窗体切换,算法替换等都能得到应用. unit Examp ...

  9. Linux/Centos下安装部署phantomjs 及使用

    PhantomJS 是一个基于 WebKit 的服务器端 JavaScript API.它全面支持web而不需浏览器支持,其快速,原生支持各种Web标准: DOM 处理, CSS 选择器, JSON, ...

  10. WCF 基础连接已经关闭: 服务器关闭了本应保持活动状态的连接。

    详细错误信息: System.ServiceModel.CommunicationException: 接收对 http://localhost:48655/XXXXXX.svc 的 HTTP 响应时 ...