我们在开发App的时候有时候碰到多个界面有一个共同点的时候。比方,都有同样的TitleBar。而且TitleBar能够设置显示的文字。TitleBar上的点击事件,假设给每个Activity都写一遍TitleBar是一件非常费事的事情,这个时候我们就能够重写一个Activity基类,让其它有同样点的Activity来继承这个类。从而省去了非常多的反复不必要的工作。

提高了效率。

如图:

两个界面拥有共同的特点,有一个我们自定义的TitleBar,这个TitleBar属于我们自定义的基类BaseActivity,假设我们想让一个类具有这个特性,仅仅须要继承BaseActivity并加入对应的布局就可以。事件什么的都写一边就OK了。

  

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" width="320" height="600" alt="">

BaseActivity.java

内部有一个重写的TitleBar控件。封装相应的方法对TitleBar进行操作,该类的事件将会被TitleBa调用。详细调用看TitleBar实现

/**
* 重写的一个Activity 的基类,在基类中实现了一个TitleBar 用TitleBar来展示一个标题
* 同一时候定义一个Back按钮,点击的时候退出当前的Activity
*
* @author mingwei
*
*/
public abstract class BaseActivity extends Activity {
private TitleBar mTitleBar; @Override
protected void onCreate(Bundle savedInstanceState) {
requestWindowFeature(Window.FEATURE_NO_TITLE);
super.onCreate(savedInstanceState);
setTheme(android.R.style.Theme_Light_NoTitleBar);
} @Override
public void setContentView(int layoutResID) {
// TODO Auto-generated method stub
super.setContentView(layoutResID);
initBaseView();
} public void initBaseView() {
mTitleBar = (TitleBar) findViewById(R.id.base_titlebar);
} public void setTitleBarBackText(String text) {
// mTitleBar.setBackText(text);
} public void setTitleBarTitle(String tite) {
if (mTitleBar != null) {
mTitleBar.setTitle(tite);
}
} public void setTitleBarTitle(int titleId) {
if (mTitleBar != null) {
mTitleBar.setTitle(getString(titleId));
}
}
public void setTitleBarTitleDrawable(Drawable drawable){
if (mTitleBar != null) {
mTitleBar.setTitleRightDrawable(drawable);
}
}
//返回键事件
public void finishActivity() {
finish();
} public void setTitleRTBtnVisiable(int visiable) {
if (mTitleBar != null) {
mTitleBar.setRTBtnVisiable(visiable);
} } public void setTitleRTBtnText(String text) {
if (mTitleBar != null) {
mTitleBar.setRTBtnText(text);
}
} public void setTitleRTBtnText(int textId) {
if (mTitleBar != null) {
mTitleBar.setRTBtnText(getString(textId));
}
} public void setTitleRTBtnFocusable(boolean focusable) {
if (mTitleBar != null) {
mTitleBar.setRTBtnFocusable(focusable);
}
}
//中间的Title点击事件
public void setCenterClick(boolean bool) {
mTitleBar.setTitleClick(bool);
} public void onRtBtnClick() {
// titlebar左上角button的click时间
} public void onCenterClick() {
// titlebar中间的title点击事件 } }

我们再来看看TitleBar长啥样子,TitleBar是一个封装的RelativLayout,包含一个返回键,中的Title,右边的button

注意:凝视1的地方。Activity中的容器或者控件想到调用Activity中的方法或者属性怎么办?

比如,我在点击Back的ImageView时想让Activity finished()掉,仅仅须要我们把容器中得到的Context强转为对应的Activity就可以,之后就能够方便的调用Activity的方法了。

/**
* 基类BaseActivity用到的TitleBar。用来返回页面和展示当前页内容的Title信息
*
* @author mingwei
*
*/
public class TitleBar extends RelativeLayout implements OnClickListener { private ImageView mBack;
private TextView mTitle;
private TextView mRTBtn;
BaseActivity mContext; public TitleBar(Context context) {
this(context, null);
} public TitleBar(Context context, AttributeSet attrs) {
super(context, attrs, 0);
} public TitleBar(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
mContext = (BaseActivity) getContext();// <span style="color:#ff0000;">凝视1</span>
} /**
* 初始化控件
*/
@Override
protected void onFinishInflate() {
super.onFinishInflate();
mContext = (BaseActivity) getContext();
mBack = (ImageView) findViewById(R.id.base_titlebar_back);
mTitle = (TextView) findViewById(R.id.base_titlebar_title);
mRTBtn = (TextView) findViewById(R.id.base_titlebar_rtbtn);
mBack.setOnClickListener(this);
mTitle.setOnClickListener(this);
mRTBtn.setOnClickListener(this);
mTitle.setClickable(false);
} /**
* 右边的控件是否可见
*/
public void setRTBtnVisiable(int visiable) {
mRTBtn.setVisibility(visiable);
} /**
* 右边控件的文版
*/
public void setRTBtnText(String title) {
mRTBtn.setText(title);
} /**
* 右边控件的显示颜色变化
*/
public void setRTBtnFocusable(boolean focusable) {
mRTBtn.setEnabled(focusable);
if (focusable) {
mRTBtn.setTextColor(getResources().getColor(R.color.base_rtbtn_clickable_color));
} else {
mRTBtn.setTextColor(getResources().getColor(R.color.base_rtbtn_clickunable_color));
}
} /**
* 返回右边控件
*/
public TextView getRTBtnTextView() {
return mRTBtn;
} /**
* 中间控件的点击事件
*/
public void setTitleClick(boolean bool) {
mTitle.setClickable(bool);
} /**
* 中间控件文本</span>
*/
public void setTitle(String title) {
mTitle.setText(title);
} /**
* 中间控件图标</span>
*/
public void setCompoundDrawables(Drawable drawable) {
mTitle.setCompoundDrawables(null, null, drawable, null);
} /**
* 中间控件图标</span>
*/
public void setTitleRightDrawable(Drawable drawable) {
mTitle.setCompoundDrawablesWithIntrinsicBounds(null, null, drawable, null);
} /**
* 控件的点击情况,分别去调用BaseActivity的方法,
* 基类被重写后将在子类中调用这些方法</span>
*/
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.base_titlebar_back:
mContext.finishActivity();
break;
case R.id.base_titlebar_title:
mContext.onCenterClick();
break;
case R.id.base_titlebar_rtbtn:
mContext.onRtBtnClick();
break;
default:
break;
}
}
}

</pre><p></p><pre>

TitleBar用到的布局

<?xml version="1.0" encoding="utf-8"?>
<com.xiaoda.juma001.widget.TitleBar xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="@dimen/base_titlebar_height"
android:background="@color/base_activity_titlebar_backcolor"
android:fitsSystemWindows="true" > <ImageView
android:id="@+id/base_titlebar_back"
android:layout_width="@dimen/base_titlebar_back_width"
android:layout_height="match_parent"
android:contentDescription="@string/base_title_back_des"
android:padding="@dimen/base_activity_titlebar_back_padding"
android:src="@drawable/base_activity_back_nor" /> <TextView
android:id="@+id/base_titlebar_title"
style="@style/BaseActivityTitlebarTitleStyle"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_alignBaseline="@+id/base_titlebar_back"
android:layout_alignBottom="@+id/base_titlebar_back"
android:layout_centerHorizontal="true" /> <TextView
android:id="@+id/base_titlebar_rtbtn"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:layout_marginRight="@dimen/base_titlebar_rtbutton_marginright"
android:gravity="center"
android:textColor="@color/base_activity_titlebar_textcolor"
android:visibility="invisible" /> <View
android:layout_width="match_parent"
android:layout_height="@dimen/base_titlebar_bottom_line_height"
android:layout_alignParentBottom="true"
android:background="@color/base_activity_titlebar_bottom_linecolor" /> </com.xiaoda.juma001.widget.TitleBar>

写到这里就写好了。我们来看看怎样使用

/**
* 继承BaseActivity
* @author mingwei
*
*/
public class AllPictureActivity extends BaseActivity { @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.allpicture_activity);
setTitleBarTitle(R.string.allpicture_title);
setTitleRTBtnVisiable(View.VISIBLE);
setTitleRTBtnText(R.string.allpicture_ok);
setTitleBarTitleDrawable(getResources().getDrawable(R.drawable.all_picture_more_dropdown));
setCenterClick(true);
initView();
} private void initView() { } /**
* 中间的TitleBar的点击事件
*/
@Override
public void onCenterClick() {
super.onCenterClick();
taggleLayout();
} private void taggleLayout() { } private void changeData(int i) { }
/**
* 返回button点击事件
*/
@Override
public void finishActivity() {
// TODO Auto-generated method stub
super.finishActivity();
} /**
* 右上角的button的点击事件
*/
@Override
public void onRtBtnClick() {
super.onRtBtnClick(); } }

别忘了给Activity布局文件加上TitleBar的文件引用

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" > <include
android:id="@id/base_titlebar"
layout="@layout/base_activity_titlebar" />//TitleBar布局文件 <GridView
android:id="@+id/allpicture_grid"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:cacheColorHint="@android:color/transparent"
android:columnWidth="90dip"
android:gravity="center"
android:horizontalSpacing="5dip"
android:listSelector="@android:color/transparent"
android:numColumns="auto_fit"
android:stretchMode="columnWidth"
android:verticalSpacing="5dip" >
</GridView> </LinearLayout>

ids文件 别忘了把你这些不变的id写到ids文件里去

<?

xml version="1.0" encoding="utf-8"?>
<resources> <item name="base_titlebar" type="id">base_titlebar</item> </resources>

实现的界面例如以下图所看到的:

Android 自己定义Activity基类的更多相关文章

  1. Android 自定义Activity基类与TitleBar

    我们在开发App的时候有时候碰到多个界面有一个共同点的时候,比如,都有相同的TitleBar,并且TitleBar可以设置显示的文字.TitleBar上的点击事件,如果给每一个Activity都写一遍 ...

  2. 34 异常机制 异常体系结构 Java把异常当做对象来处理 并定义一个基类java.lang.Throwable作为所有异常的超类 Error Exception

    异常体系结构 概念 Java把异常当做对象来处理,并定义一个基类java.lang.Throwable作为所有异常的超类. 在Java API中已经定义了许多异常类,这些异常类分为两大类,错误Erro ...

  3. 【Android进阶】为什么要创建Activity基类以及Activity基类中一般有哪些方法

    现在也算是刚刚基本完成了自己的第一个商业项目,在开发的过程中,参考了不少人的代码风格,然而随着工作经验的积累,终于开始慢慢的了解到抽象思想在面向对象编程中的重要性,这一篇简单的介绍一下我的一点收获. ...

  4. 【Android先进】我们为什么要创建Activity基类Activity什么是一般的基类方法

    今天,它可以被视为只是基本完成了其首个商业项目,在发展过程中,风格,然而随着工作经验的积累.最终開始慢慢的了解到抽象思想在面向对象编程中的重要性,这一篇简单的介绍一下我的一点收获. 首先,在如今的项目 ...

  5. asp.net 的page 基类页面 做一些判断 可以定义一个基类页面 继承Page类 然后重写OnPreLoad事件

    public class BasePage:Page protected override void OnPreLoad(EventArgs e){     base.OnPreLoad(e);    ...

  6. 在对Activity基类的封装中,我做了什么

    在开发实践中,不同Activity有很多代码是反复冗余的.因此非常有必要将这部分抽取出来.封装一个继承自Activity的类,命名为BaseActivity. 翻看之前写过的代码,起初,BaseAct ...

  7. android Activity基类通用方法

    public class BaseActivity extends Activity { Resources res; // 通用资源缩写 @Override protected void onCre ...

  8. Android:自定义BaseActivity基类

    使用BaseActivity可以封装一些重复代码例如设置标题栏颜色,封装一些工具类... 主要功能: 封装Toast 新建一个BaseActivity继承自Activity package com.o ...

  9. Android 在非Activity的类中调用startActivityForResult

    http://www.360doc.com/content/11/0720/10/7322578_134657348.shtml

随机推荐

  1. 北大ACM(POJ1018-Communication System)

    Question:http://poj.org/problem?id=1018 问题点:枚举. Memory: 564K Time: 329MS Language: C++ Result: Accep ...

  2. 模块挂载、切换,uml模式、流程图模式

    模块挂载.切换,uml模式.流程图模式

  3. ORB-SLAM2:一种开源的VSLAM方案(译文)

    摘要: ORB-SLAM2是基于单目,双目和RGB-D相机的一套完整的SLAM方案.它能够实现地图重用,回环检测和重新定位的功能.无论是在室内的小型手持设备,还是到工厂环境的无人机和城市里驾驶的汽车, ...

  4. gym101343J. Husam and the Broken Present 2 (状压DP)

    题意:给定n个串 每个串长度不超过100 找到一个新串 使得这n个串都是它的字串 输出这个新串的最小长度 题解:n是15 n的阶乘的复杂度肯定不行 就想到了2的15次方的复杂度 想到了状压但是不知道怎 ...

  5. 【转】Go语言入门教程(一)Linux下安装Go

    说明 系统是Ubuntu. 关于安装 下载安装包 当前官方下载地址是https://golang.org/dl/,如果不能访问,请自行FQ,FQ是技术工作者的必备技能. 安装 tar -xzvf go ...

  6. adb 命令收藏学习地址

    adb 命令相关的网页https://www.cnblogs.com/medsonk/p/8334847.htmlhttps://www.cnblogs.com/medsonk/p/6959658.h ...

  7. 封装一个获取module.exports内容的方法

    let fs = require('fs') let req = (moduleName) => { //content代表的是文件内容 let content = fs.readFileSyn ...

  8. 【2018百度之星资格赛】F 三原色图 - 最小生成树

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=6349 Knowledge Point: 最小生成树算法Prim&Kruskal Summari ...

  9. FileWriter实现从一个文件中读取内容并写到另一个文件中

    FileWriter和FileOutputStream都是向文件写内容,区别是前台一次写一个字符,后者一次写一个字节 package com.janson.day20180827; import ja ...

  10. python3中整数和小数的转换

    在整数除法中,除法(/)总是返回一个浮点数,如果只想得到整数的结果,丢弃可能的分数部分,可以使用运算符 // : >>> 17 / 3 # 整数除法返回浮点型 5.666666666 ...