Tuesday, February 16, 2016

ButterKnife使用教程

http://lihb.github.io/ButterKnife使用教程/

一、简介

使用ButterKnife框架,可以使你从大量的findViewById中解脱出来,更专注于业务逻辑的实现。
Butterknife的特性:
  • 支持 Activity 中的 View 注入
  • 支持 View 中的 View 注入
  • 支持 View 事件回调函数注入
目前支持如下事件回调函数:
  • View: @OnLongClick and @OnFocusChanged.
  • TextView: @OnEditorAction.
  • AdapterView: @OnItemClick and @OnItemLongClick.
  • CompoundButton: @OnCheckedChanged.

二、安装及配置

1.去官网或者github下载jar包(目前最新版本为:butterknife-6.1.0.jar),放到工程的libs目录,如果你使用的是Android Studio,在app目录下的build.gradle中添加如下依赖即可:
  1. dependencies {
  2. compile fileTree(dir: 'libs', include: ['*.jar'])
  3. compile 'com.android.support:appcompat-v7:21.0.2'
  4. compile 'com.jakewharton:butterknife:6.1.0'
  5. }
2.IDE中的配置
2.1 Eclipse中的配置
右键单击工程,选择properties--->java compile---> Annotation Processing,勾选 "Enable project specific settings"。如下图所示:
eclipse配置1
然后,点开Annotation Processing,选中Factory Path,勾选 "Enable project specific settings" ,选择 "Add JARs…"添加你下载的butterknife jar包,如下所示:
eclipse配置2
2.2 IntelliJ IDEA中的配置
需要开启AnnotationProcessor配置。如下图:
idea配置1

三、使用

没使用butterknife之前,你的代码如下:
  1. public class Main extends Activity {
  2. EditText editInfo;
  3. Button btnOK;
  4. @Override
  5. public void onCreate(Bundle savedInstanceState)
  6. {
  7. super.onCreate(savedInstanceState);
  8. setContentView(R.layout.main);
  9. editInfo = (EditText) findViewById(R.id.edit_info);
  10. btnOK = (Button) findViewById(R.id.btn_ok);
  11. editInfo.setText("Hello World");
  12. btnOK.setOnClickListener(new View.OnClickListener() {
  13. @Override
  14. public void onClick(View v) {
  15. String str = editInfo.getText().toString();
  16. if("Hello World".equals(str)) {
  17. editInfo.setText("Hello Java");
  18. return;
  19. }
  20. if("Hello Java".equals(str)) {
  21. editInfo.setText("Hello World");
  22. return;
  23. }
  24. }
  25. });
  26. }
  27. }
使用butterknife之后,你的代码可简写如下所示:
  1. public class Main extends Activity {
  2. @InjectView(R.id.edit_info)
  3. EditText editInfo;
  4. @InjectView(R.id.btn_ok)
  5. Button btnOK;
  6. @Override
  7. public void onCreate(Bundle savedInstanceState)
  8. {
  9. super.onCreate(savedInstanceState);
  10. setContentView(R.layout.main);
  11. ButterKnife.inject(this);
  12. editInfo.setText("Hello World")
  13. }
  14. @OnClick(R.id.btn_ok)
  15. public void changeText() {
  16. String str = editInfo.getText().toString();
  17. if("Hello World".equals(str)) {
  18. editInfo.setText("Hello Java");
  19. return;
  20. }
  21. if("Hello Java".equals(str)) {
  22. editInfo.setText("Hello World");
  23. return;
  24. }
  25. }
  26. }
一些示例代码如下所示:
在Activity 中注入
  1. class ExampleActivity extends Activity {
  2. @InjectView(R.id.title) TextView title;
  3. @InjectView(R.id.subtitle) TextView subtitle;
  4. @InjectView(R.id.footer) TextView footer;
  5. @Override
  6. public void onCreate(Bundle savedInstanceState) {
  7. super.onCreate(savedInstanceState);
  8. setContentView(R.layout.simple_activity);
  9. ButterKnife.inject(this);
  10. // TODO Use "injected" views...
  11. }
  12. }
在Fragment中注入
  1. public class FancyFragment extends Fragment {
  2. @InjectView(R.id.button1) Button button1;
  3. @InjectView(R.id.button2) Button button2;
  4. @Override
  5. View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
  6. View view = inflater.inflate(R.layout.fancy_fragment, container, false);
  7. ButterKnife.inject(this, view);
  8. // TODO Use "injected" views...
  9. return view;
  10. }
  11. }
在ViewHolder中注入
  1. public class MyAdapter extends BaseAdapter {
  2. @Override
  3. public View getView(int position, View view, ViewGroup parent) {
  4. ViewHolder holder;
  5. if (view != null) {
  6. holder = (ViewHolder) view.getTag();
  7. } else {
  8. view = inflater.inflate(R.layout.whatever, parent, false);
  9. holder = new ViewHolder(view);
  10. view.setTag(holder);
  11. }
  12. holder.name.setText("John Doe");
  13. // etc...
  14. return convertView;
  15. }
  16. static class ViewHolder {
  17. @InjectView(R.id.title) TextView name;
  18. @InjectView(R.id.job_title) TextView jobTitle;
  19. public ViewHolder(View view) {
  20. ButterKnife.inject(this, view);
  21. }
  22. }
  23. }
注入回调函数
下面是几种注入回调函数的方法示例:
  1. // 带有 Button 参数
  2. @OnClick(R.id.submit)
  3. public void sayHi(Button button) {
  4. button.setText("Hello!");
  5. }
  6. // 不带参数
  7. @OnClick(R.id.submit)
  8. public void submit() {
  9. // TODO submit data to server...
  10. }
  11. // 同时注入多个 View 事件
  12. @OnClick({ R.id.door1, R.id.door2, R.id.door3 })
  13. public void pickDoor(DoorView door) {
  14. if (door.hasPrizeBehind()) {
  15. Toast.makeText(this, "You win!", LENGTH_SHORT).show();
  16. } else {
  17. Toast.makeText(this, "Try again", LENGTH_SHORT).show();
  18. }
  19. }
Reset函数
如果需要在界面销毁的时候,把注入的View设置为 Null,则可以用 reset 函数:
  1. public class FancyFragment extends Fragment {
  2. @InjectView(R.id.button1) Button button1;
  3. @InjectView(R.id.button2) Button button2;
  4. @Override
  5. View onCreateView(LayoutInflater inflater,ViewGroup group, Bundle savedInstanceState) {
  6. View view = inflater.inflate(R.layout.fancy_fragment, container, false);
  7. ButterKnife.inject(this, view);
  8. // TODO Use "injected" views...
  9. return view;
  10. }
  11. @Override void onDestroyView() {
  12. super.onDestroyView();
  13. Views.reset(this);
  14. }
  15. }
另外,还支持可选的 View注入,如果该 View 没有,也没关系:
  1. @Optional @InjectView(R.id.might_not_be_there) TextView mightNotBeThere;
  2. @Optional @OnClick(R.id.maybe_missing) void onMaybeMissingClicked() {
  3. // TODO ...
  4. }
Android Studio、Idea插件
演示:
插件

四、参考文献

No comments:

Post a Comment