LibGfx+Tests: Load bmp files with unpremultiplied alpha

From what I can tell BMP files with an alpha channel always store
unpremultiplied alpha. So let's load them as such to avoid rendering
artifacts from using the wrong alpha type.
This commit is contained in:
InvalidUsernameException 2025-11-27 22:18:14 +01:00 committed by Jelle Raaijmakers
parent 949053cee7
commit bc44203744
Notes: github-actions[bot] 2025-11-28 16:01:33 +00:00
3 changed files with 24 additions and 1 deletions

View file

@ -1298,7 +1298,7 @@ static ErrorOr<void> decode_bmp_pixel_data(BMPLoadingContext& context)
u32 const width = abs(context.dib.core.width);
u32 const height = !context.is_included_in_ico ? abs(context.dib.core.height) : (abs(context.dib.core.height) / 2);
context.bitmap = TRY(Bitmap::create(format, { static_cast<int>(width), static_cast<int>(height) }));
context.bitmap = TRY(Bitmap::create(format, Gfx::AlphaType::Unpremultiplied, { static_cast<int>(width), static_cast<int>(height) }));
ByteBuffer rle_buffer;
ReadonlyBytes bytes { context.file_bytes + context.data_offset, context.file_size - context.data_offset };

View file

@ -0,0 +1,11 @@
<!DOCTYPE html>
<style>
body {
color: white;
background-color: black;
}
</style>
<p>All three images should render the same</p>
<img src="">
<img src="">
<img src="">

View file

@ -0,0 +1,12 @@
<!DOCTYPE html>
<link rel="match" href="../expected/bmp-load-as-unpremultiplied-alpha-ref.html" />
<style>
body {
color: white;
background-color: black;
}
</style>
<p>All three images should render the same</p>
<img src="">
<img src="">
<img src="">