Fix framebuffer texture capture with texStorage2D bug #292
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Bug
Test demo: https://06wj.github.io/test/spectorJSTest/
data:image/s3,"s3://crabby-images/61170/61170b2925bcfcfbe09027a3f555a7871e0146d9" alt="image"
The picture below is the capture result.The framebuffer display a blank picture.
Solution
When using texStorage2D, there is no type value in the texture customData.
data:image/s3,"s3://crabby-images/17d2f/17d2f0574109e3884497798c323f0dee7bbb907d" alt="image"
Because there is no type value in customData, textureType will be set to null, causing an error when readPixels is called, leading to a capture failure.
data:image/s3,"s3://crabby-images/626a6/626a6426024bfef8ef295c6c606595be54c94e05" alt="image"
So a change has been made here. When there is no type, the framebuffer's attachmentComponentType is still used.
data:image/s3,"s3://crabby-images/6d384/6d3844cc6682bbd9325ed542ba9c909c4c714fa3" alt="image"
The picture below is the fixed capture result.