android TAB切换

有一些场景需要左右两个按钮tab实现切换的布局,如图:

类似这样的布局

这种只是在xml中实现的简单布局,没有切换时的动画效果,

1、Xml的简单代码

XML 复制代码
      <RelativeLayout
                android:layout_width="match_parent"
                android:layout_height="49dp"
                android:background="@drawable/bg_deal_channel_onchain">


                <LinearLayout
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:layout_centerVertical="true"

                    android:orientation="horizontal">

                    <View
                        android:layout_width="0dp"
                        android:layout_height="match_parent"
                        android:layout_weight="1" />

                    <View
                        android:layout_width="0dp"
                        android:layout_height="match_parent"
                        android:layout_weight="1" />
                </LinearLayout>


                <LinearLayout
                    android:id="@+id/bg_channel_selected"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:layout_centerVertical="true"
                    android:background="@mipmap/bg_left"
                    android:orientation="horizontal"
                    android:visibility="visible" />


                <LinearLayout
                    android:id="@+id/bg_chain_selected"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:layout_centerVertical="true"
                    android:background="@mipmap/bg_right"
                    android:orientation="horizontal"
                    android:visibility="gone" />


                <LinearLayout
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:layout_centerVertical="true"

                    android:orientation="horizontal">


                    <LinearLayout
                        android:id="@+id/ll_channel_mode"
                        android:layout_width="0dp"
                        android:layout_height="match_parent"
                        android:layout_weight="1"
                        android:background="@android:color/transparent"
                        android:gravity="center"
                        android:onClick="onModeSwitchClick">

                        <TextView
                            android:id="@+id/tv_channel_mode"
                            android:layout_width="wrap_content"
                            android:layout_height="wrap_content"
                            android:text="通道"
                            android:textColor="@color/white"
                            android:textSize="15sp"
                            android:textStyle="bold" />
                    </LinearLayout>


                    <LinearLayout
                        android:id="@+id/ll_chain_mode"
                        android:layout_width="0dp"
                        android:layout_height="match_parent"
                        android:layout_weight="1"
                        android:background="@android:color/transparent"
                        android:gravity="center"
                        android:onClick="onModeSwitchClick">

                        <TextView
                            android:id="@+id/tv_chain_mode"
                            android:layout_width="wrap_content"
                            android:layout_height="wrap_content"
                            android:text="链上"
                            android:textColor="@color/black"
                            android:textSize="15sp"
                            android:textStyle="bold" />
                    </LinearLayout>

                </LinearLayout>

            </RelativeLayout>

资源文件bg_deal_channel_onchain

XML 复制代码
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <solid android:color="@color/white" />
    <corners
        android:topRightRadius="20dp"
        android:topLeftRadius="20dp" />
    <stroke
        android:width="1dp"
        android:color="@color/white" />
</shape>

java代码

点击第二个按钮

java 复制代码
public void switchToChainMode() {
        tab_onchain.setVisibility(View.VISIBLE);

        if (currentMode == 2) return;

        AlphaAnimation fadeOut = new AlphaAnimation(1.0f, 0.0f);
        fadeOut.setDuration(150);
        fadeOut.setAnimationListener(new Animation.AnimationListener() {
            @Override
            public void onAnimationStart(Animation animation) {}

            @Override
            public void onAnimationEnd(Animation animation) {
                bgChannelSelected.setVisibility(View.GONE);
                bgChainSelected.setVisibility(View.VISIBLE);
                AlphaAnimation fadeIn = new AlphaAnimation(0.0f, 1.0f);
                fadeIn.setDuration(150);
                bgChainSelected.startAnimation(fadeIn);
            }

            @Override
            public void onAnimationRepeat(Animation animation) {}
        });
        bgChannelSelected.startAnimation(fadeOut);
        AnimatorUtil.animateButtonPress(llChainMode);
        AnimatorUtil.animateTextTransition(this,tvChannelMode, tvChainMode, false);

        currentMode = 2;
    }

点击第一个按钮

java 复制代码
public void switchToChannelMode() {
     
        tab_onchain.setVisibility(View.GONE);
        if (currentMode == 1) return;

        AlphaAnimation fadeOut = new AlphaAnimation(1.0f, 0.0f);
        fadeOut.setDuration(150);
        fadeOut.setAnimationListener(new Animation.AnimationListener() {
            @Override
            public void onAnimationStart(Animation animation) {}

            @Override
            public void onAnimationEnd(Animation animation) {
                bgChainSelected.setVisibility(View.GONE);
                bgChannelSelected.setVisibility(View.VISIBLE);
                AlphaAnimation fadeIn = new AlphaAnimation(0.0f, 1.0f);
                fadeIn.setDuration(150);
                bgChannelSelected.startAnimation(fadeIn);
            }

            @Override
            public void onAnimationRepeat(Animation animation) {}
        });
        bgChainSelected.startAnimation(fadeOut);
        AnimatorUtil.animateButtonPress(llChainMode);
        AnimatorUtil.animateTextTransition(this,tvChannelMode, tvChainMode, true);

        currentMode = 1;
    }

2、其中动画可根据具体需求实现。

-END

相关推荐
效能革命笔记36 分钟前
国内首家|Gitee Repo 通过信通院「先进级」认证:企业级制品库核心能力与选型指南
gitee
Android小码家2 小时前
Framework之Launcher小窗开发
android·framework·虚拟屏·小窗
赏金术士2 小时前
第七章:状态管理实战与架构总结
android·ui·kotlin·compose
颂love3 小时前
MySQL的执行流程
android·数据库·mysql
云起SAAS7 小时前
抖音小游戏源码 - 消消乐 | 含激励广告+成就系统 | 开箱即用商业级消除游戏模板
android·游戏·广告联盟·看激励广告联盟流量主·抖音小游戏源码 - 消消乐
大貔貅喝啤酒9 小时前
基于Windows下载安装Android Studio 3.3.2版本教程(2026详细图文版)
android·java·windows·android studio
程序员码歌9 小时前
OpenSpec 到 Superpowers:AI 编码从说清到做对
android·前端·人工智能
2501_915106329 小时前
深入解析无源码iOS加固原理与方案,保护应用安全
android·安全·ios·小程序·uni-app·cocoa·iphone
我叫张小白。12 小时前
PyCharm 集成 Git 与 Gitee
git·pycharm·gitee
黄林晴13 小时前
重磅官宣:Android UI 开发正式进入 Compose-first 时代
android·google io