-
Notifications
You must be signed in to change notification settings - Fork 42
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
Support compressed images and RGBA data in Image class #368
Conversation
Signed-off-by: Luca Della Vedova <[email protected]>
Signed-off-by: Luca Della Vedova <[email protected]>
Signed-off-by: Luca Della Vedova <[email protected]>
Codecov Report
@@ Coverage Diff @@
## main #368 +/- ##
==========================================
+ Coverage 77.88% 77.93% +0.04%
==========================================
Files 84 84
Lines 10728 10750 +22
==========================================
+ Hits 8356 8378 +22
Misses 2372 2372
Continue to review full report at Codecov.
|
Signed-off-by: Luca Della Vedova <[email protected]>
I agree completely. Fixing this API has been on my someday/maybe list for a while. While it is out of the scope for this PR, if anyone on your side has some spare cycles, I would really appreciate a cleaner API before Garden. |
Windows failing is expected. |
I'm happy to look at it, I ticketed an issue #369 and can start working on it if the idea sounds reasonable to you. |
Great, thanks! I think improving this API will both make it more reasonable for users as well as make it generally more efficient as we are doing a lot of reallocations and copies. |
Signed-off-by: Michael Carroll <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, I just added two more quick test cases so we can get 💯 coverage on the diff.
* Add API to load compressed images and read RGBA data Signed-off-by: Luca Della Vedova <[email protected]> Signed-off-by: Michael Carroll <[email protected]>
🎉 New feature
Work towards #344 , specifically #344 (comment) to allow loading embedded textures.
Main user of this API would be gz-rendering, discussion on downstream API taking place in the gz-rendering PR
Summary
This PR adds support for loading compressed images from in memory binary blobs, this is achieved through a new
SetFromCompressedData
function that takes as an input a byte array and a format and loads the image internally. For now only PNG is supported but other formats can be added trivially by adding a new case to the if statement.Since images are provided as binary blobs, height and width are not known when the function is called. An alternative approach could be to use
SetFromData
with the byte buffer being passed as an image of1 * len(buffer)
size, but I thought that wasn't too clean so went for another function.It also adds a
RGBAData
function that returns the image in RGBA8 format. The main use case for this is that loading a PNG without an alpha channel throughFreeImage
would return an RGB8 24 bit image. This format might be tricky to use for downstream users because it's not aligned to the 32 bit boundary. This is specifically an issue in OGRE2 which is unable to transfer 24 bit textures to GPU (ref here).Hence the convenience function is added for downstream users to make sure the image is always in a 32 bit RGBA8 format.
Note, I'm personally not a big fan of the API for the
Data
functions where a user has to remember to manually delete[] the pointer they passed as soon as they are done with it, it would probably be safer to either return astd::vector
of bytes (at the risk of expensive copies happening if people are not careful) or astd::shared_ptr
to astd::vector
of bytes, which would make sure copies only increase the reference count and memory is still correctly deallocated.However having this API would have required changing the behavior of the
DataImpl
function that is used in other parts of the library so I didn't quite know if this was a good idea.Test it
Unit tests have been added, manual test is significantly more complex since it requires using the branches in #344 and the gz-rendering PR, having a GLB asset and making sure the asset is correctly displayed.
Checklist
codecheck
passed (See contributing)Note to maintainers: Remember to use Squash-Merge and edit the commit message to match the pull request summary while retaining
Signed-off-by
messages.