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);
}
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.
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)
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;
}
}