2020-06-22 21:35:22 +02:00
|
|
|
/*
|
2021-01-31 09:24:46 +01:00
|
|
|
* Copyright (c) 2020-2021, Andreas Kling <kling@serenityos.org>
|
2020-06-22 21:35:22 +02:00
|
|
|
*
|
2021-04-22 01:24:48 -07:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
2020-06-22 21:35:22 +02:00
|
|
|
*/
|
|
|
|
|
2021-01-16 23:58:57 +01:00
|
|
|
#include <LibCore/AnonymousBuffer.h>
|
2020-06-22 21:35:22 +02:00
|
|
|
#include <LibImageDecoderClient/Client.h>
|
|
|
|
|
|
|
|
namespace ImageDecoderClient {
|
|
|
|
|
2023-02-08 23:05:44 +01:00
|
|
|
Client::Client(NonnullOwnPtr<Core::LocalSocket> socket)
|
2022-02-25 12:27:37 +02:00
|
|
|
: IPC::ConnectionToServer<ImageDecoderClientEndpoint, ImageDecoderServerEndpoint>(*this, move(socket))
|
2020-06-22 21:35:22 +02:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2021-02-20 11:35:00 +01:00
|
|
|
void Client::die()
|
|
|
|
{
|
|
|
|
if (on_death)
|
|
|
|
on_death();
|
|
|
|
}
|
|
|
|
|
2023-12-23 13:56:23 -05:00
|
|
|
Optional<DecodedImage> Client::decode_image(ReadonlyBytes encoded_data, Optional<Gfx::IntSize> ideal_size, Optional<ByteString> mime_type)
|
2023-01-15 21:50:32 +02:00
|
|
|
{
|
|
|
|
if (encoded_data.is_empty())
|
|
|
|
return {};
|
|
|
|
|
|
|
|
auto encoded_buffer_or_error = Core::AnonymousBuffer::create_with_size(encoded_data.size());
|
|
|
|
if (encoded_buffer_or_error.is_error()) {
|
|
|
|
dbgln("Could not allocate encoded buffer");
|
|
|
|
return {};
|
|
|
|
}
|
|
|
|
auto encoded_buffer = encoded_buffer_or_error.release_value();
|
|
|
|
|
|
|
|
memcpy(encoded_buffer.data<void>(), encoded_data.data(), encoded_data.size());
|
2023-12-23 13:56:23 -05:00
|
|
|
auto response_or_error = try_decode_image(move(encoded_buffer), ideal_size, mime_type);
|
2021-02-20 11:33:34 +01:00
|
|
|
|
2021-05-03 16:51:42 +02:00
|
|
|
if (response_or_error.is_error()) {
|
2021-02-20 11:33:34 +01:00
|
|
|
dbgln("ImageDecoder died heroically");
|
|
|
|
return {};
|
|
|
|
}
|
2021-01-29 22:30:48 +01:00
|
|
|
|
2021-05-03 16:51:42 +02:00
|
|
|
auto& response = response_or_error.value();
|
|
|
|
|
2021-05-14 19:40:49 +02:00
|
|
|
if (response.bitmaps().is_empty())
|
|
|
|
return {};
|
|
|
|
|
2021-01-29 22:30:48 +01:00
|
|
|
DecodedImage image;
|
2021-05-03 16:51:42 +02:00
|
|
|
image.is_animated = response.is_animated();
|
|
|
|
image.loop_count = response.loop_count();
|
2024-02-14 01:15:06 -05:00
|
|
|
image.scale = response.scale();
|
2023-10-01 19:56:19 +01:00
|
|
|
image.frames.ensure_capacity(response.bitmaps().size());
|
2023-02-19 23:52:10 +01:00
|
|
|
auto bitmaps = response.take_bitmaps();
|
2023-10-01 19:56:19 +01:00
|
|
|
for (size_t i = 0; i < bitmaps.size(); ++i) {
|
|
|
|
if (!bitmaps[i].is_valid())
|
|
|
|
return {};
|
|
|
|
|
|
|
|
image.frames.empend(*bitmaps[i].bitmap(), response.durations()[i]);
|
2021-01-29 22:30:48 +01:00
|
|
|
}
|
2021-03-17 16:30:02 +01:00
|
|
|
return image;
|
2020-06-22 21:35:22 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|