Как убрать задержку при загрузке изображений с сервера при использовании glide? - PullRequest
0 голосов
/ 10 апреля 2019

У меня есть активность с recyclerView внутри, я хочу загрузить изображения с сервера и показать их в recyclerView, используя библиотеку glide.

Изображения имеют разный размер (600x400, 900x1360, ...).

Проблема: при быстрой прокрутке вниз или вверх происходит задержка при загрузке и показе изображений:

снимок экрана

Что я могу сделать, чтобы устранить эту раздражающую задержку?

Активность xml:

<android.support.constraint.ConstraintLayout 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"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <android.support.v7.widget.RecyclerView
        android:id="@+id/act_main_recycler"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_marginTop="16dp"
        android:layout_marginBottom="16dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

</android.support.constraint.ConstraintLayout>

recyclerView items xml:

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginBottom="8dp"
    android:background="@color/colorPrimary">


    <TextView
        android:id="@+id/textView"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginLeft="32dp"
        android:layout_marginTop="16dp"
        android:layout_marginRight="32dp"
        android:text="Image Name"
        android:textColor="@android:color/white"
        android:textSize="18sp"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <ImageView
        android:id="@+id/postImage"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginTop="16dp"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toBottomOf="@id/textView" />

</android.support.constraint.ConstraintLayout>

onBindViewHolder в адаптере recyclerView:

@Override
    public void onBindViewHolder(@NonNull Image_ViewHolder holder, int position) {

        Glide.with(context)
                .load(addresses.get(position))
                .into(holder.postImage);

    }

пс.если я установлю фиксированный размер для imageView (например, 600 x 400), проблема будет решена, но я хочу изображение в оригинальном размере.

1 Ответ

0 голосов
/ 10 апреля 2019

Замените код Glide следующим:

Glide.with(context).load(addresses.get(position))
                    .override(nWidth, Target.SIZE_ORIGINAL)                       
                    .apply(RequestOptions.diskCacheStrategyOf(DiskCacheStrategy.ALL))
                    .into(holder.imgLogo);

nWidth = Измените размер изображения в пиксельном пикселе.(Пример 200)

И еще одно предложение по вашей проблеме, если вы можете получить размер изображения, а затем применить этот размер в качестве высоты и ширины ImageView.

...