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(mobile): #15182 Video memories no longer play #15210

Draft
wants to merge 3 commits into
base: main
Choose a base branch
from

Conversation

Tyris
Copy link
Contributor

@Tyris Tyris commented Jan 10, 2025

I believe this was introduced along with the introduction of the currentAssetRepository.

The fix (for #15182) is relatively simple by just ensuring the right currentAsset gets set on memoryPage load and transition.

Unfortunately, while this fixes the issue, I now have pretty weird stutter that shows for a few hundred ms between the preview image and playing the actual video on my Pixel 8. There is already some timers to try to prevent "stutters" (which may be related), but I found I had to increase them significantly (300ms to ~1s) to hide the issue completely. I'm guessing it's related to funniness in Android's video surface (which is known to be a bit dodgy); but I tried messing around with waiting till the video was initialised/loading/playing, but couldn't get it going.

Since I'm not sure if the above stuttering is a regression (I'm very new to using the app) - I thought I'd raise this PR but ask someone who's more familiar with this area of logic to have a look.

if (currentAssetPage.value == 0) {
Future.delayed(const Duration(milliseconds: 1)).then((_) {
final asset = currentMemory.value.assets[0];
ref.read(currentAssetProvider.notifier).set(asset);
Copy link
Contributor

Choose a reason for hiding this comment

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

The current asset should be set before this page is being built. Setting it in a future on the page itself is hacky.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I agree, but where would you recommend? This is really the earliest place it can be done that makes sense since we don't know the asset prior to this point (I believe - I'm still getting used to the code-base and Flutter).

I tried doing it in a useEffect, but Flutter doesn't like that. I used a future because we do the same already for caching the "next" asset (and Flutter actually suggested I use a Future when I tried it in useEffect).

Copy link
Contributor

Choose a reason for hiding this comment

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

You can set it before pushing the route here

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Not sure I like setting it before the asset is current in a tap action, but 🤷

Done.

Copy link
Contributor

Choose a reason for hiding this comment

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

It's what the Riverpod dev recommends; it avoids rebuilding the widget one frame after it's built and means the widget can assume the current asset is set without having to bootstrap itself.

@mertalev
Copy link
Contributor

There is already some timers to try to prevent "stutters" (which may be related), but I found I had to increase them significantly (300ms to ~1s) to hide the issue completely. I'm guessing it's related to funniness in Android's video surface (which is known to be a bit dodgy); but I tried messing around with waiting till the video was initialised/loading/playing, but couldn't get it going.

It depends on how long the animation takes. The video initialization kind of competes with Flutter animations, so the timers are to make sure the video waits for the animation. The memory animation might be slow enough that the existing timers aren't enough. Other animations like swiping and maybe the hero animation were made faster so the video can wait for them without waiting too long.

…n memories.

Also adjusted the scale of the memory preview image to match the ratio of the video. This still appears to jump because the video preview doesn't seem to be the first frame for some reason :\
@Tyris
Copy link
Contributor Author

Tyris commented Jan 16, 2025

There is already some timers to try to prevent "stutters" (which may be related), but I found I had to increase them significantly (300ms to ~1s) to hide the issue completely. I'm guessing it's related to funniness in Android's video surface (which is known to be a bit dodgy); but I tried messing around with waiting till the video was initialised/loading/playing, but couldn't get it going.

It depends on how long the animation takes. The video initialization kind of competes with Flutter animations, so the timers are to make sure the video waits for the animation. The memory animation might be slow enough that the existing timers aren't enough. Other animations like swiping and maybe the hero animation were made faster so the video can wait for them without waiting too long.

Have updated the PR with a cludgy playbackDelayFactor to improve this. I noticed that for remote videos, the preview frame is not the first frame, so it looks jumpy when it goes to play - imo it looks better just using the blurhash (removing the preview image entirely) - but open to input.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants