Flutter Impeller
surface_transaction.cc
Go to the documentation of this file.
1 // Copyright 2013 The Flutter Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
6 
10 
11 namespace impeller::android {
12 
14  : transaction_(GetProcTable().ASurfaceTransaction_create()) {}
15 
17 
19  return transaction_.is_valid();
20 }
21 
24 };
25 
27  if (!IsValid()) {
28  return false;
29  }
30 
31  if (!callback) {
32  callback = [](auto) {};
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(stats);
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 }
53 
55  const HardwareBuffer* buffer,
56  fml::UniqueFD acquire_fence) {
57  if (control == nullptr || buffer == nullptr) {
58  VALIDATION_LOG << "Invalid control or buffer.";
59  return false;
60  }
61  GetProcTable().ASurfaceTransaction_setBuffer(
62  transaction_.get(), //
63  control->GetHandle(), //
64  buffer->GetHandle(), //
65  acquire_fence.is_valid() ? acquire_fence.release() : -1 //
66  );
67  return true;
68 }
69 
71  const Color& color) {
72  if (!IsValid() || !control.IsValid()) {
73  return false;
74  }
75  GetProcTable().ASurfaceTransaction_setColor(transaction_.get(), //
76  control.GetHandle(), //
77  color.red, //
78  color.green, //
79  color.blue, //
80  color.alpha, //
81  ADATASPACE_SRGB_LINEAR //
82  );
83  return true;
84 }
85 
87  const SurfaceControl* new_parent) {
88  if (!IsValid() || !control.IsValid()) {
89  return false;
90  }
91  if (new_parent && !new_parent->IsValid()) {
92  return false;
93  }
94  GetProcTable().ASurfaceTransaction_reparent(
95  transaction_.get(), //
96  control.GetHandle(), //
97  new_parent == nullptr ? nullptr : new_parent->GetHandle() //
98  );
99  return true;
100 }
101 
103  return GetProcTable().IsValid() &&
104  GetProcTable().ASurfaceTransaction_create.IsAvailable();
105 }
106 
107 } // namespace impeller::android
A wrapper for AHardwareBuffer https://developer.android.com/ndk/reference/group/a-hardware-buffer.
AHardwareBuffer * GetHandle() const
A wrapper for ASurfaceControl. https://developer.android.com/ndk/reference/group/native-activity#asur...
ASurfaceControl * GetHandle() const
bool SetContents(const SurfaceControl *control, const HardwareBuffer *buffer, fml::UniqueFD acquire_fence={})
Encodes that the updated contents of a surface control are specified by the given hardware buffer....
std::function< void(ASurfaceTransactionStats *)> OnCompleteCallback
bool Apply(OnCompleteCallback callback=nullptr)
Applies the updated encoded in the transaction and invokes the callback when the updated are complete...
bool SetBackgroundColor(const SurfaceControl &control, const Color &color)
Encodes the updated background color of the surface control. The update will not be committed till th...
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 co...
const ProcTable & GetProcTable()
Definition: proc_table.cc:12
Scalar blue
Definition: color.h:137
Scalar alpha
Definition: color.h:142
Scalar red
Definition: color.h:127
Scalar green
Definition: color.h:132
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
SurfaceTransaction::OnCompleteCallback callback
std::shared_ptr< const fml::Mapping > data
Definition: texture_gles.cc:64
#define VALIDATION_LOG
Definition: validation.h:91