summaryrefslogtreecommitdiff
path: root/Libraries/LibGfx
diff options
context:
space:
mode:
authorPeter Nelson <peter@peterdn.com>2020-08-12 18:42:13 +0100
committerAndreas Kling <kling@serenityos.org>2020-08-13 15:49:41 +0200
commitc8f8f4e6c3915248d8af632453e29b506355dc81 (patch)
tree8c495af4a922cb20e66aeaa6aa421899bc1ae1e0 /Libraries/LibGfx
parentdaa762bb061bbb5ddb90030ac422b28101b2892d (diff)
downloadserenity-c8f8f4e6c3915248d8af632453e29b506355dc81.zip
LibGfx: use disposal method of previous frame in GIF transparency
The disposal method on a GIF animation frame now correctly applies to rendering of the next frame.
Diffstat (limited to 'Libraries/LibGfx')
-rw-r--r--Libraries/LibGfx/GIFLoader.cpp12
1 files changed, 9 insertions, 3 deletions
diff --git a/Libraries/LibGfx/GIFLoader.cpp b/Libraries/LibGfx/GIFLoader.cpp
index 814018c24e..fa1ba9a957 100644
--- a/Libraries/LibGfx/GIFLoader.cpp
+++ b/Libraries/LibGfx/GIFLoader.cpp
@@ -282,13 +282,19 @@ static bool decode_frames_up_to_index(GIFLoadingContext& context, size_t frame_i
Color background_color = Color(background_rgb.r, background_rgb.g, background_rgb.b);
image.bitmap = Bitmap::create_purgeable(BitmapFormat::RGBA32, { context.logical_screen.width, context.logical_screen.height });
- image.bitmap->fill(background_color);
- if (i > 0 && image.disposal_method == ImageDescriptor::DisposalMethod::InPlace) {
+
+ const auto previous_image_disposal_method = i > 0 ? context.images.at(i - 1).disposal_method : ImageDescriptor::DisposalMethod::None;
+
+ if (previous_image_disposal_method == ImageDescriptor::DisposalMethod::InPlace) {
for (int y = 0; y < image.bitmap->height(); ++y) {
for (int x = 0; x < image.bitmap->width(); ++x) {
image.bitmap->set_pixel(x, y, context.images.at(i - 1).bitmap->get_pixel(x, y));
}
}
+ } else if (previous_image_disposal_method == ImageDescriptor::DisposalMethod::RestoreBackground) {
+ image.bitmap->fill(background_color);
+ } else if (previous_image_disposal_method == ImageDescriptor::DisposalMethod::RestorePrevious) {
+ image.bitmap->fill(Color(Color::NamedColor::Transparent));
}
int pixel_index = 0;
@@ -320,7 +326,7 @@ static bool decode_frames_up_to_index(GIFLoadingContext& context, size_t frame_i
c.set_alpha(0);
}
- if (!image.transparent || image.disposal_method == ImageDescriptor::DisposalMethod::None || color != image.transparency_index) {
+ if (!image.transparent || previous_image_disposal_method == ImageDescriptor::DisposalMethod::None || color != image.transparency_index) {
image.bitmap->set_pixel(x, y, c);
}