界面控件的初始化一般通過 findViewByid 來查找綁定再強制轉換,這項工作只是個純體力活沒有任何營養,現在有很多開源類包支持通過注解的形式來綁定控件類似這樣
public class TestActivity extends BaseActivity {
@ViewInject(R.id.claim_statement)
private WebView mWebView;
}
但是這種形式其實編寫的代碼量跟findViewByid相差無幾。
因為習慣類中控件屬性名跟xml中id名保持一致,這樣可以很方便在類與xml中對應查找,初始化的時候復制粘貼也快
~
所以我想既然控件名跟id一致那可以直接通過反射類中屬性來初始化控件不是可以省掉一大段初始化控件的過程
下面直接上代碼
package com.gy.util;
import android.view.View;
import java.lang.reflect.Field;
/**
* 屬性名反射綁定控件
* Created by gy on 2016/3/16.
*/
public class ViewBindUtil {
public static final void bindViews(Object object, View footView) {
if(object == null) {
return;
}
//獲取對象中所有屬性-不包含父類私有成員
Field[] fields = getFields(object);
for(Field fi : fields) {
//判斷屬性是否繼承自view
if(View.class.isAssignableFrom(fi.getType())) {
//根據屬性名獲取id
int id = footView.getResources().getIdentifier(fi.getName(), "id", footView.getContext().getPackageName());
if(id > 0) {
try {
//查找到id時綁定控件到對應屬性上
fi.set(object, footView.findViewById(id));
} catch(IllegalAccessException e) {
e.printStackTrace();
}
}
}
}
}
public static Field[] getFields(Object o) {
Field[] f1 = o.getClass().getDeclaredFields();
// 設置不檢查訪問
for(int i = 0; i < f1.length; i++) {
f1[i].setAccessible(true);
}
return f1;
}
}
封裝到activity中
public abstract class BaseActivity extends FragmentActivity {
@Override
public void setContentView(int layoutResID) {
super.setContentView(layoutResID);
ViewBindUtil.bindViews(this, getWindow().getDecorView());
}
@Override
public void setContentView(View view) {
super.setContentView(view);
ViewBindUtil.bindViews(this, getWindow().getDecorView());
}
}
這樣只要繼承這個activity就能省去綁定過程直接使用了
public class MainActivity extends BaseActivity {
private TextView tv_name;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
tv_name.setText("123");
}
}
這個方法可以適用於任何對象activity,fragment或者listview自定義的viewholder,只要保證控件的屬性名與id一致即可,id不一致的時候還是可以手動綁定的