【1-100】RadioGroup实现应用主界面「建议收藏」

【1-100】RadioGroup实现应用主界面

大家好,又见面了,我是全栈君。

首先,我们先来创建主界面的布局文件

<?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"
                android:orientation="vertical">
    <FrameLayout
        android:id="@+id/fragment_container"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_above="@+id/group_tab"/>
    <RadioGroup
        android:id="@+id/group_tab"
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:layout_alignParentBottom="true"
        android:background="#FBFBFB"
        android:orientation="horizontal">
        
        <RadioButton
            android:id="@+id/rb_watch"
            style="@style/main_tab_style"
            android:drawableTop="@drawable/select_tab_watch"
            android:text="高速全览"/>
            
            .......省略
            
        <RadioButton
            android:id="@+id/rb_event"
            style="@style/main_tab_style"
            android:checked="true"
            android:drawableTop="@drawable/select_tab_event"
            android:text="事件管理"/>
    </RadioGroup>
</RelativeLayout>

可以看到,我们将最后一个先设置为选中状态,在Activity中再进行状态的切换

四个RadioButton的属性大多都是一样的,所以抽取到styles

<style name="main_tab_style">
        <item name="android:layout_width">0dp</item>
        <item name="android:layout_height">match_parent</item>
        <item name="android:layout_weight">1</item>
        <item name="android:button">@null</item>
        <item name="android:textSize">12sp</item>
        <item name="android:textColor">@drawable/select_tab_text_color</item>
        <item name="android:layout_marginTop">5dp</item>
        <item name="android:drawablePadding">3dp</item>
        <item name="android:gravity">center</item>
    </style>

还有drawableToptext相应的Seletor
select_tab_bus.xml
这里只列出了一个,其他三个只是图片不同就不列出来了

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@drawable/tab_bus_pre" android:state_pressed="false" android:state_selected="true" />
    <item android:drawable="@drawable/tab_bus_pre" android:state_checked="true" android:state_pressed="false" />
    <item android:drawable="@drawable/tab_bus_nomal" />
</selector>

select_tab_text_color.xml

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checked="true" android:color="#2e9ed0"/>
    <!-- not selected -->
    <item android:state_checked="false" android:color="#B2B2B2"/>
</selector>

到这里我们的布局就准备好了,接下来开始编写Fragment与Activity的代码。

fragment代码很简单,如下,

public class MainExpresswayWatchFragment extends Fragment {
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
         Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment_common, container, false);
        TextView tvContent = (TextView) view.findViewById(R.id.tv_content);
        tvContent.setText("高速全览");
        return view;
    }

    @Override
    public void setMenuVisibility(boolean menuVisible) {
        super.setMenuVisibility(menuVisible);
        // 每个Fragment都需要实现`setMenuVisibility`来控制视图,
        // 当Fragment不可见的时候,需要隐藏相应的视图,不然会使界面重叠在一起。
        if (this.getView() != null) {
            this.getView().setVisibility(menuVisible ? View.VISIBLE : View.GONE);
        }
    }
}

接下来是Activity的代码,关键代码都有注释,我就不多说了…

public class MainActivity extends AppCompatActivity implements RadioGroup.OnCheckedChangeListener {
    private RadioGroup radioGroup;
    private FrameLayout fragmentContainer;

    // 是否第一次进入主界面
    private boolean isFirstEnter = true;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_radio_group_main);
        radioGroup = (RadioGroup) findViewById(R.id.group_tab);
        fragmentContainer = (FrameLayout) findViewById(R.id.fragment_container);

        radioGroup.setOnCheckedChangeListener(this);
    }

    @Override
    protected void onStart() {
        super.onStart();
        if (isFirstEnter) {
            isFirstEnter = false;
            // 准备显示界面的时候切换第一个RadioButton为选中状态
            radioGroup.check(R.id.rb_watch);
        }
    }

    @Override
    public void onCheckedChanged(RadioGroup radioGroup, int i) {
        int index = 0;
        switch (i) {
            case R.id.rb_watch:
                index = 0;
                break;
            case R.id.rb_bus_danger:
                index = 1;
                break;
            case R.id.rb_car:
                index = 2;
                break;
            case R.id.rb_event:
                index = 3;
                break;
        }
        // 从FragmentManager中查找Fragment,找不到就使用getItem获取
        Fragment fragment = (Fragment) fragments.instantiateItem(fragmentContainer, index);
        // 设置显示第一个Fragment
        fragments.setPrimaryItem(fragmentContainer, 0, fragment);
        // 提交事务
        fragments.finishUpdate(fragmentContainer);
    }

    // 使用FragmentStatePagerAdapter管理Fragment
    FragmentStatePagerAdapter fragments = new FragmentStatePagerAdapter(getSupportFragmentManager()) {
        @Override
        public Fragment getItem(int position) {
            Fragment fragment = null;
            switch (position) {
                case 0:
                    fragment = new MainExpresswayWatchFragment();
                    break;
                case 1:
                    fragment = new MainBusDangerFragment();
                    break;
                case 2:
                    fragment = new MainCarManageFragment();
                    break;
                case 3:
                    fragment = new MainEventDangerFragment();
                    break;
            }
            return fragment;
        }

        @Override
        public int getCount() {
            return 4;
        }
    };
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/108869.html原文链接:https://javaforall.net

(0)
上一篇 2022年2月21日 下午12:00
下一篇 2022年2月21日 下午1:00


相关推荐

  • STM32移植uIP

    STM32移植uIP文件说明 这是 uIP1 0 源码文件 apps 是作者写好的应用程序 demo doc 是一些文档 lib 里面只有一个文件是内存申请与释放函数的接口 uip 是 tcp ip 的协议栈了 unix 是与外部的接口 我们移植也主要去改这些文件 说一下一眼看不出作用的文件 lc h lc addrlabels h lc switch h psock c ps

    2026年3月26日
    2
  • java对象数组 创建对象数组,初始化对象数组「建议收藏」

    java对象数组 创建对象数组,初始化对象数组「建议收藏」对象数组的概念:如果一个数组中的元素是对象类型,则称该数组为对象数组。当需要一个类的多个对象时,应该用该类的对象数组来表示,通过改变下标值就可以访问到不同的对象。对象数组的定义和使用:对象数组的定义与一般数组的定义类似,但是需要为每一个元素实例化。对象数组的声明形式是:类名对象数组名[];为对象数组分配内存空间:对象数组名=new类名[数组长度];//注意:此处不是构…

    2022年5月20日
    48
  • 前端js面试题(基础)「建议收藏」

    前端js面试题(基础)「建议收藏」1、js中使用typeof能得到哪些类型?——undefined、string、number、boolean、object、function2、===和==分别在何时使用?//==的使用情况为以下2种(其他情况下推荐使用===)if(obj.a==null){ //相当于obj.a===null||obj.a===undefined}functionfn(a,b){ i…

    2022年8月26日
    7
  • c++runtime_c=2πr

    c++runtime_c=2πr转自:https://blog.csdn.net/BlackRose2013/article/details/7670820用fstream在指定文件流模式的情况下也可以自动新建文件:fstreamoo(“aa.txt”,ofstream::out);在C++中,有一个stream这个类,所有的I/O都以这个“流”类为基础的,包括我们要认识的文件I/O,stream这个类有两个重要的运算符…

    2025年11月28日
    7
  • Linux下配置DNS服务

    Linux下配置DNS服务一 DNS 服务简介 DNS 服务器 也称为域名解析服务器 是用来将互联网上的域名解析为 IP 地址的一类服务器 在世界上有成百上千台 DNS 服务器 对于有些公司来说 对于同一个域名可能有多个 DNS 服务器 这样可以降低主域名服务器的负载 例如 baidu com 可能会存在多个 DNS 服务器 因为在同一时刻可能有成百上千台主机同时请求 baidu com 这个域名 如果只有一台 DNS

    2026年3月19日
    3
  • oracle创建索引和删除索引

    oracle创建索引和删除索引创建CREATEINDEXindex_Trans_list(索引名)ONTrans_list(表名) (receivedepid(字段名))删除dropindexindex_Trans_list(索引名)

    2025年9月14日
    15

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号