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

Fix player resuming from start when clicking on a timestamp #11734

Merged
merged 2 commits into from
Nov 27, 2024

Conversation

Thompson3142
Copy link
Contributor

@Thompson3142 Thompson3142 commented Nov 21, 2024

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

Opening a timestamp from a comment (or somewhere else) started the pop-up player from the beginning instead of the timestamp (more details in the linked issue). Now it always opens the pop-up player at the specified time and not from start.
I am honestly unsure if this fix is acceptable since i don't fully understand the purpose of calling setRecovery() in this spot in the first place, so i am open to suggestions and/or help regarding this topic. I have not found any behavior that breaks with these changes though.

Fixes the following issue(s)

APK testing

The APK can be found by going to the "Checks" tab below the title. On the left pane, click on "CI", scroll down to "artifacts" and click "app" to download the zip file which contains the debug APK of this PR. You can find more info and a video demonstration on this wiki page.

Due diligence

@github-actions github-actions bot added the size/small PRs with less than 50 changed lines label Nov 21, 2024
@Profpatsch
Copy link
Contributor

Why does the player change to a popup player in the first place when clicking on a timpestamp? Shouldn’t it just seek in the currently playing player?

@ShareASmile
Copy link
Collaborator

Why does the player change to a popup player in the first place when clicking on a timpestamp? Shouldn’t it just seek in the currently playing player?

While discussing it, We should also See the context in which it wasn't touched, like a comment from #4241 when we switched to Unified Player.

@ShareASmile ShareASmile changed the title Fixed player resuming from start when clicking on a timestamp Fix player resuming from start when clicking on a timestamp Nov 22, 2024
@Thompson3142
Copy link
Contributor Author

I just assumed this was the expected behavior at this point, you can definitely make the argument to change this or give the user the option to choose between the two. I personally dislike the idea of just removing the pop-up option all together since most users are probably used to it at this point but i am not the person that should make this decision.

@ShareASmile ShareASmile added bug Issue is related to a bug player Issues related to any player (main, popup and background) labels Nov 23, 2024
@ShareASmile
Copy link
Collaborator

i don't fully understand the purpose of calling setRecovery() in this spot in the first place, so i am open to suggestions and/or help regarding this topic.

While debugging #7427 developer litetex investigated the player code. Though I am not a developer, I am unable to help you but reading comments there(also mentioned issues/PRs) may help you understand the code around it better and may get some new insights into it.

@Thompson3142
Copy link
Contributor Author

I have looked into it a bit and it seems like its no longer necessary to call setRecovery() in this spot. At least for me the bug did not reappear when i removed this piece of code, it seems like this was fixed somewhere along the line but never removed. Probably would be good though if more people than just me could confirm this (ideally ones that know how to reproduce this bug), i have updated the PR accordingly.

I don't know how the process for feature requests is but since the rewrite to NewPlayer is going on right now, it seems like the topic how timestamps should be opened should probably be discussed for NewPlayer but not be implemented for this version of the Player. If that is not the case i am happy to implement it differently.

@Profpatsch
Copy link
Contributor

Please be aware that we are completely reworking the player at the moment so anything apart from very simple bug fixes will not be reviewed/merged.

But we’ll keep this in mind for the new player.
I think this PR might be worth merging anyway, to get the jump-to-timestamp function finally working again.

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.

The setRecovery() call was introduced in c45514b, see this blame, but since that commit is giant, who knows what was the thought process behind adding that line.

I tested on my phone (Android 13), on API 34 emulated and on API 22 emulated, and I tried opening a video, switching popup/background/main multiple times and starting a new video that replaces the queue, and could not notice any issue. Therefore let's take a gamble: let's merge this and see if users report any new sort of player bug. If something happens, since this is a single-line change, it can be reverted without issues. Thank you for looking into this!

@Stypox Stypox merged commit e4b0245 into TeamNewPipe:dev Nov 27, 2024
6 checks passed
@SavSanta
Copy link

SavSanta commented Dec 7, 2024

Seems the changes fix the problem.

if the playlist is open while clicking a timestamp. The entries in the playlist still exist after clicking a timestamp. It's even [badly] scrollable in the pop-up window that always happens.

However closing and re-opening the playlist via the UI button and all the entries are gone.

example
https://github.com/user-attachments/assets/6bead949-3598-43ac-8354-13fe06e1fe5b

So on clarification it DOES fix at least the portion of resetting the player timestamp back to zero. SO the above can be disregarded

@Thompson3142
Copy link
Contributor Author

These are (imho) not related, this PR was specifically for #11302 your issue is still unfixed but not relevant in this context.

@SavSanta
Copy link

SavSanta commented Dec 8, 2024

Hmm, yea that is true. It doesnt go to the beginning. My bad. +1 for timestamp reset has been fixed from my testing. Above edit commented out

@Candlemass
Copy link

I'm still having this problem. Any time the seek bar is touched newpipe throws an error and video playback is stopped. Playback can only be resumed from the beginning of the video if it is closed and reopened. Attempting to play the video again after the initial error from attempting to seek without reopening only throws another error. Version 0.27.4.

@Profpatsch
Copy link
Contributor

I'm still having this problem. Any time the seek bar is touched newpipe throws an error and video playback is stopped. Playback can only be resumed from the beginning of the video if it is closed and reopened. Attempting to play the video again after the initial error from attempting to seek without reopening only throws another error. Version 0.27.4.

If you look at the error stack trace, does it say “Status 403” on the very right somewhere between line 5 and 10?

Because these errors are not related to the resume feature here, they are a new thing youtube is trying to prevent users from accessing their videos. They happen more often if you start from the middle than from the beginning.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Issue is related to a bug player Issues related to any player (main, popup and background) size/small PRs with less than 50 changed lines
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Tapping on timestamp causes popup player to start from beginning
6 participants