web-dev-qa-db-ja.com

com.bumptech.glide.Registry $ NoModelLoaderAvailableException:ModelLoaderを見つけることができませんでした

カスタムモデルをGlideにロードしようとしていますが、次のエラーが発生します。

GlideExecutor:リクエストがキャッチされなかったスロー可能なcom.bumptech.glide.Registry $ NoModelLoaderAvailableExceptionをスローしました:モデルのModelLoaderが見つかりませんでした:com.company.project.glide.Movie@aac331a

グライドバージョン:4.0.0

私のコード:

モデル

public class Movie {
    private String name;
    private String artist;

    public Movie(String name, String artist) {
        this.name = name;
        this.artist = artist;
    }

    public String getName() {
        return name;
    }

    public String getArtist() {
        return artist;
    }
}

モジュール

@com.bumptech.glide.annotation.GlideModule
public class GlideModule  extends AppGlideModule {

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

    @Override
    public void applyOptions(Context context, GlideBuilder builder) {
        super.applyOptions(context, builder);
    }

    @Override
    public void registerComponents(Context context, Registry registry) {
        registry.append(Movie.class, InputStream.class, new MovieArtModel.Factory());
    }
}

ModelLoader

public class MovieArtModel implements ModelLoader<Movie, InputStream> {

    @Nullable
    @Override
    public LoadData<InputStream> buildLoadData(Movie movie, int width, int height, Options options) {
        Timber.d("buildLoadData: ");
        return new LoadData<>(new ObjectKey(movie), new MovieArtLoader(movie, width, height));
    }


    @Override
    public boolean handles(Movie movie) {
        return false;
    }

    public static class Factory implements ModelLoaderFactory<Movie, InputStream> {

        @Override
        public ModelLoader<Movie, InputStream> build(MultiModelLoaderFactory multiFactory) {
            return new MovieArtModel();
        }

        @Override
        public void teardown() {
        }
    }


    static class MovieArtLoader implements DataFetcher<InputStream> {
        private Movie movie;
        private boolean isCancelled = false;
        private int widthSize;
        private int heightSize;

        MovieArtLoader(Movie movie, int widthSize, int heightSize) {
            Timber.d("MovieArtLoader: Initializing...width size = " + widthSize + " :: heightSize = " + heightSize);
            this.movie = movie;
            this.widthSize = widthSize;
            this.heightSize = heightSize;
        }

        @Override
        public void loadData(Priority priority, DataCallback<? super InputStream> callback) {
            Timber.d("loadData");

            //First check if request is not cancelled before starting request
            if(!isCancelled()) {
                InputStream inputStream = getMovieArtInputStream(movie);
                if (inputStream != null) {
                    callback.onDataReady(inputStream);
                } else {
                    callback.onLoadFailed(new IOException("Forced Glide network failure. Can't load Movie image"));
                }


            }
        }
            return null;
        }



        @Override public void cleanup() {
            Timber.d("cleanup: ");
        }


        @Override public void cancel() {
            Timber.d("cancel: ");
            isCancelled = true;
        }

        @Override
        public Class<InputStream> getDataClass() {
            return null;
        }

        @Override
        public DataSource getDataSource() {
            return null;
        }

        private boolean isCancelled() {
            return isCancelled;
        }
    }

それから私はそれをこうしてロードしています:

GlideApp.with(itemView.getContext())
                .asBitmap()
                .load(new Movie(book.getMovieName(), book.getArtist()))
                .placeholder(R.drawable.movie_default_small)
                .diskCacheStrategy(DiskCacheStrategy.RESOURCE)
                .listener(this)
                .into(imageView);

どこが間違っているのですか?


編集

以下の答えを適用しましたが、NPEを取得し始めました。これはスタックトレースです:

E/GlideExecutor: Request threw uncaught throwable
                                                                        Java.lang.NullPointerException: Attempt to invoke virtual method 'int Java.lang.Object.hashCode()' on a null object reference
                                                                            at com.bumptech.glide.util.MultiClassKey.hashCode(MultiClassKey.Java:66)
                                                                            at Android.support.v4.util.SimpleArrayMap.indexOfKey(SimpleArrayMap.Java:320)
                                                                            at Android.support.v4.util.SimpleArrayMap.get(SimpleArrayMap.Java:360)
                                                                            at com.bumptech.glide.provider.LoadPathCache.get(LoadPathCache.Java:34)
                                                                            at com.bumptech.glide.Registry.getLoadPath(Registry.Java:132)
                                                                            at com.bumptech.glide.load.engine.DecodeHelper.getLoadPath(DecodeHelper.Java:132)
                                                                            at com.bumptech.glide.load.engine.DecodeHelper.hasLoadPath(DecodeHelper.Java:128)
                                                                            at com.bumptech.glide.load.engine.SourceGenerator.startNext(SourceGenerator.Java:59)
                                                                            at com.bumptech.glide.load.engine.DecodeJob.runGenerators(DecodeJob.Java:282)
                                                                            at com.bumptech.glide.load.engine.DecodeJob.runWrapped(DecodeJob.Java:252)
                                                                            at com.bumptech.glide.load.engine.DecodeJob.run(DecodeJob.Java:222)
                                                                            at Java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.Java:1112)
                                                                            at Java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.Java:587)
                                                                            at Java.lang.Thread.run(Thread.Java:818)
                                                                            at com.bumptech.glide.load.engine.executor.GlideExecutor$DefaultThreadFactory$1.run(GlideExecutor.Java:347)
10
X09

NoModelLoaderAvailableException特定のモデルクラスに{@ linkcom.bumptech.glide.load.model.ModelLoader}が登録されておらず、@ talkLittleの回答で修正され、そのムービーにequals()およびhashCode()を使用して、キャッシュを正しく機能させます。

新しい[〜#〜] npe [〜#〜]は、@Nullable@NonNullアノテーションを試行することを受け入れたために発生しました。

2
user6490462
@Override
public boolean handles(Movie movie) {
    return true;
}

これを行う必要があります。そうしないと、GlideはModelLoaderを無視し、提供されたMovieモデルを処理しないと考えます。

5
TalkLittle