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 a bug in safari where browser image is not displayed #179

Closed

Conversation

eliknebel
Copy link

This PR addresses an issue where display: none css in Safari hides the browser image.

The fix here changes display none to instead passthrough pointer events and position the image absolutely, allowing the canvas element to sit directly behind it.

Closes #178

@eliknebel eliknebel closed this Feb 10, 2021
@enesccinar
Copy link

Hey guys, thanks for the extension. I am still having trouble with this issue.

@eliknebel
Copy link
Author

I tired submitting an initial fix PR for this but realized that it scrolling on iPadOS still was not working, so I closed the PR until I find a fix that works on iOS too. However, the fix does work for macOS Safari

@eliknebel
Copy link
Author

eliknebel commented Feb 11, 2021

After poking around in the source code and testing out some different changes, I'm starting to believe the scrolling issue on iPad is related to https://bugs.webkit.org/show_bug.cgi?id=210071 which fixes have landed on iOS 14.5 beta but may not have landed in the chromium builds (and it may never, since this was an issue specific to iPadOS and mouse/trackpad scrolling).

In any case, I do believe the fix here is valid for Safari users, and possibly another workaround for scrolling on an iPad can be introduced later? (scrolling using arrow keys, rendering custom scrollbar, etc..).

I am going to reopen this PR, but it should be vetted and taken cautiously. After studying the source code further, I realized the canvas element itself was rendering the screen coming from the headless chrome browser and simply using the html img element to hold the image data. It's unclear to me exactly why this fix works, but I believe it either has to do with Safari not wanting to load the image data from an image that is display: none -or- there is some sort of canvas memory issue in Safari when it tried to render the image in a canvas, and it simply bails out; by removing the display: none css, the image is allowed to be rendered directly by the browser which then passes pointer events through to the underlying canvas.

@eliknebel eliknebel reopened this Feb 11, 2021
@eliknebel eliknebel changed the title fix a bug in safari where browser image is not displayed Fix a bug in safari where browser image is not displayed Feb 11, 2021
@enesccinar
Copy link

thanks.. yes, the scroll problem was about the webkit and fixed on ipados 14.5 beta version.

@auchenberg
Copy link
Owner

Closing as per my comment in #178 (comment).

This doesn't fix the underlaying and real issue

@auchenberg auchenberg closed this Feb 20, 2021
@auchenberg
Copy link
Owner

And a big thanks for taking the time to contribute, I really appreciate it! 🙇

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

Successfully merging this pull request may close these issues.

Canvas doesn't render in Safari on iOS
3 participants