完整项目下载

背景:项目中使用标题栏,只是简单的include一个标题栏的视图,赋值、控制元素显示、点击事件都要自己搞,不优雅!

要求:

1:对现有代码入侵最小

2:使用足够简单

OK,围绕着这个需求,咱做了一个标准的标题栏。中间有文本,左右两边可以是文字或者是图片。

显示标题栏和左侧文字的调用方式如下:

 <zhexian.app.myapplication.ActionBarLeftRightButton
android:layout_width="match_parent"
android:layout_height="50dp"
app:titleLeftImage="@mipmap/arrow_back"
app:titleRightText="提交"
app:titleText="当春乃发生"/>

后台事件呢:控制元素隐藏,设置点击事件?

答案是一句都没有。66666666

怎么实现的?

咱设置了一个Style,文字优先级比图片高。你设置哪个属性,哪个属性对应的控件就会显示。

本控件会判断载体Context是否实现了click事件,如果是,自动给显示的控件加上OnClick事件。

 <declare-styleable name="ActionBarLeftRightButton">
<attr name="titleLeftText" format="string"/>
<attr name="titleLeftImage" format="reference"/>
<attr name="titleText" format="string"/>
<attr name="titleRightText" format="string"/>
<attr name="titleRightImage" format="reference"/>
</declare-styleable>

所以后台你要做的全部,就是在OnClick事件里面写对应ID的实现就好了。

实际用下来之后,体验比以前好多了,优雅~

核心代码如下:

package zhexian.app.myapplication;

import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.drawable.Drawable;
import android.text.TextUtils;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.ImageButton;
import android.widget.RelativeLayout;
import android.widget.TextView; /**
* 标题栏,左右有按钮,图片或者文字都可以
* 优先文字、其次图片,两者都没有的话则不显示
* 参考属性R.styleable.ActionBarLeftRightButton
* Created by 陈俊杰 on 2015/12/8.
*/
public class ActionBarLeftRightButton extends RelativeLayout {
public ActionBarLeftRightButton(Context context) {
this(context, null, 0);
} public ActionBarLeftRightButton(Context context, AttributeSet attrs) {
this(context, attrs, 0);
} public ActionBarLeftRightButton(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
initView(context, attrs);
} /**
* 如果需要对具体的某个元素进行单独操作,可以用本函数获得该对象的引用
*
* @param id
* @param <T>
* @return
*/
public <T> T getView(int id) {
return (T) findViewById(id);
} /**
* 初始化,需要Context实现了OnClickListener
*
* @param context
* @param attrs
*/
void initView(Context context, AttributeSet attrs) {
View view = LayoutInflater.from(context).inflate(R.layout.view_actionbar_left_right_btn, this, true);
setBackgroundResource(R.color.orange);
TypedArray attrArray = context.obtainStyledAttributes(attrs, R.styleable.ActionBarLeftRightButton); boolean isHolderCanClick = context instanceof OnClickListener;
OnClickListener onClickListener = isHolderCanClick ? (OnClickListener) context : null; bindNavigateAction(view, true, attrArray, onClickListener);
bindNavigateAction(view, false, attrArray, onClickListener); String titleText = attrArray.getString(R.styleable.ActionBarLeftRightButton_titleText); if (!TextUtils.isEmpty(titleText))
bindTextView((TextView) view.findViewById(R.id.title_text), titleText, onClickListener); attrArray.recycle();
} /**
* 绑定左边或者右边的按钮、文字
*
* @param view
* @param isLeft
* @param attrArray
* @param onClickListener
*/
void bindNavigateAction(View view, boolean isLeft, TypedArray attrArray, OnClickListener onClickListener) {
String leftText = attrArray.getString(isLeft ? R.styleable.ActionBarLeftRightButton_titleLeftText : R.styleable.ActionBarLeftRightButton_titleRightText); if (!TextUtils.isEmpty(leftText)) {
bindTextView(view, leftText, isLeft, onClickListener); } else {
Drawable leftImage = attrArray.getDrawable(isLeft ? R.styleable.ActionBarLeftRightButton_titleLeftImage : R.styleable.ActionBarLeftRightButton_titleRightImage); if (leftImage != null)
bindImageView(view, leftImage, isLeft, onClickListener);
}
} void bindTextView(View view, String text, boolean isLeft, OnClickListener onClickListener) {
bindTextView((TextView) view.findViewById(isLeft ? R.id.title_left_text : R.id.title_right_text), text, onClickListener);
} /**
* 绑定文本
*
* @param textView
* @param text
* @param onClickListener
*/
void bindTextView(TextView textView, String text, OnClickListener onClickListener) {
textView.setVisibility(VISIBLE);
textView.setText(text); if (onClickListener != null)
textView.setOnClickListener(onClickListener);
} /**
* 绑定图片
*
* @param view
* @param drawable
* @param isLeft
* @param onClickListener
*/
void bindImageView(View view, Drawable drawable, boolean isLeft, OnClickListener onClickListener) {
ImageButton button = (ImageButton) view.findViewById(isLeft ? R.id.title_left_button : R.id.title_right_button);
button.setVisibility(VISIBLE);
button.setImageDrawable(drawable); if (onClickListener != null)
button.setOnClickListener(onClickListener);
}
}

【android】实现一个自己的标题栏的更多相关文章

  1. Android沉浸式(侵入式)标题栏(状态栏)Status(二)

     Android沉浸式(侵入式)标题栏(状态栏)Status(二) 附录1以xml写style实现了Android沉浸式(侵入式)状态栏(标题栏),同样以上层Java代码实现.在附录文章1的基础上 ...

  2. Android沉浸式(侵入式)标题栏(状态栏)Status(一)

     Android沉浸式(侵入式)标题栏(状态栏)Status(一) 现在越来越多的APP设计采用这种称之为沉浸式状态栏(Status)的设计,这种沉浸式状态栏又称之"侵入式"状 ...

  3. Android:一个高效的UI才是一个拉风的UI(二)

    趁今晚老大不在偷偷早下班,所以有时间继续跟大伙扯扯UI设计之痛,也算一个是对上篇<Android:一个高效的UI才是一个拉风的UI(一)>的完整补充吧.写得不好的话大家尽管拍砖~(来!砸死 ...

  4. Android 判断一个 View 是否可见 getLocalVisibleRect(rect) 与 getGlobalVisibleRect(rect)

    Android 判断一个 View 是否可见 getLocalVisibleRect(rect) 与 getGlobalVisibleRect(rect) [TOC] 这两个方法的区别 View.ge ...

  5. Android由一个activity 间隔5秒自动跳转到另外一个activity

    Android由一个activity 间隔5秒自动跳转到另外一个activity 2013年10月10日18:03:42 //一.写一个定时器 5秒后开启        final Intent lo ...

  6. Android沉浸式(侵入式)标题栏(状态栏)Status(三)

     Android沉浸式(侵入式)标题栏(状态栏)Status(三) 从附录文章1,2可以看到,依靠Android系统提供的标准方案,状态栏即便在透明状态下,仍然有些半透明而不是全透明.本文是And ...

  7. Android:一个高效的UI才是一个拉风的UI(一)

    开篇 Android是一个运行在移动终端上的操作系统,跟传统PC最大的不同所在就是移动终端的资源紧缺问题“比较”明显,当然对于一些屌丝机型,应该用“非常“来形容才靠谱.所以经常会出现在一些比较缺乏青春 ...

  8. android 让一个控件按钮居于底部的几种方法

    android 让一个控件按钮居于底部的几种方法1.采用linearlayout布局:android:layout_height="0dp" <!-- 这里不能设置fill_ ...

  9. Android中一个类实现的接口数不能超过七个

    近期一段时间,在开发Android应用程序的过程中,发现Android中一个类实现的接口数超过七个的时候,常常会出现超过第7个之后的接口不能正常使用.

随机推荐

  1. 【php】使用gdb调试php程序

    1.简介 GDB是GNU开源组织发布的一个强大的UNIX下的程序调试工具.如果你是在 UNIX平台下做软件,你会发现GDB这个调试工具有比VC.BCB的图形化调试器更强大的功能.同时GDB也具有例如d ...

  2. Android 滑动效果入门篇(一)—— ViewFlipper

    ViewFilpper 是Android官方提供的一个View容器类,继承于ViewAnimator类,用于实现页面切换,也可以设定时间间隔,让它自动播放.又ViewAnimator继承至于Frame ...

  3. LinuxI2C核心、总线驱动与设备驱动

    I2C体系结构分为三个部分:I2C核心.总线驱动.设备驱动 I2C核心: I2C核心提供了一组不依赖硬件的接口函数,I2C总线驱动和设备驱动之间依赖于I2C核心作为纽带 (1)增加/删除i2c_ada ...

  4. 【分享】iTOP-4412开发板使用之初体验[多图]

    近期入手了4412开发板,配的7寸屏和WIFI模块,GPS模块,下面晒个照片介绍一下,手机拍摄图片有点模糊,实物很精致,是我所见过最好的板子.b( ̄▽ ̄)d 预装的Android4.0.3系统,5点以 ...

  5. uva 1152 4 values whose sum is zero ——yhx

    The SUM problem can be formulated as follows: given four lists A;B;C;D of integer values, computehow ...

  6. 【Android UI设计与开发】1.引导界面(一)ViewPager介绍和简单实现

    1.ViewPager 实现效果图 2.ViewPager 实现功能 ViewPager类提供了多界面切换的新效果,新效果有如下特征: <1>当前显示一组界面中的其中一个界面: <2 ...

  7. UltraISO制作U盘启动盘安装Win7/10系统攻略

    UltraISO制作U盘启动盘安装Win7/9/10系统攻略 U盘安装好处就是不用使用笨拙的光盘,光盘还容易出现问题,无法读取的问题.U盘体积小,携带方便,随时都可以制作系统启动盘. U盘建议选择8G ...

  8. css3实现立方体的旋转功能

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. H5 canvas绘制出现模糊的问题

    在之前做移动端小游戏幸运转盘.九宫格转盘,使用到了 canvas ,也是第一次在项目中使用 canvas 来实现. 近期测试人员反应 canvas 绘制的内容太模糊,心想着用 canvas 绘制出来的 ...

  10. addEvent和removeEvent优化写法

    ;(function(){ /** * 初始化分支是一种优化模式,当知道某个条件在整个生命周期内都不会发生变化时,仅对该条件测试一次. */ // 一般写法 var util = { addEvent ...