电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Android自定義選項卡切換效果

瀏覽:6日期:2022-09-18 09:30:57

本文實例為大家分享了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'> <TextViewandroid: 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'/> <TextViewandroid: 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: 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: android:color='#328BDD' /> <corners android:radius='3dp' /> <solid android:color='#328BDD' /></shape> </item> <item><shape android:shape='rectangle'> <stroke android: 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);} } /** * TAB切換時的listener */ 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() {@Overridepublic 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(); } } } ...}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Android
相關文章:
主站蜘蛛池模板: 常州减速机_减速机厂家_常州市减速机厂有限公司 | 3d打印服务,3d打印汽车,三维扫描,硅胶复模,手板,快速模具,深圳市精速三维打印科技有限公司 | 广州展览设计公司_展台设计搭建_展位设计装修公司-众派展览装饰 广州展览制作工厂—[优简]直营展台制作工厂_展会搭建资质齐全 | 网站建设-网站制作-网站设计-网站开发定制公司-网站SEO优化推广-咏熠软件 | 包装设计公司,产品包装设计|包装制作,包装盒定制厂家-汇包装【官方网站】 | 专业的压球机生产线及解决方案厂家-河南腾达机械厂 | 高防护蠕动泵-多通道灌装系统-高防护蠕动泵-www.bjhuiyufluid.com慧宇伟业(北京)流体设备有限公司 | 亮化工程,亮化设计,城市亮化工程,亮化资质合作,长沙亮化照明,杰奥思【官网】 | 物流公司电话|附近物流公司电话上门取货| 广州活动策划公司-15+年专业大型公关活动策划执行管理经验-睿阳广告 | HDPE储罐_厂家-山东九州阿丽贝防腐设备| 台湾Apex减速机_APEX行星减速机_台湾精锐减速机厂家代理【现货】-杭州摩森机电 | 碳刷_刷握_集电环_恒压簧_电刷厂家-上海丹臻机电科技有限公司 | 活性氧化铝|无烟煤滤料|活性氧化铝厂家|锰砂滤料厂家-河南新泰净水材料有限公司 | 不锈钢水箱厂家,不锈钢保温水箱-山东桑特供水设备 | 翅片管散热器价格_钢制暖气片报价_钢制板式散热器厂家「河北冀春暖气片有限公司」 | 磁棒电感生产厂家-电感器厂家-电感定制-贴片功率电感供应商-棒形电感生产厂家-苏州谷景电子有限公司 | 机械立体车库租赁_立体停车设备出租_智能停车场厂家_春华起重 | 武汉刮刮奖_刮刮卡印刷厂_为企业提供门票印刷_武汉合格证印刷_现金劵代金券印刷制作 - 武汉泽雅印刷有限公司 | 视频教程导航网_视频教程之家_视频教程大全_最新视频教程分享发布平台 | 成都治疗尖锐湿疣比较好的医院-成都治疗尖锐湿疣那家医院好-成都西南皮肤病医院 | 韦伯电梯有限公司| 刹车盘机床-刹车盘生产线-龙口亨嘉智能装备 | 氧化锆纤维_1800度高温退火炉_1800度高温烧结炉-南京理工宇龙新材料股份有限公司 | 成都离婚律师|成都结婚律师|成都离婚财产分割律师|成都律师-成都离婚律师网 | 铸铝门厂家,别墅大门庭院大门,别墅铸铝门铜门[十大品牌厂家]军强门业 | CCC验厂-家用电器|服务器CCC认证咨询-奥测世纪 | 沈阳缠绕膜价格_沈阳拉伸膜厂家_沈阳缠绕膜厂家直销 | 塑钢件_塑钢门窗配件_塑钢配件厂家-文安县启泰金属制品有限公司 深圳南财多媒体有限公司介绍 | 优秀的临床医学知识库,临床知识库,医疗知识库,满足电子病历四级要求,免费试用 | 截齿|煤截齿|采煤机截齿|掘进机截齿|旋挖截齿-山东卓力截齿厂家报价 | 游戏版号转让_游戏资质出售_游戏公司转让-【八九买卖网】 | 承插管件_不锈钢承插管件_锻钢高压管件-温州科正阀门管件有限公司 | 滚珠丝杆升降机_螺旋升降机_丝杠升降机-德迈传动 | 不锈钢法兰-碳钢法兰-法兰盘生产加工厂家-[鼎捷峰]-不锈钢法兰-碳钢法兰-法兰盘生产加工厂家-[鼎捷峰] | 中矗模型-深圳中矗模型设计有限公司| 新能源汽车电池软连接,铜铝复合膜柔性连接,电力母排-容发智能科技(无锡)有限公司 | 工业胀紧套_万向节联轴器_链条-规格齐全-型号选购-非标订做-厂家批发价格-上海乙谛精密机械有限公司 | 布袋式除尘器|木工除尘器|螺旋输送机|斗式提升机|刮板输送机|除尘器配件-泊头市德佳环保设备 | 12cr1mov无缝钢管切割-15crmog无缝钢管切割-40cr无缝钢管切割-42crmo无缝钢管切割-Q345B无缝钢管切割-45#无缝钢管切割 - 聊城宽达钢管有限公司 | 南京泽朗生物科技有限公司 |