web-dev-qa-db-fra.com

Glide montrant une erreur: Impossible de trouver GeneratedAppGlideModule

J'essaie de charger une image à l'aide de la carte mais de toute façon, je ne peux pas charger l'image à l'aide de la carte. Comme cela montre l'erreur suivante:

Impossible de trouver GeneratedAppGlideModule. Vous devez inclure une dépendance de compilation annotationProcessor sur com.github.bumptech.glide: compiler dans votre application et une implémentation AppGlideModule annotée @GlideModule ou LibraryGlideModules seront ignorés en mode silencieux.

J'ai renvoyé Cette solution aussi. Mais, j'ai déjà la version mise à jour de glide.

Dans mon grade, j'ai ajouté 

implementation 'com.github.bumptech.glide:glide:4.7.1'

et 

annotationProcessor 'com.github.bumptech.glide:compiler:4.7.1'

Code

XML

<?xml version="1.0" encoding="utf-8"?>

<layout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    xmlns:app="http://schemas.Android.com/apk/res-auto"
    xmlns:tools="http://schemas.Android.com/tools"
    tools:context=".view.SettingActivity">

    <data>
        <variable
            name="settingsViewModel"
            type="com.sevenbits.Android.mvvmsample.viewmodel.SettingsViewModel"/>

    </data>

    <ScrollView
        Android:layout_width="match_parent"
        Android:layout_height="match_parent"
        Android:background="@drawable/splash_bg">

        <Android.support.constraint.ConstraintLayout
            Android:layout_width="match_parent"
            Android:layout_height="wrap_content">

            <LinearLayout
                Android:id="@+id/profile"
                Android:layout_width="match_parent"
                Android:layout_height="wrap_content"
                Android:layout_margin="20dp"
                Android:background="@color/white"
                Android:elevation="10dp"
                Android:orientation="vertical"
                Android:padding="5dp"
                app:layout_constraintLeft_toLeftOf="parent"
                app:layout_constraintRight_toRightOf="parent"
                app:layout_constraintTop_toTopOf="parent">

                <de.hdodenhof.circleimageview.CircleImageView
                    Android:layout_width="100dp"
                    Android:layout_height="100dp"
                    Android:layout_gravity="center"
                    Android:layout_margin="10dp"
                    app:image_url="@{settingsViewModel.imageUrl}"
                    app:civ_border_width="2dp"
                    app:civ_border_color="@color/colorPrimary"/>

                  ...
            </LinearLayout>

    </Android.support.constraint.ConstraintLayout>

</ScrollView>

CustomBindingAdapter

public class CustomBindingAdapter {

@BindingAdapter({"bind:image_url"})
public static void loadImage(ImageView imageView, String url) {

    RequestOptions requestOptions = new RequestOptions();
    requestOptions=requestOptions.placeholder(R.drawable.boy_32);

        Glide.with(imageView.getContext())
                .load(url)
                .apply(requestOptions)
                .into(imageView);
}
9
Riddhi

Enfin, j'ai trouvé ma réponse ici .

Ce que j'ai fait :

Étape 1

J'ai créé une classe vide nommée MyGlideApp

import com.bumptech.glide.annotation.GlideModule;
import com.bumptech.glide.module.AppGlideModule;

@GlideModule
public class MyGlideApp extends AppGlideModule {

}

Remarque: N'oubliez pas d'ajouter l'annotation @GlideModule.

Step-2 Après cela, je construis/reconstruis le projet, puis je remplace Glide par GlideApp. Et maintenant plus besoin d'utiliser RequestOptions

public class CustomBindingAdapter {

    @BindingAdapter({"bind:image_url"})
    public static void loadImage(ImageView imageView, String url) {

//        RequestOptions requestOptions = new RequestOptions();
//        requestOptions=requestOptions.placeholder(R.drawable.boy_32);

        GlideApp.with(imageView.getContext())
                .load(url)
                .placeholder(R.drawable.boy_32)
                .into(imageView);

//            Glide.with(imageView.getContext())
//                    .load(url)
//                    .apply(requestOptions)
//                    .into(imageView);
    }
}

C'est tout.

23
Riddhi

Solution Kotlin:

Assurez-vous d’ajouter ce qui suit dans votre fichier gradle (remplacez annotationProcessor par kapt source ):

repositories {
  mavenCentral()
  google()
}

dependencies {
    implementation 'com.github.bumptech.glide:glide:4.8.0'
    kapt 'com.github.bumptech.glide:compiler:4.8.0'
}


Ajoutez une implémentation de AppGlideModule dans votre application GlideSource (vous pouvez remplacer les méthodes par défaut overrideSource ): 

import Android.content.Context
import com.bumptech.glide.GlideBuilder
import com.bumptech.glide.annotation.GlideModule
import com.bumptech.glide.load.engine.DiskCacheStrategy
import com.bumptech.glide.module.AppGlideModule
import com.bumptech.glide.request.RequestOptions
import com.bumptech.glide.signature.ObjectKey

@GlideModule
class AppNameGlideModule : AppGlideModule() {

    override fun applyOptions(context: Context, builder: GlideBuilder) {
        super.applyOptions(context, builder)
        builder.apply { RequestOptions().diskCacheStrategy(DiskCacheStrategy.ALL).signature(ObjectKey(System.currentTimeMillis().toShort())) }
    }

}


Lorsque vous utilisez glide, utilisez GlideApp au lieu de Glide, exemple:

GlideApp.with(context)
            .load(url)
            .into(imageView)
3
Arshak

En plus de la réponse de Ridhi:

Pour que cela fonctionne correctement, je devais inclure isManifestParsingEnabled.

import com.bumptech.glide.annotation.GlideModule;
import com.bumptech.glide.module.AppGlideModule;

@GlideModule
public class MyGlideApp extends AppGlideModule {

    @Override
    public boolean isManifestParsingEnabled() {
        return false;
    }

}
1
Max