RadioButton使用(一)实现底部带指示条的Tab选项卡

本文介绍了如何使用RadioButton替代ViewPager实现底部带指示条的Tab选项卡。通过RadioButton的互斥特性,实现简洁的代码和清晰的逻辑。示例代码包括XML布局和Fragment,展示了一个可扩展到多个选项卡的解决方案。
摘要由CSDN通过智能技术生成

在对之前的项目中做重构时候发现一个界面的tab选项卡,之前一直 用着看是不能滑动的,但是在代码中发现是用viewpager实现的后面强制把滑动给禁掉了,代码显示有点多也很乱。既然问了领导需求没有滑动只能点击,那么就没有必要再用viewpager去实现了。重构后采用RadioButton,主要利用RadioButton的“互斥”特性实现这样代码量少,逻辑清晰,也便于其他开发阅读理解。
由于这个demo是直接临时从项目中抽出来的,所以稍微有点乱,不过代码量不多,有需要的可以自己回头再整理下,废话不多说看看最后实现的效果图:
这里写图片描述

直接上代码

package com.radiobuttontab;

import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentTransaction;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.DisplayMetrics;
import android.view.View;
import android.widget.FrameLayout;
import android.widget.RadioButton;

/**
 * Created by nanfeilong on 2017/8/6
 * RadioButton 选项卡
 */
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
   


    private RadioButton tab1, tab2, tab3;
    private View mViewPagerLine;//选项卡下面的红色线条控件
    private Fragment1 fragment1;
    private Fragment2 fragment2;
    private Fragment3 fragment3;
    private int width;
    private FrameLayout.LayoutParams params;
    private DisplayMetrics metric;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        tab1 = (RadioButton) findViewById(R.id.tab1);
        tab2 = (RadioButton)findViewById(R.id.tab2);
        tab3 = (RadioButton) findViewById(R.id.tab3);
        mViewPagerLine = findViewById(R.id.imformation_viewpager_line);//选项卡下面的红色线条
        params = (android.widget.FrameLayout.LayoutParams) mViewPagerLine.getLayoutParams();
        initFragment();
    }

    private void initFragment() {
        fragment1 = new Fragment1();
        fragment2 = new Fragment2();
        fragment3 = new Fragment3();
        width=getScreenWidth()/3;
        setMetric();
        tab1.setOnClickListener(this);
        tab2.setOnClickListener(this);
        tab3.setOnClickListener(this);
    }

    /**
     * 初始选项卡红色线条位置
     */
    private void setMetric() {
            tab1.setChecked(true);
            selectedTab(0);
    }
    /**
     * 切换fragment
     *
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值