Manages the lifetime of the on-screen and off-screen rendering contexts on iOS. On-screen contexts are used by Flutter for rendering into the surface. The lifecycle of this context may be tied to the lifecycle of the surface. On the other hand, the lifecycle of the off-screen context it tied to that of the platform view. This one object used to manage both context because GPU handles may need to be shared between the two context. To achieve this, context may need references to one another at creation time. This one object manages the creation, use and collection of both contexts in a client rendering API agnostic manner.
More...
#include <ios_context.h>
|
static std::unique_ptr< IOSContext > | Create (IOSRenderingAPI api, IOSRenderingBackend backend, const std::shared_ptr< const fml::SyncSwitch > &is_gpu_disabled_sync_switch) |
| Create an iOS context object capable of creating the on-screen and off-screen GPU context for use by Impeller. More...
|
|
Manages the lifetime of the on-screen and off-screen rendering contexts on iOS. On-screen contexts are used by Flutter for rendering into the surface. The lifecycle of this context may be tied to the lifecycle of the surface. On the other hand, the lifecycle of the off-screen context it tied to that of the platform view. This one object used to manage both context because GPU handles may need to be shared between the two context. To achieve this, context may need references to one another at creation time. This one object manages the creation, use and collection of both contexts in a client rendering API agnostic manner.
Definition at line 38 of file ios_context.h.
◆ ~IOSContext()
flutter::IOSContext::~IOSContext |
( |
| ) |
|
|
virtualdefault |
Collects the context object. This must happen on the thread on which this object was created.
◆ IOSContext()
flutter::IOSContext::IOSContext |
( |
| ) |
|
|
explicitprotecteddefault |
◆ Create()
Create an iOS context object capable of creating the on-screen and off-screen GPU context for use by Impeller.
In case the engine does not support the specified client rendering API, this a nullptr
may be returned.
- Parameters
-
[in] | api | A client rendering API supported by the engine/platform. |
[in] | backend | A client rendering backend supported by the engine/platform. |
- Returns
- A valid context on success.
nullptr
on failure.
Definition at line 21 of file ios_context.mm.
28 <<
"Software rendering is incompatible with Impeller.\n"
29 "Software rendering may have been automatically selected when running on a "
31 "in an environment that does not support Metal. Enabling GPU passthrough in your "
32 "environment may fix this.";
33 return std::make_unique<IOSContextNoop>();
37 FML_LOG(FATAL) <<
"Impeller opt-out unavailable.";
40 return std::make_unique<IOSContextMetalImpeller>(is_gpu_disabled_sync_switch);
References flutter::kImpeller, flutter::kMetal, flutter::kSkia, and flutter::kSoftware.
◆ CreateExternalTexture()
virtual std::unique_ptr<Texture> flutter::IOSContext::CreateExternalTexture |
( |
int64_t |
texture_id, |
|
|
NSObject< FlutterTexture > * |
texture |
|
) |
| |
|
pure virtual |
Creates an external texture proxy of the appropriate client rendering API.
- Parameters
-
[in] | texture_id | The texture identifier |
[in] | texture | The texture |
- Returns
- The texture proxy if the rendering backend supports embedder provided external textures.
Implemented in flutter::IOSContextNoop.
◆ GetAiksContext()
std::shared_ptr< impeller::AiksContext > flutter::IOSContext::GetAiksContext |
( |
| ) |
const |
|
virtual |
◆ GetBackend()
◆ GetImpellerContext()
std::shared_ptr< impeller::Context > flutter::IOSContext::GetImpellerContext |
( |
| ) |
const |
|
virtual |
The documentation for this class was generated from the following files: