I am facing following problems with given code:
- Images reload when I scroll back the recyclerview
- Wrong thumbnails are loaded(they keep changing when I scroll back and forth)
- UI hangs(I tried threading but problem is still there)
These problems are not present for video files(else part of outer if)
Inside videoadapter:
if(videoFiles.get(position).getType().equals(MediaStore.Files.FileColumns.MEDIA_TYPE_AUDIO+"")){
if(coverpicture(videoFiles.get(position).getPath())!=null) {
Glide.with(mContext)
.load(coverpicture(videoFiles.get(position).getPath()))
.diskCacheStrategy(DiskCacheStrategy.ALL)
.placeholder(circularProgressDrawable)
.into(holder.thumbnail);
}
else {
Glide.with(mContext)
.load(new File(videoFiles.get(position).getPath()))
.placeholder(R.drawable.ic_baseline_music_note)
.into(holder.thumbnail);
}
} else {
Glide.with(mContext)
.load(new File(videoFiles.get(position).getPath()))
.placeholder(circularProgressDrawable)
.into(holder.thumbnail);
}
This is how I call videoadapter:
videoAdapter = new VideoAdapter(getActivity(),videoFiles);
The function coverpicture:
private Bitmap coverpicture(String path) {
final MediaMetadataRetriever[] mr = new MediaMetadataRetriever[1];
final byte[][] byte1 = new byte[1][1];
Thread ttt = new Thread(){
@Override
public void run() {
super.run();
mr[0] = new MediaMetadataRetriever();
mr[0].setDataSource(path);
byte1[0] = mr[0].getEmbeddedPicture();
mr[0].release();
}
};
ttt.start();
while(true){
if(!ttt.isAlive()){
if(byte1[0] != null) {
return BitmapFactory.decodeByteArray(byte1[0], 0, byte1[0].length);
}
else {
return null;
}
}
}
}
EDit: wrong thumbnail problem is solved when I replace first glide statement with
(it would be useful if someone explained why)
Glide.with(mContext)
.load(coverpicture(videoFiles.get(position).getPath()))
.diskCacheStrategy(DiskCacheStrategy.ALL)
.placeholder(circularProgressDrawable)
.into(new DrawableImageViewTarget(holder.thumbnail));