Android get Drawable image после загрузки picasso

Я использую библиотеку Picasso для загрузки изображения с URL-адреса. Код, который я использовал, приведен ниже.

Picasso.with(getContext()).load(url).placeholder(R.drawable.placeholder)
                .error(R.drawable.placeholder).into(imageView);

Что я хочу сделать, так это получить изображение, загруженное с URL-адреса. Я использовал

Drawable image = imageView.getDrawable();

Однако, это всегда будет возвращать образ заполнителя вместо загрузки изображения из url. У вас есть идеи? Как мне получить доступ к извлекаемому изображению, которое оно просто загрузило с URL-адреса.

Спасибо заранее.

Ответ 1

Это происходит потому, что изображение загружается асинхронно. Вам нужно получить доступный, когда он будет загружен в представление:

   Target target = new Target() {
          @Override
          public void onBitmapLoaded(Bitmap bitmap, Picasso.LoadedFrom from) {
              imageView.setImageBitmap(bitmap);
              Drawable image = imageView.getDrawable();
          }

        @Override
        public void onBitmapFailed(Drawable errorDrawable) {}

        @Override
        public void onPrepareLoad(Drawable placeHolderDrawable) {}
   };

   Picasso.with(this).load("url").into(target);

Ответ 2

        mImageView.post(new Runnable() {
            @Override
            public void run() {
                mPicasso = Picasso.with(mImageView.getContext());
                mPicasso.load(IMAGE_URL)
                        .resize(mImageView.getWidth(), mImageView.getHeight())
                        .centerCrop()
                        .into(mImageView, new com.squareup.picasso.Callback() {
                            @Override
                            public void onSuccess() {
                                Drawable drawable = mImageView.getDrawable();
                                // ...
                            }

                            @Override
                            public void onError() {
                                // ...
                            }
                        });
            }
        });