Flutter Engine
The Flutter Engine
Loading...
Searching...
No Matches
Classes | Public Types | Public Member Functions | Static Public Member Functions | List of all members
impeller::android::SurfaceTransaction Class Reference

A wrapper for ASurfaceTransaction. https://developer.android.com/ndk/reference/group/native-activity#asurfacetransaction. More...

#include <surface_transaction.h>

Public Types

using OnCompleteCallback = std::function< void(void)>
 

Public Member Functions

 SurfaceTransaction ()
 
 ~SurfaceTransaction ()
 
 SurfaceTransaction (const SurfaceTransaction &)=delete
 
SurfaceTransactionoperator= (const SurfaceTransaction &)=delete
 
bool IsValid () const
 
bool SetContents (const SurfaceControl *control, const HardwareBuffer *buffer)
 Encodes that the updated contents of a surface control are specified by the given hardware buffer. The update will not be committed till the call to Apply however.
 
bool SetBackgroundColor (const SurfaceControl &control, const Color &color)
 Encodes the updated background color of the surface control. The update will not be committed till the call to Apply however.
 
bool Apply (OnCompleteCallback callback=nullptr)
 Applies the updated encoded in the transaction and invokes the callback when the updated are complete.
 
bool SetParent (const SurfaceControl &control, const SurfaceControl *new_parent=nullptr)
 Set the new parent control of the given control. If the new parent is null, it is removed from the control hierarchy.
 

Static Public Member Functions

static bool IsAvailableOnPlatform ()
 

Detailed Description

A wrapper for ASurfaceTransaction. https://developer.android.com/ndk/reference/group/native-activity#asurfacetransaction.

A surface transaction is a collection of updates to the hierarchy of surfaces (represented by ASurfaceControl instances) that are applied atomically in the compositor.

This wrapper is only available on Android API 29 and above.

Note
Transactions should be short lived objects (create, apply, collect). But, if these are used on multiple threads, they must be externally synchronized.

Definition at line 34 of file surface_transaction.h.

Member Typedef Documentation

◆ OnCompleteCallback

Definition at line 83 of file surface_transaction.h.

Constructor & Destructor Documentation

◆ SurfaceTransaction() [1/2]

impeller::android::SurfaceTransaction::SurfaceTransaction ( )

Definition at line 13 of file surface_transaction.cc.

14 : transaction_(GetProcTable().ASurfaceTransaction_create()) {}
const ProcTable & GetProcTable()
Definition proc_table.cc:12

◆ ~SurfaceTransaction()

impeller::android::SurfaceTransaction::~SurfaceTransaction ( )
default

◆ SurfaceTransaction() [2/2]

impeller::android::SurfaceTransaction::SurfaceTransaction ( const SurfaceTransaction )
delete

Member Function Documentation

◆ Apply()

bool impeller::android::SurfaceTransaction::Apply ( OnCompleteCallback  callback = nullptr)

Applies the updated encoded in the transaction and invokes the callback when the updated are complete.

Warning
The callback will be invoked on a system managed thread.
Note
It is fine to immediately destroy the transaction after the call to apply. It is not necessary to wait for transaction completion to collect the transaction handle.
Parameters
[in]callbackThe callback
Returns
true if the surface transaction was applied. true does not indicate the application was completed however. Only the invocation of the callback denotes transaction completion.

Definition at line 26 of file surface_transaction.cc.

26 {
27 if (!IsValid()) {
28 return false;
29 }
30
31 if (!callback) {
32 callback = []() {};
33 }
34
35 const auto& proc_table = GetProcTable();
36
37 auto data = std::make_unique<TransactionInFlightData>();
38 data->callback = callback;
39 proc_table.ASurfaceTransaction_setOnComplete(
40 transaction_.get(), //
41 data.release(), //
42 [](void* context, ASurfaceTransactionStats* stats) -> void {
43 auto data = reinterpret_cast<TransactionInFlightData*>(context);
44 data->callback();
45 delete data;
46 });
47 proc_table.ASurfaceTransaction_apply(transaction_.get());
48
49 // Transactions may not be applied over and over.
50 transaction_.reset();
51 return true;
52}
void reset(const T &value=Traits::InvalidValue())
const T & get() const
FlKeyEvent uint64_t FlKeyResponderAsyncCallback callback
DEF_SWITCHES_START aot vmservice shared library Name of the *so containing AOT compiled Dart assets for launching the service isolate vm snapshot data
Definition switches.h:41

◆ IsAvailableOnPlatform()

bool impeller::android::SurfaceTransaction::IsAvailableOnPlatform ( )
static
Returns
true if any surface transactions can be created on this platform.

Definition at line 99 of file surface_transaction.cc.

99 {
100 return GetProcTable().IsValid() &&
101 GetProcTable().ASurfaceTransaction_create.IsAvailable();
102}
bool IsValid() const
If a valid proc table could be setup. This may fail in case of setup on non-Android platforms.
Definition proc_table.cc:65

◆ IsValid()

bool impeller::android::SurfaceTransaction::IsValid ( ) const

Definition at line 18 of file surface_transaction.cc.

18 {
19 return transaction_.is_valid();
20}
bool is_valid() const

◆ operator=()

SurfaceTransaction & impeller::android::SurfaceTransaction::operator= ( const SurfaceTransaction )
delete

◆ SetBackgroundColor()

bool impeller::android::SurfaceTransaction::SetBackgroundColor ( const SurfaceControl control,
const Color color 
)

Encodes the updated background color of the surface control. The update will not be committed till the call to Apply however.

See also
SurfaceTransaction::Apply.
Parameters
[in]controlThe control
[in]colorThe color
Returns
true if the background control will be set when transaction is applied.

Definition at line 67 of file surface_transaction.cc.

68 {
69 if (!IsValid() || !control.IsValid()) {
70 return false;
71 }
72 GetProcTable().ASurfaceTransaction_setColor(transaction_.get(), //
73 control.GetHandle(), //
74 color.red, //
75 color.green, //
76 color.blue, //
77 color.alpha, //
78 ADATASPACE_SRGB_LINEAR //
79 );
80 return true;
81}
SkColor4f color

◆ SetContents()

bool impeller::android::SurfaceTransaction::SetContents ( const SurfaceControl control,
const HardwareBuffer buffer 
)

Encodes that the updated contents of a surface control are specified by the given hardware buffer. The update will not be committed till the call to Apply however.

See also
SurfaceTransaction::Apply.
Parameters
[in]controlThe control
[in]bufferThe hardware buffer
Returns
If the update was encoded in the transaction.

Definition at line 54 of file surface_transaction.cc.

55 {
56 if (control == nullptr || buffer == nullptr) {
57 VALIDATION_LOG << "Invalid control or buffer.";
58 return false;
59 }
60 GetProcTable().ASurfaceTransaction_setBuffer(transaction_.get(), //
61 control->GetHandle(), //
62 buffer->GetHandle(), //
63 -1);
64 return true;
65}
static const uint8_t buffer[]
#define VALIDATION_LOG
Definition validation.h:73

◆ SetParent()

bool impeller::android::SurfaceTransaction::SetParent ( const SurfaceControl control,
const SurfaceControl new_parent = nullptr 
)

Set the new parent control of the given control. If the new parent is null, it is removed from the control hierarchy.

Parameters
[in]controlThe control
[in]new_parentThe new parent
Returns
true if the control will be re-parented when the transaction is applied.

Definition at line 83 of file surface_transaction.cc.

84 {
85 if (!IsValid() || !control.IsValid()) {
86 return false;
87 }
88 if (new_parent && !new_parent->IsValid()) {
89 return false;
90 }
91 GetProcTable().ASurfaceTransaction_reparent(
92 transaction_.get(), //
93 control.GetHandle(), //
94 new_parent == nullptr ? nullptr : new_parent->GetHandle() //
95 );
96 return true;
97}

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