diff options
author | Clyhtsuriva <aimeric@adjutor.xyz> | 2021-02-20 16:43:50 +0100 |
---|---|---|
committer | Clyhtsuriva <aimeric@adjutor.xyz> | 2021-02-20 16:43:50 +0100 |
commit | 1eb274dcaaf1ee5f79505da935afcd89856e21fd (patch) | |
tree | 8a15beb7ae2107a14da4d8a12bf8daf56c203f63 /app/src/main/java/xyz/adjutor/aniki/topanime | |
parent | 893c9110c99cff286011e3d35acb39ba65a97476 (diff) |
Implementation of Glide.
Replace the current way by Glide for more stability.
Also allows to keep the images with sharedpreferences.
Diffstat (limited to 'app/src/main/java/xyz/adjutor/aniki/topanime')
-rw-r--r-- | app/src/main/java/xyz/adjutor/aniki/topanime/TopAnimeAdapter.kt | 36 |
1 files changed, 8 insertions, 28 deletions
diff --git a/app/src/main/java/xyz/adjutor/aniki/topanime/TopAnimeAdapter.kt b/app/src/main/java/xyz/adjutor/aniki/topanime/TopAnimeAdapter.kt index 68a2c7b..4953939 100644 --- a/app/src/main/java/xyz/adjutor/aniki/topanime/TopAnimeAdapter.kt +++ b/app/src/main/java/xyz/adjutor/aniki/topanime/TopAnimeAdapter.kt @@ -2,20 +2,15 @@ package xyz.adjutor.aniki.topanime -import android.annotation.SuppressLint -import android.graphics.Bitmap -import android.graphics.BitmapFactory -import android.os.AsyncTask -import android.util.Log import android.view.LayoutInflater import android.view.View import android.view.ViewGroup import android.widget.ImageView import android.widget.TextView import androidx.recyclerview.widget.RecyclerView +import com.bumptech.glide.Glide +import com.bumptech.glide.request.RequestOptions import xyz.adjutor.aniki.R -import xyz.adjutor.aniki.topanime.TopAnime -import xyz.adjutor.aniki.topanime.TopAnimeAdapter class TopAnimeAdapter(val animeList: List<TopAnime>) : RecyclerView.Adapter<TopAnimeAdapter.AnimeViewHolder>() { @@ -26,7 +21,6 @@ class TopAnimeAdapter(val animeList: List<TopAnime>) : val animeRank: TextView = itemView.findViewById(R.id.tv_rank) val animeScore: TextView = itemView.findViewById(R.id.tv_score) val animeImage: ImageView = itemView.findViewById(R.id.iv_image) - } // Returns a new ViewHolder @@ -48,27 +42,13 @@ class TopAnimeAdapter(val animeList: List<TopAnime>) : holder.animeTitle.text = currentAnime.title holder.animeRank.text = currentAnime.rank.toString() holder.animeScore.text = currentAnime.score.toString() - DownloadImageFromInternet(holder.animeImage).execute(currentAnime.image_url) + val image : String = currentAnime.image_url.toString() + Glide + .with(holder.itemView.context) + .load(image) + .apply(RequestOptions().override(400)) + .into(holder.animeImage) } - @SuppressLint("StaticFieldLeak") - private inner class DownloadImageFromInternet(var imageView: ImageView) : AsyncTask<String, Void, Bitmap?>() { - override fun doInBackground(vararg urls: String): Bitmap? { - val imageURL = urls[0] - var image: Bitmap? = null - try { - val `in` = java.net.URL(imageURL).openStream() - image = BitmapFactory.decodeStream(`in`) - } - catch (e: Exception) { - Log.e("Error Message", e.message.toString()) - e.printStackTrace() - } - return image - } - override fun onPostExecute(result: Bitmap?) { - imageView.setImageBitmap(result) - } - } } |