Отображение изображений в RecyclerView с использованием Picasso (или Glide) и дооснащения, только для аутентифицированных пользователей - PullRequest
0 голосов
/ 22 февраля 2019

Я использую RecyclelerView для отображения моих контактов и отображения их основных данных, включая изображения пользователей.Он работает как надо, Picasso великолепен, и я получаю очень крутой список.

Сейчас я пытаюсь отключить просмотр изображений пользователями до тех пор, пока они не будут проверены, т.е. я хочу отключить просмотр изображений для всех, кто неаутентифицированный пользователь.Я сделал это на своих сервисах и отключил всех, кроме моего приложения laravel, чтобы открыть ссылку на изображение.Теперь я сталкиваюсь с одной проблемой - когда я возвращаю изображение, это не ссылка, а в формате byte[], и я не могу отобразить его с помощью Picasso.Я мог бы попытаться преобразовать его в Bitmap bitmap = BitmapFactory.decodeByteArray(bytes, 0, bytes.length);, а затем преобразовать растровое изображение в нарисованное как: Drawable drawable = new BitmapDrawable(getResources(), bitmap);, а затем отобразить нарисованное как изображение imageView.setImageDrawable(drawable);, но, прочитав это, я обнаружил немало недостатков.

Мой вопросбыло бы , что является лучшим способом для отображения изображения с использованием Picasso или Glide, и модифицировать, чтобы возвращать изображения только для аутентифицированных пользователей .Есть ли другой способ вернуть изображение из сервиса laravel?Есть ли способ использовать байтовый формат с Picasso или Glide?Или есть другой формат, который я могу преобразовать в свой byte[] для отображения в представлении реселлера, который не окажет негативного влияния на производительность?

В настоящее время отображение изображения с Пикассо в моем ContactsAdapter:

@Override
public void onBindViewHolder(ContactsAdapter.ContactsViewHolder holder, int position) {
    Contact contact = contactList.get(position);

    holder.userName.setText(contact.getUserName());

    TextDrawable.IBuilder builder = TextDrawable.builder()
            .beginConfig()
            .withBorder(0)
            .toUpperCase()
            .endConfig()
            .round();

    ColorGenerator generator = ColorGenerator.MATERIAL;
    int color = generator.getColor(contact.getUserId());
    textDrawable = builder.build(contactList.get(position).getUserName().substring(0, 1), color);
    holder.thumbNail.setImageDrawable(textDrawable);

    Picasso.with(context)
            .load(AppConfig.URL_PROFILE_PHOTO + contact.getThumbnailUrl()) // DISK URL WITH USER IMAGE NAME
            .placeholder(textDrawable)
            .error(textDrawable)
            .transform(new CircleTransform())
            .into(holder.thumbNail);
}

Laravelсервис преобразует ссылку на изображение следующим образом:

return Image::make($storagePath)->response();

Я извлек метод ProfileImage и попытался изменить его, чтобы использовать полученный мной сервис:

private void ProfileImage(HashMap<String, String> user, String name, String id) {
    TokenManager tokenManager = TokenManager.getInstance(getSharedPreferences("prefs", MODE_PRIVATE));
    ApiInterface apiService = ApiClient.createServiceWithAuth(ApiInterface.class, tokenManager);

    ColorGenerator generator = ColorGenerator.MATERIAL;
    int color = generator.getColor(id);
    String firstLetter = name.substring(0, 1);
    TextDrawable textDrawable = TextDrawable.builder().buildRect(firstLetter, color);
    holder.thumbNail.setImageDrawable(textDrawable);

    Call<ResponseBody> call = apiService.getUserImage(id);
    call.enqueue(new Callback<ResponseBody>() {
        @Override
        public void onResponse(Call<ResponseBody> call, retrofit2.Response<ResponseBody> response) {

            if (response.isSuccessful()) {
                byte[] bytes = new byte[0];
                try {
                    bytes = response.body().bytes();

                    Picasso.with(getApplicationContext())
                            .load(/** I CANNOT USE THE URL HERE */)
                            .placeholder(textDrawable)
                            .error(textDrawable)
                            .centerCrop()
                            .fit()
                            .into(holder.thumbNail);
                } catch (IOException e) {
                    e.printStackTrace();
                }
            } else {
                if (response.code() == 401) {
                    finish();
                } else {
                    Log.d(TAG, "There was an error: " + response);
                }
            }
        }

        @Override
        public void onFailure(Call<ResponseBody> call, Throwable t) {
            Log.e(TAG, t.toString());
        }
    });
}

1 Ответ

0 голосов
/ 04 марта 2019

Если вы можете переключиться на Glide, вы можете использовать Glide.with().load(byte[] model) напрямую

bytes = response.body().bytes();

Glide.with(getApplicationContext())
     .load(bytes)
     .placeholder(textDrawable)
     .error(textDrawable)
     .centerCrop()
     .fitCenter()
     .into(holder.thumbNail);
...