-
-
Notifications
You must be signed in to change notification settings - Fork 21.4k
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
Image::compress / compress_with_channels unreliable, not exportable #79932
Comments
Looks like most of the image compression/decompression libraries aren't included in export builds. In the past I know that we avoided including any image saving/loading libraries in the export builds, but I know that has been slowly opening up. I guess the discussion here should be whether we want to enable the compression libraries for export builds. It would be helpful to do a build size analysis to see what the realistic cost for enabling them is. |
I'd suggest adding build-time options to enable them in export templates when needed, similar to #73003. |
I now understand that the function doesn't work because it's not even there, by design. We're using these functions when the user creates terrain materials with null textures. We want to create blank textures automatically, but now we cannot. I will have to work around this by putting warnings everywhere that the user cannot leave it with null textures. It's a bit tacky, and users will ignore the warnings and then complain about why their exports don't work. Philosophically, I don't understand why there would be an API for us to use, yet a random portion of the API is removed on export. If the engine runs itself as a game and has access to all of these functions and libraries, my project should too. I don't like having to spend time troubleshooting a broken project only to find it's one of those neutered libraries taken out just because. I like the idea that on the export screen we have the option of including or excluding every possible library that we have access to in the editor. Build time options, would allow us to put that in the instructions and include an export_template.cfg. |
Can't you store premade compressed textures in the add-on, make sure these are exported and use those if the user hasn't specified any?
That's what documentation is for 🙂
This is not feasible without recompiling export templates. (This is how #62996 works already; it won't work if you don't compile custom export templates with the build profile used at build-time.) We don't want to require having a build toolchain set up to export projects, so this can't be provided by default. Build instructions also vary heavily depending on platform and cross-compilation isn't always possible. |
We are creating image blanks -> textures -> texture array. All of the images have to be the same size to go in the array, so if the user has already put in a 1k x 1k texture, we need to match that. We'd have to include multiple sizes from 256, which some are using, all the way up to 4k just for blanks, *2 because we need a different type for normal. We could exclude the material from the array, but then our array indexing on the CPU will be different from the shader. 🤔 I'll probably just leave warnings everywhere for now if they have empty materials until we have the option to include image compression. |
I've found a solution for us. Rather than generate the image blanks at runtime, which doesn't work on export. Now I generate the texture blanks while in the editor and save it with the rest of the data. Do you guys want to leave this open to update the documentation or provide the option of including the compression libraries on export? |
Godot version
Godot 4.1.1-stable
System information
Windows 11/64, RTX 3070, Vulkan
Issue description
I'm building Terrain3D and ran into problems with
Image::compress()
andImage::compress_from_channels()
which don't work on export and are unreliable in the editor.We transitioned to
With either function, debug exports give this error message:
I'm using the default export options:
Godot 4.1.1-stable
Terrain3D 0.8.1+ a69eff
Steps to reproduce
See above
Minimal reproduction project
n/a
The text was updated successfully, but these errors were encountered: