Ich versuche ein Bild mit Gleiten zu laden, aber irgendwie kann ich das Bild nicht mit Gleiten laden. Da zeigt sich folgender Fehler:
GeneratedAppGlideModule konnte nicht gefunden werden. Sie sollten eine AnnotationProcessor-Kompilierabhängigkeit von com.github.bumptech.glide: Compiler in Ihre Anwendung aufnehmen und eine @GlideModule-annotierte AppGlideModule-Implementierung oder LibraryGlideModules werden automatisch ignoriert.
Ich habe Diese Lösung auch. Aber ich habe bereits die aktualisierte Version von Glide.
In meinem Abschluss habe ich hinzugefügt
implementation 'com.github.bumptech.glide:glide:4.7.1'
und
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);
}
Schließlich fand ich meine Antwort hier .
Was ich getan habe :
Schritt 1
Ich habe eine leere Klasse mit dem Namen MyGlideApp
erstellt.
import com.bumptech.glide.annotation.GlideModule;
import com.bumptech.glide.module.AppGlideModule;
@GlideModule
public class MyGlideApp extends AppGlideModule {
}
Hinweis: Vergessen Sie nicht, die Anmerkung @GlideModule
hinzuzufügen.
Schritt-2 Danach baue ich das Projekt neu/baue es neu auf und ersetzte dann Glide
durch GlideApp
. Jetzt muss RequestOptions
nicht mehr verwendet werden.
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);
}
}
Das ist alles.
Ich habe dieses Problem mit Glide:4.9.0
Mit AndroidX konfrontiert
hat es so gelöst
In deinen gradle.propertiesAndroid.useAndroidX = true
Android.enableJetfier=true
In deinem build.gradle//Glide dependency implementation 'com.github.bumptech.glide:glide:4.9.0' annotationProcessor 'com.github.bumptech.glide:compiler:4.9.0'
Dann füge dein CustomGlideModule
hinzu@GlideModule public class CustomeGlideModule extends AppGlideModule {}
Der letzte Schritt generiert das GlideModule
Build >> Make Project und Sie sollten das generierte Modul in Ihrem Build-Ordner sehen
Kotlin-Lösung:
Stellen Sie sicher, dass Sie Folgendes in Ihre gradle-Datei einfügen (ersetzen Sie annotationProcessor durch kapt source ):
repositories {
mavenCentral()
google()
}
dependencies {
implementation 'com.github.bumptech.glide:glide:4.8.0'
kapt 'com.github.bumptech.glide:compiler:4.8.0'
}
Fügen Sie AppGlideModule -Implementierung in Ihrer Anwendung GlideSource (Sie können die Standardmethoden overrideSource überschreiben):
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())) }
}
}
Verwenden Sie bei der Verwendung von glide GlideApp anstelle von Glide. Beispiel:
GlideApp.with(context)
.load(url)
.into(imageView)
Alle obigen Antworten sind wahr und funktionieren einwandfrei
aber ich bemerkte, wenn ich # placeholder und # error verwendete, funktionierte der Glide ohne build GlideModule Klasse wie oben erwähnt
Beispiel: Bei Verwendung von glide ist dies kein Word und give muss bauen GlideModule
Glide.with(this)
.load(uri)
.into(imageView);
und das ist gut so
Glide.with(this).load(uri).placeholder(Android.R.drawable.progress_indeterminate_horizontal).error(Android.R.drawable.stat_notify_error).into(imageView);
Neben Ridhis Antwort:
Damit es richtig funktioniert, musste ich isManifestParsingEnabled
einschließen.
import com.bumptech.glide.annotation.GlideModule;
import com.bumptech.glide.module.AppGlideModule;
@GlideModule
public class MyGlideApp extends AppGlideModule {
@Override
public boolean isManifestParsingEnabled() {
return false;
}
}