Android Studio中配置
Tips:
在Dagger2的使用中,按照ButterKnife和Dagger2 guthub上readme配置會出現(xiàn)ButterKnife找不到控件的問題,所以在講Dagger2的時候順便將ButterKnife的配置再重新說一遍。找到具體的原因,解決問題。
- dagger2:
- app中的build.gradle 中添加 :
apply plugin: 'com.neenbedankt.android-apt'
- dependencies中添加:
apt 'com.google.dagger:dagger-compiler:2.10-rc4'
- 在整個project的build.gradle中添加:
buildscript { .... dependencies { ... classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8' } }
- butterKnife:
- 在app的build.gradle中:
android{
...
//dagger2和butterknife沖突
packagingOptions{
exclude 'META-INF/services/javax.annotation.processing.Processor'
}
}
dependencies {
...
compile 'com.jakewharton:butterknife:+'
apt 'com.jakewharton:butterknife-compiler:+'
}
集成dagger2和butterKnife后,使用butterKnife找不到控件,其原因在于注釋工具:android-apt和annotationProcessor。
- android-apt是安卓處理注釋的工具,是個人開發(fā)的一個apt框架。
- annotationProcessor是google推出替代android-apt的,后面android-apt也停止更新了。
- 這兩個注釋工具只能用其中一個,dagger2用的apt,我們就把butterKnife的改成apt就能正常使用butterKnife了。
四種基礎的注解
-
@Inject
@Inject 注解主要有兩個作用:- 在使用類的構造函數(shù)上進行依賴注入,在我們需要使用這個類的時候,通過@Inject注解就能注入,得到該類的實例化對象。
- 在使用某個類(需要某個類的實例化對象)時,在使用的類中通過@Inject注解讓Daager2為其提供依賴。
這樣說起來太過于抽象,來舉個例子:
- 在類的構造函數(shù)上使用@Inject:
要獲得adapter的實例化對象,那么我們可以通過@Inject依賴注入,在Activity中就能得到adapter的實例化對象了。
@Inject
public MyAdapter() {
}
@Inject
MyAdapter mAdapter;
得到adapter的實例化對象后,再去設置context和數(shù)據(jù)源:
@OnClick(R.id.b_test)
public void onViewClicked() {
List<String> list = new ArrayList<>();
for (int i = 0; i < 5; i++) {
list.add("這是第 " + (i+1) + " 條數(shù)據(jù)!");
}
DaggerTestActivityComponent.create().inject(this);
mAdapter.setContext(this);
mAdapter.setList(list);
mRvName.setLayoutManager(new LinearLayoutManager(this));
mRvName.setHasFixedSize(true);
mRvName.setAdapter(mAdapter);
}
- 使用某個類的實例化對象
假如,有一個Student的類,我們需要在某個時候使用它,那么,我們可以直接在使用的地方,直接用:
@Inject
Student mStudent;
@Model
@Model這個注解使用在Module標注的類中的,第一個@Inject注解是使用在類中的構造函數(shù)上。當然使用@Inject注解的,同樣可以使用@Model來進行依賴注入。@Provides
@Provides是用來標注類中的方法的,一般配合@Model使用。通過依賴注入獲取實例化對象時,@Provide可以直接調用標注的方法,完成賦值或者其他的一些操作。
@Module
public class StudentModel {
@Provides
public Student getStudent(){
Student student = new Student();
student.setId(1);
student.setAge(24);
student.setName("Leo");
student.setGender("male");
return student;
}
}
-
@Component
我們在被使用的類中標注了注解,那么,我們使用時,是怎么將依賴方和被依賴方關聯(lián)起來的?所以,這個時候就要使用到@Component了,它是依賴方和需要依賴方之間的橋梁,把相關依賴注入到其中。
@Component(modules = StudentModel.class)
public interface MainActivityComponent {
void inject(MainActivity mainActivity);
}
這個時候,我們就可以在activity中使用student這個對象了。
@OnClick(R.id.b_student)
public void onViewClicked() {
Toast.makeText(this, mStudent.toString(), Toast.LENGTH_SHORT).show();
}
值得注意的是相關依賴寫好后,需要rebuild工程才能使用,因為Dagger2是使用的是RunTime注解。
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ButterKnife.bind(this);
//Rebuild Poject生成的類 注入到MainActivity中
DaggerMainActivityComponent.create().inject(this);
}
文中的代碼已上傳至github
Dagger2Demo