Flutter Engine
 
Loading...
Searching...
No Matches
flutter::ImageGeneratorRegistry Class Reference

Keeps a priority-ordered registry of image generator builders to be used when decoding images. This object must be created, accessed, and collected on the UI thread (typically the engine or its runtime controller). More...

#include <image_generator_registry.h>

Public Member Functions

 ImageGeneratorRegistry ()
 
 ~ImageGeneratorRegistry ()
 
void AddFactory (ImageGeneratorFactory factory, int32_t priority)
 Install a new factory for image generators.
 
std::shared_ptr< ImageGeneratorCreateCompatibleGenerator (const sk_sp< SkData > &buffer)
 Walks the list of image generator builders in descending priority order until a compatible ImageGenerator is able to be built. This method is safe to perform on the UI thread, as checking for ImageGenerator compatibility is expected to be a lightweight operation. The returned ImageGenerator can then be used to fully decode the image on e.g. the IO thread.
 
fml::TaskRunnerAffineWeakPtr< ImageGeneratorRegistryGetWeakPtr () const
 

Detailed Description

Keeps a priority-ordered registry of image generator builders to be used when decoding images. This object must be created, accessed, and collected on the UI thread (typically the engine or its runtime controller).

Definition at line 28 of file image_generator_registry.h.

Constructor & Destructor Documentation

◆ ImageGeneratorRegistry()

flutter::ImageGeneratorRegistry::ImageGeneratorRegistry ( )

Definition at line 21 of file image_generator_registry.cc.

21 : weak_factory_(this) {
23 [](sk_sp<SkData> buffer) {
24 return APNGImageGenerator::MakeFromData(std::move(buffer));
25 },
26 0);
27
29 [](sk_sp<SkData> buffer) {
30 return BuiltinSkiaCodecImageGenerator::MakeFromData(std::move(buffer));
31 },
32 0);
33
34 // todo(bdero): https://github.com/flutter/flutter/issues/82603
35#ifdef FML_OS_MACOSX
37 [](sk_sp<SkData> buffer) {
38 auto generator =
39 SkImageGeneratorCG::MakeFromEncodedCG(std::move(buffer));
41 std::move(generator));
42 },
43 0);
44#elif FML_OS_WIN
46 [](sk_sp<SkData> buffer) {
47 auto generator = SkImageGeneratorWIC::MakeFromEncodedWIC(buffer);
49 std::move(generator));
50 },
51 0);
52#endif
53}
static std::unique_ptr< ImageGenerator > MakeFromData(sk_sp< SkData > data)
static std::unique_ptr< ImageGenerator > MakeFromData(sk_sp< SkData > data)
static std::unique_ptr< ImageGenerator > MakeFromGenerator(std::unique_ptr< SkImageGenerator > generator)
void AddFactory(ImageGeneratorFactory factory, int32_t priority)
Install a new factory for image generators.

References AddFactory(), flutter::buffer, flutter::BuiltinSkiaCodecImageGenerator::MakeFromData(), flutter::APNGImageGenerator::MakeFromData(), and flutter::BuiltinSkiaImageGenerator::MakeFromGenerator().

◆ ~ImageGeneratorRegistry()

flutter::ImageGeneratorRegistry::~ImageGeneratorRegistry ( )
default

References callback.

Member Function Documentation

◆ AddFactory()

void flutter::ImageGeneratorRegistry::AddFactory ( ImageGeneratorFactory  factory,
int32_t  priority 
)

Install a new factory for image generators.

Parameters
[in]factoryCallback that produces ImageGenerators for compatible input data.
[in]priorityThe priority used to determine the order in which factories are tried. Higher values mean higher priority. The built-in Skia decoders are installed at priority 0, and so a priority > 0 takes precedent over the builtin decoders. When multiple decoders are added with the same priority, those which are added earlier take precedent.
See also
CreateCompatibleGenerator

Definition at line 57 of file image_generator_registry.cc.

58 {
59 image_generator_factories_.insert({std::move(factory), priority, ++nonce_});
60}

Referenced by ImageGeneratorRegistry(), flutter::testing::TEST_F(), flutter::testing::TEST_F(), flutter::testing::TEST_F(), and flutter::testing::TEST_F().

◆ CreateCompatibleGenerator()

std::shared_ptr< ImageGenerator > flutter::ImageGeneratorRegistry::CreateCompatibleGenerator ( const sk_sp< SkData > &  buffer)

Walks the list of image generator builders in descending priority order until a compatible ImageGenerator is able to be built. This method is safe to perform on the UI thread, as checking for ImageGenerator compatibility is expected to be a lightweight operation. The returned ImageGenerator can then be used to fully decode the image on e.g. the IO thread.

Parameters
[in]bufferThe raw encoded image data.
Returns
An ImageGenerator that is compatible with the input buffer. If no compatible ImageGenerator type was found, then std::shared_ptr<ImageGenerator>(nullptr) is returned.
See also
ImageGenerator

Definition at line 63 of file image_generator_registry.cc.

63 {
64 if (!image_generator_factories_.size()) {
65 FML_LOG(WARNING)
66 << "There are currently no image decoders installed. If you're writing "
67 "your own platform embedding, you can register new image decoders "
68 "via `ImageGeneratorRegistry::AddFactory` on the "
69 "`ImageGeneratorRegistry` provided by the engine. Otherwise, please "
70 "file a bug on https://github.com/flutter/flutter/issues.";
71 }
72
73 for (auto& factory : image_generator_factories_) {
74 std::shared_ptr<ImageGenerator> result = factory.callback(buffer);
75 if (result) {
76 return result;
77 }
78 }
79 return nullptr;
80}
#define FML_LOG(severity)
Definition logging.h:101

References flutter::buffer, and FML_LOG.

Referenced by flutter::testing::TEST(), flutter::testing::TEST(), flutter::testing::TEST(), flutter::testing::TEST(), flutter::testing::TEST(), flutter::testing::TEST(), flutter::testing::TEST(), flutter::testing::TEST_F(), flutter::testing::TEST_F(), flutter::testing::TEST_F(), flutter::testing::TEST_F(), flutter::testing::TEST_F(), flutter::testing::TEST_F(), flutter::testing::TEST_F(), flutter::testing::TEST_F(), flutter::testing::TEST_F(), flutter::testing::TEST_F(), flutter::testing::TEST_F(), flutter::testing::TEST_F(), flutter::testing::TEST_F(), and flutter::testing::TEST_F().

◆ GetWeakPtr()

fml::TaskRunnerAffineWeakPtr< ImageGeneratorRegistry > flutter::ImageGeneratorRegistry::GetWeakPtr ( ) const

Definition at line 83 of file image_generator_registry.cc.

83 {
84 return weak_factory_.GetWeakPtr();
85}

Referenced by flutter::Engine::GetImageGeneratorRegistry().


The documentation for this class was generated from the following files: