Presenter не может быть предоставлен без аннотированного метода @Provides или @Produces | Android | Кинжал 2
Я работаю с архитектурой Viper MVP Code -
Когда я компилирую код, я получаю эту ошибку:
Error:(32, 10) error: com.tv.goin.activities.login.LoginMvpPresenter<com.tv.goin.activities.logi n.LoginMvpView,com.tv.goin.activities.login.LoginMvpInteractor>
cannot be provided without an @Provides- or @Produces-annotated method.
com.tv.goin.activities.login.LoginMvpPresenter<com.tv.goin.activities.login.LoginMvpView,com.tv.goin.activities.login.LoginMvpInteractor> is injected at
com.tv.goin.activities.login.LoginActivity.mPresenter
com.tv.goin.activities.login.LoginActivity is injected at
com.tv.goin.di.component.ActivityComponent.inject(activity)
Вот мой файл Gradle -
apply plugin: 'com.android.application'
//apply plugin: 'com.neenbedankt.android-apt'
android {
compileSdkVersion rootProject.ext.compileSdkVersion
buildToolsVersion rootProject.ext.buildToolsVersion
defaultConfig {
applicationId "com.tv.goin"
minSdkVersion rootProject.ext.minSdkVersion
targetSdkVersion rootProject.ext.targetSdkVersion
versionCode 1
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
vectorDrawables.useSupportLibrary = true
}
buildTypes {
debug {
buildConfigField("String", "BASE_URL", "\"http://www.mocky.io/v2\"")
buildConfigField("String", "API_KEY", "\"ABCXYZ123TEST\"")
}
release {
minifyEnabled true
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
buildConfigField("String", "BASE_URL", "\"http://www.mocky.io/v2\"")
buildConfigField("String", "API_KEY", "\"ABCXYZ123TEST\"")
}
}
}
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
// android support libraries
compile "com.android.support:appcompat-v7:$rootProject.supportLibraryVersion"
compile "com.android.support:recyclerview-v7:$rootProject.supportLibraryVersion"
compile "com.android.support:cardview-v7:$rootProject.supportLibraryVersion"
compile "com.android.support:design:$rootProject.supportLibraryVersion"
compile "com.android.support:support-vector-drawable:$rootProject.supportLibraryVersion"
compile "com.android.support:animated-vector-drawable:$rootProject.supportLibraryVersion"
// font
compile "uk.co.chrisjenx:calligraphy:$rootProject.calligraphyVersion"
// network
compile "com.amitshekhar.android:rx2-android-networking:$rootProject.rx2FastAndroidNetworking"
// image
compile "com.github.bumptech.glide:glide:$rootProject.glideVersion"
// parser
compile "com.google.code.gson:gson:$rootProject.gsonVersion"
// database
compile "org.greenrobot:greendao:$rootProject.greenDaoVersion"
// debug database
debugCompile "com.amitshekhar.android:debug-db:$rootProject.debugDBVersion"
// dependency injection
compile "com.google.dagger:dagger:$rootProject.dagger2Version"
annotationProcessor "com.google.dagger:dagger-compiler:$rootProject.dagger2Version"
provided 'javax.annotation:jsr250-api:1.0'
compile 'javax.inject:javax.inject:1'
// reactive
compile "io.reactivex.rxjava2:rxjava:$rootProject.rxjava2Version"
compile "io.reactivex.rxjava2:rxandroid:$rootProject.rxandroidVersion"
// code generator for view
compile "com.jakewharton:butterknife:$rootProject.butterKnifeVersion"
annotationProcessor "com.jakewharton:butterknife-compiler:$rootProject.butterKnifeVersion"
// swipe view
compile "com.mindorks:placeholderview:$rootProject.placeholderviewVersion"
// logger
compile "com.jakewharton.timber:timber:$rootProject.timberVersion"
// dependencies for local unit tests
testCompile "junit:junit:$rootProject.ext.junitVersion"
testCompile "org.mockito:mockito-core:$rootProject.mockitoVersion"
testAnnotationProcessor "com.google.dagger:dagger-compiler:$rootProject.dagger2Version"
// UI Testing
androidTestCompile "com.android.support.test.espresso:espresso-core:$rootProject.espressoVersion"
androidTestCompile "com.android.support.test.espresso:espresso-intents:$rootProject.espressoVersion"
androidTestCompile "org.mockito:mockito-core:$rootProject.mockitoVersion"
androidTestAnnotationProcessor "com.google.dagger:dagger-compiler:$rootProject.dagger2Version"
}
configurations.all {
resolutionStrategy.force "com.android.support:support-annotations:$supportLibraryVersion"
}
Вот мой корневой уровень Gradle -
// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.3.0'
// classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
jcenter()
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
// Define versions in a single place
ext {
// Sdk and tools
minSdkVersion = 16
targetSdkVersion = 25
compileSdkVersion = 25
buildToolsVersion = '25.0.2'
// App dependencies
supportLibraryVersion = '25.3.1'
gsonVersion = '2.8.0'
calligraphyVersion = '2.2.0'
glideVersion = '3.7.0'
rx2FastAndroidNetworking = '1.0.0'
dagger2Version = '2.8'
rxjava2Version = '2.0.6'
rxandroidVersion = '2.0.1'
butterKnifeVersion = '8.6.0'
greenDaoVersion = '3.2.0'
placeholderviewVersion = '0.6.1'
debugDBVersion = '1.0.0'
timberVersion = '4.5.1'
//Test dependencies
junitVersion = '4.12'
espressoVersion = '2.2.2'
mockitoVersion = '2.7.1'
}
РЕДАКТИРОВАТЬ
Класс LoginMvpPresenter
пакет com.tv.goin.activities.login;
import com.tv.goin.BaseClasses.MvpPresenter; import com.tv.goin.di.PerActivity; /** * Created by Shoeb on 26/7/17. */ @PerActivity public interface LoginMvpPresenter<V extends LoginMvpView, I extends LoginMvpInteractor> extends MvpPresenter<V,I> { }
1 ответ
Поскольку я не знаю структуру вашего графа зависимостей или то, как вы вводите эти зависимости, я могу привести только общий пример. Также я не совсем уверен, как это работает с обобщениями, которые вы указали в вашем интерфейсе.
Вы пытаетесь предоставить интерфейс, который не имеет реализации. Вам нужно определить объект, который вы собираетесь вернуть, который реализует ваш интерфейс в Module
, Поскольку этот интерфейс Presenter
Я предполагаю, что это используется в Деятельности или Фрагменте.
В вашем Activity
создайте внутренний класс, как показано ниже:
@dagger.Module
class Module {
@Provides
public LoginMvpPresenter<Class> providesPresenter() {
return new LoginMvpPresenterImpl();
}
}
Затем также в качестве внутреннего интерфейса создайте компонент.
@dagger.Component {
dependencies = AppComponent.class,
modules = {
Module.class
}
}
interface Component {
void inject(MyActivity activity);
}
Теперь ваша деятельность знает, как создать зависимость и где ее внедрить, все, что вам нужно сделать, это внедрить ваш класс, что вы можете сделать из onCreate
из вас Activity
вот так.
DaggerMyActivity_Component.builder()
.appComponent(getAppComponent())
.build()
.inject(this);
Теперь вы можете использовать @Inject
аннотации и объявить вашего докладчика как поле вашего Activity
учебный класс.