13 OwningContext owning_context) {
17 return sk_sp<DlImageImpeller>(
23 std::shared_ptr<Texture> y_texture,
24 std::shared_ptr<Texture> uv_texture,
26 if (!aiks_context || !y_texture || !uv_texture) {
30 std::move(y_texture), std::move(uv_texture), yuv_color_space);
38 fml::ScopedCleanupClosure restore_cache(
39 [&] { renderer.GetRenderTargetCache()->EnableCache(); });
41 std::optional<Snapshot> snapshot =
42 yuv_to_rgb_filter_contents->RenderToSnapshot(
44 {.coverage_limit = std::nullopt,
45 .sampler_descriptor = std::nullopt,
48 .label =
"MakeYUVToRGBFilter Snapshot"});
49 if (!snapshot.has_value()) {
55 DlImageImpeller::DlImageImpeller(std::shared_ptr<Texture> texture,
56 OwningContext owning_context)
57 : texture_(
std::move(texture)), owning_context_(owning_context) {}
94 return texture_ ? flutter::DlISize(texture_->GetSize()) : flutter::DlISize();
99 auto size =
sizeof(*this);
101 size += texture_->GetTextureDescriptor().GetByteSizeOfBaseMipLevel();
ContentContext & GetContentContext() const
const std::shared_ptr< RenderTargetAllocator > & GetRenderTargetCache() const
size_t GetApproximateByteSize() const override
static sk_sp< DlImageImpeller > MakeFromYUVTextures(AiksContext *aiks_context, std::shared_ptr< Texture > y_texture, std::shared_ptr< Texture > uv_texture, YUVColorSpace yuv_color_space)
bool isTextureBacked() const override
std::shared_ptr< impeller::Texture > impeller_texture() const override
static sk_sp< DlImageImpeller > Make(std::shared_ptr< Texture > texture, OwningContext owning_context=OwningContext::kIO)
flutter::DlISize GetSize() const override
sk_sp< SkImage > skia_image() const override
~DlImageImpeller() override
bool isUIThreadSafe() const override
bool isOpaque() const override
OwningContext owning_context() const override
void SetBlendMode(BlendMode blend_mode)
static std::shared_ptr< FilterContents > MakeYUVToRGBFilter(std::shared_ptr< Texture > y_texture, std::shared_ptr< Texture > uv_texture, YUVColorSpace yuv_color_space)