我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android自定义选项卡切换效果

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android自定义选项卡切换效果

本文实例为大家分享了Android自定义选项卡切换效果的具体代码,供大家参考,具体内容如下

一、实际使用的效果

二、自定义可切换的标题栏

1、布局


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="232dp"
    android:layout_height="32dp"
    android:background="@drawable/leave_back_tab_bg_selector"
    android:orientation="horizontal">
    <TextView
        android:id="@+id/tvLeaveNum"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@drawable/leave_back_button_bg_selector"
        android:gravity="center"
        android:layout_weight="1"
        android:textColor="@color/white"
        android:textSize="14sp"
        android:clickable="true"
        android:focusable="true"
        android:focusableInTouchMode="true"
        android:text="@string/leave_crews_num"/>

    <TextView
        android:id="@+id/tvBackNum"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@drawable/leave_back_button_bg_selector"
        android:gravity="center"
        android:layout_weight="1"
        android:textColor="@color/white"
        android:textSize="14sp"
        android:clickable="true"
        android:focusable="true"
        android:focusableInTouchMode="true"
        android:text="@string/back_crews_num"/>
</LinearLayout>

leave_back_button_bg_selector:


<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
        <shape android:shape="rectangle">
            <stroke android:width="1dp" android:color="#328BDD" />
            <corners android:radius="3dp" />
            <solid android:color="@color/transparent" />
        </shape>
    </item>
</selector>

leave_back_button_bg_selector


<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:state_focused="true">
        <shape android:shape="rectangle">
            <stroke android:width="1dp" android:color="#328BDD" />
            <corners android:radius="3dp" />
            <solid android:color="#328BDD" />
        </shape>
    </item>

    <item>
        <shape android:shape="rectangle">
            <stroke android:width="1dp" android:color="@color/transparent" />
            <corners android:radius="3dp" />
            <solid android:color="@color/transparent" />
        </shape>
    </item>
</selector>

2、控件封装


import android.content.Context;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.TextView;

import butterknife.BindView;
import butterknife.ButterKnife;
import butterknife.OnFocusChange;

public class LeaveBackTitleTabView extends LinearLayout {

    public final static int INDEX_LEAVE = 1;
    public final static int INDEX_BACK = 2;

    @BindView(R.id.tvBackNum)
    TextView tvBackNum;
    @BindView(R.id.tvLeaveNum)
    TextView tvLeaveNum;
    private Context mContext;

    private ITabChangeListener tabChangeListener;

    public void setTabChangeListener(ITabChangeListener tabChangeListener) {
        this.tabChangeListener = tabChangeListener;
    }

    public LeaveBackTitleTabView(Context context) {
        super(context);
        mContext = context;
    }

    public LeaveBackTitleTabView(Context context, AttributeSet attrs) {
        super(context, attrs);
        mContext = context;
        View view = (View) LayoutInflater.from(context).inflate(R.layout.view_leave_back_list_tab, this, true);
        ButterKnife.bind(view);
    }

    @OnFocusChange({R.id.tvLeaveNum,R.id.tvBackNum})
    public void doFocusChanged(View view){
        switch(view.getId()){
            case R.id.tvLeaveNum :
                if(tabChangeListener != null){
                    tabChangeListener.onTabChanged(INDEX_LEAVE);
                }
                break;
            case R.id.tvBackNum:
                if(tabChangeListener != null){
                    tabChangeListener.onTabChanged(INDEX_BACK);
                }
                break;
        }
    }

    public void setCrewsNum(int leaveNum,int backNum){
        tvLeaveNum.setText(String.format(getResources().getString(R.string.leave_crews_num), String.valueOf(leaveNum)));
        tvBackNum.setText(String.format(getResources().getString(R.string.back_crews_num), String.valueOf(backNum)));

        if(leaveNum > 0 && backNum > 0){
            tvLeaveNum.requestFocus();
        }else if(leaveNum > 0 && backNum == 0){
            tvLeaveNum.setClickable(true);
            tvLeaveNum.setFocusable(true);
            tvBackNum.setClickable(false);
            tvBackNum.setFocusable(false);
            tvLeaveNum.requestFocus();
        }else if(leaveNum == 0 && backNum > 0){
            tvLeaveNum.setClickable(false);
            tvLeaveNum.setFocusable(false);
            tvBackNum.setClickable(true);
            tvBackNum.setFocusable(true);
            tvBackNum.requestFocus();
        }else{
            tvLeaveNum.setClickable(false);
            tvLeaveNum.setFocusable(false);
            tvBackNum.setClickable(false);
            tvBackNum.setFocusable(false);
        }
    }

    
    public interface ITabChangeListener{
        public void onTabChanged(int index);
    }
}

3、使用方法


<com.hisign.ship_terminal_hs518.view.LeaveBackTitleTabView
      android:layout_width="232dp"
      android:layout_height="32dp"
      android:layout_marginTop="10dp"
      android:visibility="gone"
      android:id="@+id/lttTitle">
</com.hisign.ship_terminal_hs518.view.LeaveBackTitleTabView>

4、注册回调事件(一般在UI界面上进行注册)


 
    private LeaveBackTitleTabView.ITabChangeListener iTabChangeListener = new LeaveBackTitleTabView.ITabChangeListener() {
        @Override
        public void onTabChanged(int index) {
            switch (index) {
                case LeaveBackTitleTabView.INDEX_LEAVE:
                    // 界面上点击了离船
                    ll_leave_crews.setVisibility(View.VISIBLE);
                    ll_back_crews.setVisibility(View.GONE);
                    break;
                case LeaveBackTitleTabView.INDEX_BACK:
                    // 界面上点击了在船
                    ll_back_crews.setVisibility(View.VISIBLE);
                    ll_leave_crews.setVisibility(View.GONE);
                    break;
            }
        }
    };

5、注意事项:

(1)、控件需要能响应点击事件,同时切换到某一选项时,该选项卡需要显示选中的状态,所以在控件中需要指定:


android:clickable="true"
    android:focusable="true"
    android:focusableInTouchMode="true"

但是这样设置了之后,控件就在点击时就不能在点击的第一下响应onClick点击事件,我的做法是响应onFouceChange事件

(2)、为啥这样设置,在点击的第一下就不响应onClick了呢?源码中显示w 在 onTouchEvent() 中的 MotionEvent.ACTION_UP 中对focus做了处理, 如果View focusableInTouchMode 是true, 并且当前没有获得焦点, 那么会尝试获取焦点, 并且不会调用 performClick()。


public boolean onTouchEvent(MotionEvent event) {
  ...
 if (((viewFlags & CLICKABLE) == CLICKABLE ||
         (viewFlags & LONG_CLICKABLE) == LONG_CLICKABLE) ||
         (viewFlags & CONTEXT_CLICKABLE) == CONTEXT_CLICKABLE) {
     switch (action) {
         case MotionEvent.ACTION_UP:
             boolean prepressed = (mPrivateFlags & PFLAG_PREPRESSED) != 0;
             if ((mPrivateFlags & PFLAG_PRESSED) != 0 || prepressed) {
                 boolean focusTaken = false;
                 if (isFocusable() && isFocusableInTouchMode() && !isFocused()) {
                     focusTaken = requestFocus();
                 }

                 if (prepressed) {
                     setPressed(true, x, y);
                }

                 if (!mHasPerformedLongPress && !mIgnoreNextUpEvent) {
                     removeLongPressCallback();
 
                     if (!focusTaken) {
                         if (mPerformClick == null) {
                             mPerformClick = new PerformClick();
                         }
                         if (!post(mPerformClick)) {
                             performClick();
                         }
                     }
                 }
 
 ...
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android自定义选项卡切换效果

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android多个TAB选项卡切换效果

在前一期中,我们做了悬浮头部的两个tab切换和下拉刷新效果,后来项目中要求改成三个tab,当时就能估量了一下,如果从之前的改,也不是不可以,但是要互相记住的状态就太多了,很容易出现错误。就决定重新实现一下这个效果,为此先写了一个demo,这
2022-06-06

jquery选项卡切换效果怎么实现

要实现jQuery选项卡切换效果,可以按照以下步骤进行操作:1. 创建HTML结构,使用`ul`和`li`元素创建选项卡的导航栏,使用`div`元素创建选项卡的内容区域,给导航栏的每个`li`元素添加一个唯一的`data-tab`属性,用于
2023-08-15

JS怎么实现选项卡切换效果

这篇文章主要为大家展示了“JS怎么实现选项卡切换效果”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JS怎么实现选项卡切换效果”这篇文章吧。相关代码:
2023-06-27

Android仿微信底部实现Tab选项卡切换效果

在网上看了比较多的关于Tab的教程,发现都很杂乱。比较多的用法是用TitlePagerTabStrip和ViewPaper。不过TitlePagerTabStrip有个很大的缺陷,Tab里面的内容刚进去是没有的,要滑一次才能加载出来。而且滑
2022-06-06

Android组件TabHost实现页面中多个选项卡切换效果

TabHost组件可以在界面中存放多个选项卡, 很多软件都使用了改组件进行设计。 一、基础知识 TabWidget : 该组件就是TabHost标签页中上部 或者 下部的按钮, 可以点击按钮切换选项卡; TabSpec : 代表了选项卡界面
2022-06-06

Android自定义ViewPager实现个性化的图片切换效果

第一次见到ViewPager这个控件,瞬间爱不释手,做东西的主界面通通ViewPager,以及图片切换也抛弃了ImageSwitch之类的,开始让ViewPager来做。时间长了,ViewPager的切换效果觉得枯燥,形成了审美疲劳~~我们
2022-06-06

Android自定义wheelview随机选号效果

先看下利用wheelview实现滚动随机选择号码效果:直接上代码 首页就是dialog显示不在描述 主要看dialog代码package com.yskj.jh.wheeldemo; import android.app.Dialog;
2022-06-06

Android自定义TabLayout效果

周末就要到了,今天项目中遇到这样一个Tab,选中tab的背景是个圆角矩形,方向指向器没有了,这样普通的TabLayout不能满足我的要求,可能会想到动态的去设置选中Tab的背景不就可以了,但是那样的话太生硬了,没有动画效果,其实想想也还比较
2022-06-06

Android自定义日历效果

要实现Android自定义日历效果,可以按照以下步骤进行:1. 创建一个自定义的CalendarView控件,继承自ViewGroup或者继承自现有的控件(如LinearLayout)。2. 在自定义的CalendarView中,处理用户的
2023-08-15

怎么用vue动态组件实现选项卡切换效果

这篇文章主要讲解了“怎么用vue动态组件实现选项卡切换效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用vue动态组件实现选项卡切换效果”吧!导航按钮:
2023-07-04

vue怎么使用动态组件实现选项卡切换效果

本文小编为大家详细介绍“vue怎么使用动态组件实现选项卡切换效果”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue怎么使用动态组件实现选项卡切换效果”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。导航按钮:
2023-07-04

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录