Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Player seekbar thumbnail preview #6434

Merged
merged 11 commits into from
Jul 19, 2021
Merged

Conversation

litetex
Copy link
Member

@litetex litetex commented Jun 5, 2021

What is it?

  • Bugfix (user facing)
  • Feature (user facing)
  • Codebase improvement (dev facing)
  • Meta improvement to the project (dev facing)

Description of the changes in your PR

Click here to show the demo (screenshots + video) data
(it's a lot so it's collapsed by default)

  • Full demo video:
demo.compressed.mp4
  • Screenshots:
    • Settings:
      settings1 settings2
    • Video seekbar thumbnail preview (high quality):
      vid_stp_hq1
      vid_stp_hq2_full
    • Video seekbar thumbnail preview (low quality):
      vid_stp_lq1
      vid_stp_lq1_full
    • Video seekbar thumbnail preview (off):
      grafik


Implementation details (click to open)

These are the major parts of this implementation:

(Meta)-Data
The metadata of a video contains a new field (the extractor had to be modified for this → TeamNewPipe/NewPipeExtractor#647 )

  • This field consists of a list of framesets (yt currently returns 2)
  • The framesets have different preview thumbnail sizes (that's why there exists the option low and high quality in the settings)
  • A frameset has urls to the preview thumbnails; a url returns an ("base") image with multiple preview thumbnails, e.g.
    prev_thumb

How it get's into the seekbar

  1. Preparing the data

The metadata is changed in the player, when a new video is played/started.

When this happens the urls get asynchronously fetched and processed, which happens mostly in SeekbarPreviewThumbnailHolder

  1. Seekbar positioning

Note: The images from the url are not "pre-processed". The extraction of the corresponding preview thumbnail and resizing happens when the seekbar is changed.

When the seekbar is moved the closest image to the current position (in ms) is searched and returned.
If none is found or an error occurs the thumbnail will simply be hidden.

After thumbnail was extracted from/cut out of the "base" image (from the url of the frameset) it will also be resized:
The size of the final thumbnail is calculated as follows:

  • absolute min-width: 100dp
  • (preferred) width: player-width / 4
  • absolute max-width: 2.5 times the original width (else it becomes too pixelated)

Settings
New option"seekbar thumbnail preview" (under Settings>Video and audio>Player)
Can contain the following values:

  • "High quality (larger)" - default
  • "Low quality (smaller)"
  • "Don't show" (a thumbnail)

The settings will be applied when the next video is started / opened or more specific when the metadata of the player is changed

Fixes the following issue(s)

Relies on the following changes

APK testing

On the website the APK can be found by going to the "Checks" tab below the title and then on "artifacts" on the right.

You may also build/test it with this manual (click to open)

Due diligence

Things that should be checked 👁️‍🗨️

Technical

I implemented these changes as good as i could think of.
However there the following topics/parts of the code should be checked carefully by the reviewers, because if it fails it may cause excessive problems:

  • thread management (a relatively simple ExecutorService is currently used, maybe there are better ways)
  • handling of the bitmaps (check for memory leaks)
  • Check the thumbnail showing logic / calculation where the seekbar preview container (thumbnail + currentTime) should be

Other behaviors and implementations that should be looked upon

  • The resizing of the thumbnail logic - I tested that on "normal" devices (Google Pixel 3a emulated), maybe some devices like tablets or TVs respond differently and the thumbnail is too small or large

@litetex litetex marked this pull request as ready for review June 5, 2021 22:53
@TobiGr TobiGr added feature request Issue is related to a feature in the app player Issues related to any player (main, popup and background) labels Jun 5, 2021
@skyGtm
Copy link

skyGtm commented Jun 6, 2021

since it shows thumbnail previews, would it be possible to implement this #6383 ?

@opusforlife2
Copy link
Collaborator

Thank you so much, @litetex! This looks awesome! And it is also one of those big features that people miss when they shift to Newpipe.

Feedback: Why are the menu options called High and Low Quality when it is actually the Preview Size that is changing? They should be called Large and Small Preview or something instead. Both with High and Low Quality, the preview images are pixelated. At least on a 1080p screen. So as a result it looks like the Large and Small Previews actually have the same quality in proportion, but for different sizes.

@litetex
Copy link
Member Author

litetex commented Jun 6, 2021

@skyGtm

since it shows thumbnail previews, would it be possible to implement this #6383 ?

For now this pr will only fix #3207 and - to not mix things up and create a monolith/"all-in-one pr monster" - #6383 should be handled as a separate feature and therefore be done in a separate pr 😄

@litetex
Copy link
Member Author

litetex commented Jun 6, 2021

@opusforlife2

Why are the menu options called High and Low Quality when it is actually the Preview Size that is changing? They should be called Large and Small Preview or something instead. Both with High and Low Quality, the preview images are pixelated. At least on a 1080p screen. So as a result it looks like the Large and Small Previews actually have the same quality in proportion, but for different sizes.

Thank you for the feedback 😄

I called them high and low quality, because yt returns 2 storyboard/seekbar thumnail sizes - high and low quality.
However I'm not quite sure how to implement these the best way and through that I used that formula:

The size of the final thumbnail is calculated as follows:

  • absolute min-width: 100px
  • (preferred) width: player-width / 4
  • absolute max-width: 2.5 times the original width (else it becomes too pixelated)

I may be revising this to make it work better with different devices (tablets, TVs, smartphones).

Currently this way it looks (at least) with "high quality" somewhat similar to the current YT behavior (on the website + app).

I think renaming these would be a good idea, I will do that when I have time again 😄

@opusforlife2
Copy link
Collaborator

Ohkay. I don't know what it looks like on Youtube, but if that's the highest possible quality, then maybe try making the preview a little smaller? The smaller preview is already quite small, though. Hmmm. Maybe leave the smaller one as it is.

Well, we'll need to try a few things, probably.

@litetex
Copy link
Member Author

litetex commented Jun 6, 2021

A few updates:

  • Changed the settings to:
    settings
  • The min-width of the thumbnail is now 100dp (so that it's more consistent)
  • Made sure that it works on tablets and tvs:
    tv
    tv_full

@opusforlife2
Copy link
Collaborator

Well, I wanted to test with the latest changes, but the CI job failed.

@litetex
Copy link
Member Author

litetex commented Jun 7, 2021

Well, I wanted to test with the latest changes, but the CI job failed.

Occurs because underlying extractor pr is missing / not merged:
TeamNewPipe/NewPipeExtractor#647

I built a new apk:
debug.zip

Note: The manual build guide as stated in the PR description above also works :)

@opusforlife2
Copy link
Collaborator

@litetex Are you not supposed to update the Extractor version to the one that corresponds to your Extractor PR's latest commit? I may be wrong, but I think that's the general procedure.

@litetex
Copy link
Member Author

litetex commented Jun 8, 2021

@litetex Are you not supposed to update the Extractor version to the one that corresponds to your Extractor PR's latest commit? I may be wrong, but I think that's the general procedure.

MontyPhytonIDontKnowThat

I can do that but, this will point to my repo not NewPipe's so guess the person who merges that has to fix it 😆
Will also update the branch from develop so that the conflicts are gone

@litetex litetex force-pushed the playerSeekbarPreview branch 2 times, most recently from f1b462b to f1a9c87 Compare June 8, 2021 18:01
Copy link
Member

@Stypox Stypox left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I did not review carefully, but from a first look the code is a beauty! Thank you :-D

@litetex litetex force-pushed the playerSeekbarPreview branch from 4b1333c to 84337f2 Compare June 9, 2021 18:53
@litetex
Copy link
Member Author

litetex commented Jun 9, 2021

@Stypox
Thank you for the review 😄

I rebased the complete branch and applied the requested changes.

Copy link
Member

@Stypox Stypox left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code looks good to me, but I would also like someone else to review. Thank you @litetex for the hard work! I tested and everything seems to work well on API 29 (real phone), API 29 (emulated TV), API 30 (emulated tablet). I was unable to test on API 19 since in the emulator the codecs to open videos are missing.

@opusforlife2
Copy link
Collaborator

I just noticed that this replaces the seek time in the centre of the player with one below the preview thumbnail. I think we should try keeping the seek time in the centre like before. Below the thumbnail, it might be too tiny for some people to read.

@opusforlife2
Copy link
Collaborator

so guess the person who merges that has to fix it 😆

That's standard procedure, don't worry.

@litetex
Copy link
Member Author

litetex commented Jun 13, 2021

@opusforlife2

I just noticed that this replaces the seek time in the centre of the player with one below the preview thumbnail. I think we should try keeping the seek time in the centre like before. Below the thumbnail, it might be too tiny for some people to read.

I wouldn't do that, as both the YT app and the website use the same positioning as introduced with the PR:
grafik
This could also cause problems on e.g. smaller screens, because the "seek time in the centre" and the thumbnail could maybe overlap.
It also breaks the visual unity of the both elements.

Note: The start- and endtime also have the same size and nobody seems to have problems with them

@opusforlife2
Copy link
Collaborator

People don't really need to care about the current time and end time. But when seeking, they may want to focus on the seek time. How about putting it above the thumbnail instead of below, and making it bigger?

@litetex
Copy link
Member Author

litetex commented Jun 14, 2021

People don't really need to care about the current time and end time.

I wouldn't say that.

But when seeking, they may want to focus on the seek time.
How about putting it above the thumbnail instead of below, and making it bigger?

Okay let's come to an agreement here: I will make the text a bit larger.

Note: The only video streaming providers implementing a seekbar preview are currently YT and media ccc
grafik

Both show the seek time below (or below inside) the preview thumbnail.
I will keep therefore that standard behavior.

@Mhowser
Copy link

Mhowser commented Jun 15, 2021

I think the seek time should be in the lower left corner instead of the center.

@Stypox
Copy link
Member

Stypox commented Jun 15, 2021

I think we should not reinvent the wheel and just keep the standard behaviour. Making the text a little bit bigger is a good compromise, but I would not make anything different.

@litetex litetex force-pushed the playerSeekbarPreview branch from 84337f2 to 9ddf16c Compare June 15, 2021 17:41
@litetex
Copy link
Member Author

litetex commented Jun 15, 2021

Enlarged the currentDisplaySeek-text

Demo (click to open)

demo
demo_large

@Stypox
Copy link
Member

Stypox commented Jul 5, 2021

@opusforlife2 @litetex Placing the seek time below the thumbnail looks more natural in my opinion, maybe just because that's the usual way. On the other hand placing the seek time above has multiple advantages: making the text more readable and having the thumbnail overlay cover a smaller portion of the player below. So I'd go with seek time above, at the end of the day.

Though I do think it would look better with that shadow extended to the width of the thumbnail.

I'd rather not do this as it would cover more of the player below. It looks just fine as it already is imo.

@litetex litetex force-pushed the playerSeekbarPreview branch from 31fac79 to 809ca4c Compare July 6, 2021 19:06
@litetex
Copy link
Member Author

litetex commented Jul 6, 2021

@Stypox
@opusforlife2

Guess the majority wins.
Then let's move the time to the top 😄

Demo pictures (click to expand)

grafik
grafik

Update:
Also increased the bottom padding a bit, so people with bigger fingers can see the thumbnail 😉

@Stypox
Copy link
Member

Stypox commented Jul 7, 2021

The behavior in the latest apk looks polished and works well in my opinion

@opusforlife2
Copy link
Collaborator

Yay! Looks awesome! Thanks, @litetex!

@Stypox
Copy link
Member

Stypox commented Jul 17, 2021

@litetex please rebase one last time, then I will do one last round of review and merge this :-)

@litetex litetex force-pushed the playerSeekbarPreview branch from 171426c to efd038a Compare July 17, 2021 14:43
@litetex
Copy link
Member Author

litetex commented Jul 17, 2021

@Stypox
Rebasing done

Copy link
Member

@Stypox Stypox left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code looks good to me, thank you for the dedication! I tested on my API 29 phone and on emulated API 19, API 21, API 29 (tv), API 30, API 30 (tablet). I tried both fullscreen and not-fullscreen. (on API 19 and 21, though, I could not find any playable video with a frameset: newer videos do not play because of missing decoders and "me at the zoo" has no frameset)

@Stypox Stypox merged commit d57bfde into TeamNewPipe:dev Jul 19, 2021
@litetex litetex deleted the playerSeekbarPreview branch July 19, 2021 19:12
@litetex
Copy link
Member Author

litetex commented Jul 19, 2021

(on API 19 and 21, though, I could not find any playable video with a frameset: newer videos do not play because of missing decoders and "me at the zoo" has no frameset)

If I have time, I will test the current develop on my old Android 4.4 device. Last time I tested it (about 2 weeks ago) everything was looking fine.

This was referenced Aug 4, 2021
@Thewisem

This comment has been minimized.

@litetex

This comment has been minimized.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature request Issue is related to a feature in the app player Issues related to any player (main, popup and background)
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Thumbnails preview on seek bar
7 participants