-
Notifications
You must be signed in to change notification settings - Fork 670
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
Need ImageBitmap conformance tests that ensure pixel unpack parameters are ignored #2577
Comments
Just checking but I assume you mean just UNPACK_ALIGNMENT. At least in WebGL2 you need the other parameters if you want to be able to upload parts of an image or if you want to be able to upload a single image as multiple slices of a 3D texture a 2D_ARRAY texture. Otherwise it seems like all the other parameters should be honored including FLIP_Y, PREMULTPLIED_ALPHA, etc... |
Not for ImageBitmaps. The intent there was that FLIP_Y and PREMULTIPLY_ALPHA must be specified as arguments to createImageBitmap, so that image decoding can happen optimally for the intended usage in WebGL. See this spec: |
There 2 issues here.
those have to continue to work otherwise ImageBitmap WebGL2 apps won't be able to use ImageBitmap to efficently load a 3D or 2D_ARRAY images. Using those parameters a single call to gl.texImage3D can load all slices. Similarly you can slice images into cubemaps
Given these work on the standard non element, arraybuffer based texImage functions I don't get why they shouldn't work on ImageBitmap. Removing them would be especially troublesome for porting to OffscreenCavnas. With them you can just switch your image loading code from using Images to using ImageBitmaps. Without them you have to change even more things. The fact that you can use ImageBitmap efficently by letting it do the conversions async seems irrelevent to what happens when calling texIImage. If you want the efficiency then use the flags in ImageBitmap. If don't care then continue to use the flags in WebGL |
The main goal in adding support for ImageBitmap was to avoid things like synchronous image re-decodes, which are needed when the developer requests UNPACK_PREMULTIPLY_ALPHA=false and are providing their image data via HTMLImageElement. We do not want to have an unexpected performance cliff for this upload path. Instead we aim to have all browsers support the createImageBitmap creation parameters, and not support these unpack parameters for that case. We are trying to move away from supporting the FLIP_Y and PREMULTIPLY_ALPHA pixel unpack parameters for ArrayBuffer based texture data. If the user has computed their texture data then they should easily be able to premultiply alpha or not. We are not supporting these for uploads from ArrayBuffer to 3D texture or 2D texture array in WebGL 2.0. (CC'ing @jdashg for any further comments or motivation) |
WebGL2 already shipped. Shipping WebGL2 apps already expect FLIP_Y and PREMULTIPLY_ALPHA to work. Arbitrarily pulling that out would break content. WebGL2 supports flipping with ArrayBuffer and has since it shipped. https://jsfiddle.net/greggman/ucbu2g3t/ I think there are two ways to look at ImageBitmap
I'd argue the goal should be "allow" not "force" As an example I just updated twgl to work in workers. As such I had to make the code work with ImageBitmap instead of HTMLImageElement. Assuming all the flags worked made it easy. If the flags don't work not only do I have to add a bunch more code but I'd have to change the twgl API. It becomes extremely non-trival to explain when things get flipped and when they don't The same will be true of upgrading three.js to run in workers. It's not as simple as not supporting flip_y on ImageBitmap. Most WebGL libraries that load images into textures let you get a handle on the image itself. Many programs use those images to draw into canvas 2D for UI things. With ImageBitmaps supporting WebGL's flip_Y this becomes easy. Without it it becomes hard
Now I try to support running in an worker where I have to use ImageBitmap that code no longer works
In other words, not supporting these flags on ImageBitmap makes making your code portable between workers and non-workers extremely non-trivial not to mention handling browsers that don't support ImageBitmap at the same time. I would also argue the bigger goal of ImageBitmap was to provide a way of loading images in workers. a secondary goal would be to allow async image manipulation but not to force it. |
The synchronous re-decodes of HTMLImageElements when uploading to WebGL textures has been a longstanding and major bottleneck for web applications. ImageBitmap solves these problems by ensuring that the data is ready to be consumed before giving it to the application. The WebGL working group does not want to reintroduce the same performance problems with the ImageBitmap upload path; instead we want to ensure that ImageBitmap works the same in every browser, and both on the main thread and in workers, so that developers can have a high-performance image-to-texture upload path everywhere. This is the path we are pursuing. |
Nothing you said in your last comment counters anything I wrote. Being able to avoid those bottlenecks is a fine goal and even with support for the WebGL unpack flags nothing changes. If the developer wants to avoid the bottlenecks they use ImageBitmap and don't use the flags. If the developer just wants to quickly ship their existing app with support for OffscreenCanvas in a workr they can use ImageBitmap and continue to use the flags. Which by the way, based on the fact that they'd be running in a worker anyway means they aren't blocking the main thread. that seems like a win/win. Because of ease of porting you'll get more apps running their WebGL code in a worker. More apps in a worker means less blocking the main thread. If you make it harder to port and and especially if you make convoluted to support older browsers that still have to use Image then you'll get less adoption, less code running in workers, more main thread blocking. |
I'm curious what happened here. I'm guessing you guys went ahead and removed As it is the WebGL spec requires a heavy conversion from the image's format to the As it is they seem work (and therefore block for conversion) Load an JPG via ImageBitmap, upload as The OpenGL ES 3.0 spec makes it clear this conversion does not happen in the driver. It's solely a WebGL spec issue.
Looking at the ImageBitmap spec it doesn't seem to be clear what format |
I believed we dropped them to enforce that they should be handled outside the WebGL API, enforcing best-practice. TBH I'm really tired of playing with these APIs, and would prefer to expose texImage2D(target, level, ImageBitmap/TexImageSource) that just uploads directly ASAP.
I would love to, but the WG has been resistant to removing these from WebGL2, and we can't reasonably remove them from WebGL1 anymore. |
In Chromium issue http://crbug.com/794706 it was discovered that the WebGL conformance tests test various ImageBitmap creation arguments, but don't verify that the pixel unpack parameters are ignored when uploading ImageBitmaps to WebGL textures.
This needs to be verified.
The text was updated successfully, but these errors were encountered: