-
Notifications
You must be signed in to change notification settings - Fork 128
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
Emoji picker does not play nicely with Impeller rendering engine #159
Comments
On a hunch, I replaced of all the similey emojis in lib/src/default_emoji_set.dart with ~300 copies of the same smiley emoj. Running with Impeller this picker of 300 identical emoji's runs extremely well, much better in fact than a page of different emojis does even with Impeller disabled. Based on this, I think it is likely that the texture limit / atlas size issues I linked to before are the underlying issue. Unfortunately I'm not sure there's a quick fix that users can employ until the framework issues are resolved. Flutter did merge one PR aimed at addressing this issue, and I asked in flutter/engine#45992 (comment) if this has made its way into stable yet. |
@emesterhazy Can you walk me through how you did test it? Impeller suppose to be enabled by default on iOS meanwhile and I can't see any issue running the EmojiPicker on iOS Simulator. Also using extra parameter to enable it seems to not make any difference, so I assume it's running with impeller enabled. |
Sorry for the slow reply. I tested the emoji picker on the iOS simulator on iOS 17 as well as a physical iPhone. Unfortunately I don't remember which version of Flutter I used at the time, but I think it was 3.13 or 3.14. I tested this again today using Flutter 3.16.0 and I'm not seeing errors in the debug console anymore. However, scrolling in the emoji picker is still very janky on the iOS simulator. I'm going to test it on a physical iPhone but I suspect it will perform poorly there as well. It looks like there's a new bug open in the Flutter repo reporting the jank: How does scrolling performance look for you? When I disable Impeller there's no jank while scrolling through emojis, at least compared to Impeller. I recorded two videos, one with Skia and one with Impeller. IMO the jank in the impeller video is pretty noticeable. It might be easier to see if you download the videos instead of viewing them in Google Drive's player. |
I was trying to improve performance in version 2.0 and found that I got huge performance increases when I replaced |
That's interesting. Do you have any idea why the performance might be so different between the two? I think that the issues with Impeller show up on the simulator as well, so you don't necessarily need a physical device to test the change. |
I don't know, I haven't looked deeper into InkWell implementation. I used the profiler to improve widgets that took long to build. My simulator has a weird behavior and freezes every few seconds, so difficult to test. Will check with real device next week. Once I can confirm improved performance in general, I will release 2.0, the major work is done. |
@emesterhazy I think with Version 2.0 the performance should be much better, also with Impeller. |
Gonna close this issue, if anyone notice performance issues again, please open another issue 🙏 |
The default rendering engine on iOS is now Impeller, which doesn't seem to play nicely with the emoji picker. This manifests as jank while scrolling and lots of errors in the console:
It seems like the issue might be with Impeller's texture limit, and there are a few open issues that seem related:
Disabling Impeller works as a quick fix to resolve the issue, but it's unfortunate that disabling it is necessary since Impeller is otherwise a more performant rendering engine.
I'm not sure if there's another workaround or change we can make to the emoji picker to avoid this issue until Flutter / Impeller implements a fix, if they do. From my preliminary testing, limiting the size of the picker to 350 px or smaller seems to prevent the atlas failures from occurring, but scrolling is still very janky.
The text was updated successfully, but these errors were encountered: