(转)通过泛型来简化findViewById

原文: http://www.stormzhang.com/android/androidtips/2014/08/24/android-viewfinder/

在Android获取一个View一般都是通过如下方式:

TextView textView = (TextView) findViewById(R.id.textview);

相信大家都写过无数次findViewById了吧,每次都要Cast一下是否很不爽啊。今天就来介绍三种简便的方法避免这种Cast

第一种

在项目基类BaseActivity中添加如下函数:

@SuppressWarnings(“unchecked”)
public final <E extends View> E getView (int id) {
    try {
        return (E) findViewById(id);
    } catch (ClassCastException ex) {
        Log.e(TAG, “Could not cast View to concrete class.”, ex);
        throw ex;
    }
}

然后就可以通过如下方式获取View了:

TextView textView = getView(R.id.textview);
Button button = getView(R.id.button);
ImageView image = getView(R.id.imageview);
注意:如果级联调用getView 函数,则还是需要Cast的,如下示例:
private static void myMethod (ImageView img) {
    //Do nothing
}
@Override
public void onCreate (Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    myMethod(getView(R.id.imageview)); //这样无法通过编译
    myMethod((ImageView) getView(R.id.imageview)); //需要Cast才可以
}

第二种

第一种方法只在Activity里有效,其实我们经常在其他View或者Fragment里也常用findViewById方法,当然你可以把上述方法copy一遍,但是这违反了面向对象基本的封装原则,有大神封装了一个ViewFinder类,具体代码可以见我Gist上的文件ViewFinder.java, 使用的时候你只需要在你的Activity或者View里这样使用:

ViewFinder finder = new ViewFinder(this);
TextView textView = finder.find(R.id.textview);

第三种

前两种方法本质上是利用了泛型,还有一种利用注解的方式,使用起来更方便,不仅省事的处理了findViewById,甚至包括setOnClickListener这种方法也能很方便的调用,具体见我这篇博客ButterKnife–View注入框架

注意:如果你是使用的Eclipse引用该library,你需要参考这里Eclipse Configuration做一些配置,否则会运行出错。

时间: 2024-10-12 22:35:31

(转)通过泛型来简化findViewById的相关文章

通过泛型来简化findViewById

我们一般写findViewById都要加个强制转换,感觉很麻烦,现在你可以在你的BaseActivity中写入如下方法: @SuppressWarnings(“unchecked”) public final <E extends View> E getView (int id) { try { return (E) findViewById(id); } catch (ClassCastException ex) { Log.e(TAG, “Could not cast View to co

Android通过泛型简化findViewById类型转换

以前老用findViewById,每次使用还得add cast一下今天看到一个视频(根据视频中使用的IDE推断,应该是几年前的视频了..),使用了一个方法,可以不用每次使用findViewById都去add cast. 我根据视频中的写法进行优化,具体做法: 创建一个BaseActivity,让它继承Activity,在其中添加如下方法: // 因为是findView所以泛型类型应该继承View protected <T extends View> T genericFindViewById(

Android 使用ORMLite打造万能泛型Dao简化数据持久化层

前面的一篇文章Android ORM系列之ActiveAndroid 介绍了ActiveAndroid的使用方法,但是ActiveAndroid有一个很明显的缺点,就是所有的实体类必须继承Model类才能进行CRUD,这是典型的php中的ActiveRecord方式的数据库操作.这时候我们会想一下,在Java Web中,hibernate或者mybatis就很好,其实在android中也有这么一个框架,但是这个框架是java的,只不过它支持Android而已,它就是ORMLite.这篇文章不会过

设计模式--模版设计模式

模版设计模式的概念或者定义: 定义一个操作中算法的框架,而将一些步骤延迟到子类中,使得子类可以不改变算法的结构即可重定义该算法中的某些特定步骤. 以前虽然经常在项目中使用模版设计模式,特别在BaseActivity,BaseFragement,BaseFragementActivity,BaseAdapter这种基类定义一些延伸到子类中实现的方法,但是不知道这个就是模版设计模式,我就毙了狗了. 比如在Base类里面为了规范代码的风格,在oncreate()里面调用空的函数,比如initView(

【转载】Java泛型(二)

转自:http://www.cnblogs.com/lwbqqyumidi/p/3837629.html 一. 泛型概念的提出(为什么需要泛型)? 首先,我们看下下面这段简短的代码: 1 public class GenericTest { 2 3 public static void main(String[] args) { 4 List list = new ArrayList(); 5 list.add("qqyumidi"); 6 list.add("corn&qu

使用getGenericSuperclass()和getActualTypeArguments()将DAO做成泛型

一.getGenericSuperclass()和getActualTypeArguments()基本用法: import java.lang.reflect.ParameterizedType; public class TT extends TT2<Integer> { public static void main(String[] args) { System.out.println(((ParameterizedType) new TT().getClass() .getGeneri

JAVA泛型(转)

一. 泛型概念的提出(为什么需要泛型)? 首先,我们看下下面这段简短的代码: 1 public class GenericTest { 2 3 public static void main(String[] args) { 4 List list = new ArrayList(); 5 list.add("qqyumidi"); 6 list.add("corn"); 7 list.add(100); 8 9 for (int i = 0; i < lis

Java2_Java泛型

一. 泛型概念的提出(为什么需要泛型)? 首先,我们看下下面这段简短的代码: 1 public class GenericTest { 2 3 public static void main(String[] args) { 4 List list = new ArrayList(); 5 list.add("qqyumidi"); 6 list.add("corn"); 7 list.add(100); 8 9 for (int i = 0; i < lis

(转)1.21 Java总结篇系列:Java泛型

一. 泛型概念的提出(为什么需要泛型)? 首先,我们看下下面这段简短的代码: 1 public class GenericTest { 2 3 public static void main(String[] args) { 4 List list = new ArrayList(); 5 list.add("qqyumidi"); 6 list.add("corn"); 7 list.add(100); 8 9 for (int i = 0; i < lis