Flutter Engine Uber Docs
Docs for the entire Flutter Engine repo.
 
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 47 of file image_generator_registry.cc.

47 : weak_factory_(this) {
49 [](sk_sp<SkData> buffer) {
50 return APNGImageGenerator::MakeFromData(std::move(buffer));
51 },
52 0);
53
54 static std::once_flag register_skia_codecs;
55 std::call_once(register_skia_codecs, RegisterSkiaCodecs);
57 [](sk_sp<SkData> buffer) {
58 return BuiltinSkiaCodecImageGenerator::MakeFromData(std::move(buffer));
59 },
60 0);
61
62 // todo(bdero): https://github.com/flutter/flutter/issues/82603
63#ifdef FML_OS_MACOSX
65 [](sk_sp<SkData> buffer) {
66 auto generator =
67 SkImageGeneratorCG::MakeFromEncodedCG(std::move(buffer));
69 std::move(generator));
70 },
71 0);
72#elif FML_OS_WIN
74 [](sk_sp<SkData> buffer) {
75 auto generator = SkImageGeneratorWIC::MakeFromEncodedWIC(buffer);
77 std::move(generator));
78 },
79 0);
80#endif
81}
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 85 of file image_generator_registry.cc.

86 {
87 image_generator_factories_.insert({std::move(factory), priority, ++nonce_});
88}

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 91 of file image_generator_registry.cc.

91 {
92 if (!image_generator_factories_.size()) {
93 FML_LOG(WARNING)
94 << "There are currently no image decoders installed. If you're writing "
95 "your own platform embedding, you can register new image decoders "
96 "via `ImageGeneratorRegistry::AddFactory` on the "
97 "`ImageGeneratorRegistry` provided by the engine. Otherwise, please "
98 "file a bug on https://github.com/flutter/flutter/issues.";
99 }
100
101 for (auto& factory : image_generator_factories_) {
102 std::shared_ptr<ImageGenerator> result = factory.callback(buffer);
103 if (result) {
104 return result;
105 }
106 }
107 return nullptr;
108}
#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 111 of file image_generator_registry.cc.

111 {
112 return weak_factory_.GetWeakPtr();
113}

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


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