mirror of
https://codeberg.org/Bazsalanszky/Infinity-For-Lemmy.git
synced 2025-01-26 17:44:45 +01:00
Improve video preview loading time
This commit improves the loading time of posts with videos on the feed. Closes #242
This commit is contained in:
parent
706f51c4f5
commit
b9e61518a4
@ -9,7 +9,7 @@ import eu.toldi.infinityforlemmy.apis.RedgifsAPI;
|
||||
import eu.toldi.infinityforlemmy.post.enrich.CompositePostEnricher;
|
||||
import eu.toldi.infinityforlemmy.post.enrich.PostEnricher;
|
||||
import eu.toldi.infinityforlemmy.post.enrich.RedGifsPostEnricher;
|
||||
import eu.toldi.infinityforlemmy.post.enrich.VideoPostEnricher;
|
||||
|
||||
|
||||
@Module
|
||||
abstract class PostEnricherModule {
|
||||
@ -20,12 +20,6 @@ abstract class PostEnricherModule {
|
||||
return new RedGifsPostEnricher(redgifsAPI);
|
||||
}
|
||||
|
||||
@Provides
|
||||
@IntoSet
|
||||
static PostEnricher provideVideoPostEnricher() {
|
||||
return new VideoPostEnricher();
|
||||
}
|
||||
|
||||
@Provides
|
||||
static PostEnricher providePostEnricher(Set<PostEnricher> postEnrichers) {
|
||||
return new CompositePostEnricher(postEnrichers);
|
||||
|
@ -249,7 +249,8 @@ public class ParsePost {
|
||||
|
||||
post = new Post(id, communityInfo, author, postTimeMillis, title, permalink, downvotes, upvotes, postType, voteType,
|
||||
nComments, upvoteRatio, nsfw, locked, saved, deleted, distinguished, suggestedSort);
|
||||
|
||||
Post.Preview preview = new Post.Preview(url, 0, 0, "", "");
|
||||
post.setPreviews(new ArrayList<>(List.of(preview)));
|
||||
post.setVideoUrl(url);
|
||||
post.setVideoDownloadUrl(url);
|
||||
} else if (!url.equals("")) {
|
||||
|
@ -1,43 +0,0 @@
|
||||
package eu.toldi.infinityforlemmy.post.enrich
|
||||
|
||||
import android.media.MediaMetadataRetriever
|
||||
import android.util.Log
|
||||
import eu.toldi.infinityforlemmy.post.Post
|
||||
|
||||
class VideoPostEnricher : PostEnricher {
|
||||
override fun enrich(posts: Collection<Post>) {
|
||||
for (post in posts) {
|
||||
if (post.postType != Post.VIDEO_TYPE || post.previews.isNotEmpty()) {
|
||||
continue
|
||||
}
|
||||
|
||||
val url = post.videoUrl ?: continue
|
||||
if (!url.endsWith(".mp4", ignoreCase = true) &&
|
||||
!url.endsWith(".webm", ignoreCase = true)
|
||||
) {
|
||||
continue
|
||||
}
|
||||
|
||||
val retriever = try {
|
||||
MediaMetadataRetriever().apply {
|
||||
setDataSource(url);
|
||||
}
|
||||
} catch (e: Exception) {
|
||||
Log.w(TAG, "Error retrieving metadata", e)
|
||||
continue
|
||||
}
|
||||
|
||||
val width = retriever.extractMetadata(MediaMetadataRetriever.METADATA_KEY_VIDEO_WIDTH)
|
||||
?.toIntOrNull() ?: -1
|
||||
val height = retriever.extractMetadata(MediaMetadataRetriever.METADATA_KEY_VIDEO_HEIGHT)
|
||||
?.toIntOrNull() ?: -1
|
||||
|
||||
// Glide can extract thumbnails from video URLs (it uses MediaMetadataRetriever too)
|
||||
post.previews = ArrayList(listOf(Post.Preview(url, width, height, null, null)))
|
||||
}
|
||||
}
|
||||
|
||||
companion object {
|
||||
private const val TAG = "VideoPostEnricher"
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user