安卓自定义组合控件--toolbar
最近在学习安卓APP的开发,用到了toolbar这个控件, 最开始使用时include layout这种方法,不过感觉封装性不好,就又改成了自定义组合控件的方式。
使用的工具为android studio 2.2,简称AS吧
1.首先创建一个新的自定义控件,如下图。AS会创建3个文件, 一个java文件,一个layout中的xml文件(这个是布局文件),一个values中的xml文件(这个是属性文件)

2. 修改布局文件,代码如下。这里使用了RelativeLayout, 并且宽度和高度都选择了match_parent, 真实的宽度是在调用控件的地方写。
布局很简单, 左边后退按钮(可定义onclick方法),中间标题,右边功能按钮(可隐藏,可更换图标,可定义onclick方法)
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/toolbar_all1"
android:layout_width="match_parent"
android:layout_height="match_parent"> <ImageView
android:id="@+id/toolbar_left_button1"
android:layout_width="20dp"
android:layout_height="20dp"
android:layout_alignParentLeft="true"
android:layout_centerVertical="true"
android:layout_marginLeft="10dp"
android:src="@mipmap/ic_top_back"/> <TextView
android:id="@+id/toolbar_title1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:textColor="@color/toolbar_text"
android:textSize="@dimen/toolbar_text_size"/> <ImageView
android:id="@+id/toolbar_right_button1"
android:layout_width="30dp"
android:layout_height="30dp"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:layout_marginRight="10dp"/> </RelativeLayout>
3. 修改属性文件,这里就定义了一个属性titleText, 用于在布局文件中给toolbar设置title
<resources>
<declare-styleable name="ToolbarControl">
<attr name="titleText" format="string"/>
</declare-styleable>
</resources>
4.修改java文件。ToolbarControl类是继承与Toolbar类的。定义了titleStr属性,并且生成getter和setter,这里要和属性文件中定义的属性名一致,类型也要一致,否则会有问题。
还定义了代码设置title,代码设置右边功能菜单的图标、onclick事件。以及左边后退按钮的onclick事件(本来想把后退封装在控件里面,但是没找到好的方法,只能从调用的地方添加个OnclickListenser, 如有方法封装到控件里面,请指教)
public class ToolbarControl extends Toolbar {
private static final String TAG = ToolbarControl.class.getSimpleName();
private String titleText;
@BindView(R.id.toolbar_left_button1)
public ImageView leftButton;
@BindView(R.id.toolbar_title1)
public TextView titleTextView;
@BindView(R.id.toolbar_right_button1)
public ImageView rightButton;
public ToolbarControl(Context context) {
super(context);
init(context, null);
}
public ToolbarControl(Context context, AttributeSet attrs) {
super(context, attrs);
init(context, attrs);
}
private void init(Context context, AttributeSet attrs) {
View view = LayoutInflater.from(context).inflate(R.layout.toolbar_control, this, true);
ButterKnife.bind(this, view);
//很重要
setContentInsetsRelative(0, 0);
// Load attributes
final TypedArray a = getContext().obtainStyledAttributes(
attrs, R.styleable.ToolbarControl, 0, 0);
titleText = a.getString(R.styleable.ToolbarControl_titleText);
Log.d(TAG, titleText);
titleTextView.setText(titleText);
a.recycle();
}
public void setTitle(String titleStr) {
if (titleTextView != null) {
titleTextView.setText(titleStr);
}
}
public void setTitleByResourceId(int rid) {
if (titleTextView != null) {
titleTextView.setText(rid);
}
}
public void setRightButtonImage(int resourceId) {
if (rightButton != null) {
rightButton.setImageResource(resourceId);
}
}
public void showImage() {
if (rightButton != null) {
rightButton.setVisibility(View.VISIBLE);
}
}
public void hideImage() {
if (rightButton != null) {
rightButton.setVisibility(View.GONE);
}
}
public void hide() {
this.setVisibility(View.GONE);
}
public void setBackButtonOnClickListerner(OnClickListener listerner) {
if (leftButton != null && listerner != null) {
leftButton.setOnClickListener(listerner);
}
}
public void setButtonOnClickListener(OnClickListener listener) {
if (rightButton != null && listener != null) {
rightButton.setOnClickListener(listener);
}
}
public String getTitleText() {
return titleText;
}
public void setTitleText(String titleText) {
this.titleText = titleText;
}
}
5. 布局中引用, 这里要设置控件的颜色、height也设置成wrap_content,并设置minHeight为?attr/actionBarSize
<com.example.ben.tracktest.controls.ToolbarControl
android:id="@+id/about_me_toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?attr/colorPrimary"
android:minHeight="?attr/actionBarSize"
app:titleText="@string/about_me_title"> </com.example.ben.tracktest.controls.ToolbarControl>
6. 代码中初始化控件。 首先将空间设置为support actionbar, 之后禁止显示自动的title, 然后设置 后退按钮的事件(就是finish),设置右边功能菜单的图标,和点击事件
private void initToolBar() {
setSupportActionBar(toolbar);
getSupportActionBar().setDisplayShowTitleEnabled(false);
toolbar.setBackButtonOnClickListerner(new View.OnClickListener() {
@Override
public void onClick(View view) {
AboutMeActivity.this.finish();
}
});
toolbar.setRightButtonImage(R.drawable.me);
toolbar.setButtonOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
//你自己的功能
}
});
}
好了,一个完整的toolbar控件极其调用功能已经完成了。看下效果吧。

如果有问题,请指教
安卓自定义组合控件--toolbar的更多相关文章
- Android自定义控件之自定义组合控件
前言: 前两篇介绍了自定义控件的基础原理Android自定义控件之基本原理(一).自定义属性Android自定义控件之自定义属性(二).今天重点介绍一下如何通过自定义组合控件来提高布局的复用,降低开发 ...
- Android 手机卫士--自定义组合控件构件布局结构
由于设置中心条目中的布局都很类似,所以可以考虑使用自定义组合控件来简化实现 本文地址:http://www.cnblogs.com/wuyudong/p/5909043.html,转载请注明源地址. ...
- Android开发之自定义组合控件
自定义组合控件的步骤1.自定义一个View,继承ViewGroup,比如RelativeLayout2.编写组合控件的布局文件,在自定义的view中加载(使用View.inflate())3.自定义属 ...
- 自定义组合控件,适配器原理-Day31
自定义组合控件,适配器原理-Day31 mobile2.1 主页定义 手机上锁功能 1.弹出设置密码框. 手机下载进度 自定定义控件 控件的属性其实就是控件类一个属性设置属性调用类的set方法方法, ...
- 安卓自定义日期控件(仿QQ,IOS7)
还记得上篇:高大上的安卓日期时间选择器,本篇是根据上篇修改而来,先看下qq中日期选择的效果: 鉴于目前还没有相似的开源日期控件,因此本人花费了一些时间修改了下之前的日期控件,效果如图: 虽说相似度不是 ...
- Android Studio自定义组合控件
在Android的开发中,为了能够服用代码,会把有一定共有特点的控件组合在一起定义成一个自定义组合控件. 本文就详细讲述这一过程.虽然这样的View的组合有一个粒度的问题.粒度太大了无法复用,粒度太小 ...
- Android自定义组合控件详细示例 (附完整源码)
在我们平时的Android开发中,有时候原生的控件无法满足我们的需求,或者经常用到几个控件组合在一起来使用.这个时候,我们就可以根据自己的需求创建自定义的控件了,一般通过继承View或其子类来实现. ...
- Android开发学习笔记-自定义组合控件的过程
自定义组合控件的过程 1.自定义一个View 一般来说,继承相对布局,或者线性布局 ViewGroup:2.实现父类的构造方法.一般来说,需要在构造方法里初始化自定义的布局文件:3.根据一些需要或者需 ...
- Android中自定义组合控件
Android中自定义控件的情况非常多,一般自定义控件可以分为两种:继承控件及组合控件.前者是通过继承View或其子类,重写方法实现自定义的显示及事件处理方式:后者是通过组合已有的控件,来实现结构的简 ...
随机推荐
- 关于textview显示特殊符号居中的问题
话说这是2017年的第一篇博客,也是一篇技术博客.先从简单的一篇解决问题开始吧,千里之行,始于足下! ------------------------------------------------- ...
- Visaul Studio 常用快捷键的动画演示
从本篇文章开始,我将会陆续介绍提高 VS 开发效率的文章,欢迎大家补充~ 在进行代码开发的时候,我们往往会频繁的使用键盘.鼠标进行协作,但是切换使用两种工具会影响到我们的开发速度,如果所有的操作都可以 ...
- .NET Core的日志[1]:采用统一的模式记录日志
记录各种级别的日志是所有应用不可或缺的功能.关于日志记录的实现,我们有太多第三方框架可供选择,比如Log4Net.NLog.Loggr和Serilog 等,当然我们还可以选择微软原生的诊断框架(相关A ...
- 文件随机读写专用类——RandomAccessFile
RandomAccessFile类可以随机读取文件,但是在测试中并不好用;File类可以测试文件存不存在,不存在可以创建文件;FileWriter类可以对文件进行重写或者追加内容;FileReade ...
- Spring(三)__aop编程
aop( aspect oriented programming ) 面向切面编程,是对所有对象或者是一类对象编程 几个重要的概念: 1.切面(aspect):要实现的交叉功能,是系统模块化的一个切面 ...
- 用angular怎么缓存父页面数据
angular做单页面应用是一个比较好的框架,但是它有一定的入门难度,对于新手来说可能会碰到很多坑,也有许多难题,大部分仔细看文档,找社区是能解决的. 但有些问题也许资料比较少,最近遇到过一个要缓存父 ...
- Atitit 软件工程概览attilax总结
Atitit 软件工程概览attilax总结 1.1. .2 软件工程的发展 进一步地,结合人类发展史和计算机世界演化史来考察软件工程的发展史. 表2 软件工程过程模型 表2将软件工程的主要过程模型做 ...
- iOS7 NavigationController 手势问题
在iOS7中,如果使用了UINavigationController,那么系统自带的附加了一个从屏幕左边缘开始滑动可以实现pop的手势.但是,如果自定义了navigationItem的leftBarB ...
- Linux硬件IO的优化简介
Linux硬件IO的优化简介 首先简单介绍下有哪些硬件设备如下(由于硬件种类厂家等各种因素我就不在此多做介绍有兴趣的可以自行学习): 1.CPU:中央处理器,是计算机运算控制的核心部件之一,相当于人的 ...
- photoshop:无法完成请求 因为暂存盘已满
今天photoshop打开一个问题,提醒:无法完成请求因为暂存盘已满 不用担心这个问题很好解决可能是你做的图比较大并不需要清理C盘空间 选择:编辑→首选项→暂存盘 设置第一暂存盘为D盘或E盘 总之 第 ...