blob: eef8dff94ce2afa93dc624fc811faabdcccfd03d [file] [log] [blame]
Vishnu Nair8fc721b2022-12-22 20:06:32 +00001/*
2 * Copyright 2022 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#pragma once
18
19#include <compositionengine/LayerFECompositionState.h>
20#include <renderengine/LayerSettings.h>
Vishnu Naira02943f2023-06-03 13:44:46 -070021#include "DisplayHardware/ComposerHal.h"
Vishnu Nair8fc721b2022-12-22 20:06:32 +000022#include "LayerHierarchy.h"
23#include "RequestedLayerState.h"
Vishnu Naircfb2d252023-01-19 04:44:02 +000024#include "Scheduler/LayerInfo.h"
Vishnu Nair8fc721b2022-12-22 20:06:32 +000025#include "android-base/stringprintf.h"
26
27namespace android::surfaceflinger::frontend {
28
29struct RoundedCornerState {
30 RoundedCornerState() = default;
31 RoundedCornerState(const FloatRect& cropRect, const vec2& radius)
32 : cropRect(cropRect), radius(radius) {}
33
34 // Rounded rectangle in local layer coordinate space.
35 FloatRect cropRect = FloatRect();
36 // Radius of the rounded rectangle.
37 vec2 radius;
38 bool hasRoundedCorners() const { return radius.x > 0.0f && radius.y > 0.0f; }
39 bool operator==(RoundedCornerState const& rhs) const {
40 return cropRect == rhs.cropRect && radius == rhs.radius;
41 }
42};
43
44// LayerSnapshot stores Layer state used by CompositionEngine and RenderEngine. Composition
45// Engine uses a pointer to LayerSnapshot (as LayerFECompositionState*) and the LayerSettings
46// passed to Render Engine are created using properties stored on this struct.
47struct LayerSnapshot : public compositionengine::LayerFECompositionState {
48 LayerSnapshot() = default;
49 LayerSnapshot(const RequestedLayerState&, const LayerHierarchy::TraversalPath&);
50
51 LayerHierarchy::TraversalPath path;
52 size_t globalZ = std::numeric_limits<ssize_t>::max();
53 bool invalidTransform = false;
54 bool isHiddenByPolicyFromParent = false;
55 bool isHiddenByPolicyFromRelativeParent = false;
56 ftl::Flags<RequestedLayerState::Changes> changes;
Vishnu Naira02943f2023-06-03 13:44:46 -070057 uint64_t clientChanges = 0;
Vishnu Nair93b8b792023-02-27 19:40:24 +000058 // Some consumers of this snapshot (input, layer traces) rely on each snapshot to be unique.
59 // For mirrored layers, snapshots will have the same sequence so this unique id provides
60 // an alternative identifier when needed.
61 uint32_t uniqueSequence;
62 // Layer id used to create this snapshot. Multiple snapshots will have the same sequence if they
63 // generated from the same layer, for example when mirroring.
Vishnu Nair8fc721b2022-12-22 20:06:32 +000064 int32_t sequence;
65 std::string name;
Vishnu Nair3cc15a42023-06-30 06:20:22 +000066 std::string debugName;
Vishnu Nair8fc721b2022-12-22 20:06:32 +000067 bool contentOpaque;
68 bool layerOpaqueFlagSet;
69 RoundedCornerState roundedCorner;
70 FloatRect transformedBounds;
Vishnu Naircfb2d252023-01-19 04:44:02 +000071 Rect transformedBoundsWithoutTransparentRegion;
Vishnu Nair8fc721b2022-12-22 20:06:32 +000072 bool premultipliedAlpha;
Vishnu Nair8fc721b2022-12-22 20:06:32 +000073 ui::Transform parentTransform;
74 Rect bufferSize;
75 Rect croppedBufferSize;
76 std::shared_ptr<renderengine::ExternalTexture> externalTexture;
77 gui::LayerMetadata layerMetadata;
78 gui::LayerMetadata relativeLayerMetadata;
Vishnu Nair6f209e22023-08-04 16:33:23 +000079 bool hasReadyFrame; // used in post composition to check if there is another frame ready
Vishnu Nair8fc721b2022-12-22 20:06:32 +000080 ui::Transform localTransformInverse;
81 gui::WindowInfo inputInfo;
82 ui::Transform localTransform;
Vishnu Nair491827d2024-04-29 23:43:26 +000083 // set to true if this snapshot will ignore local transforms. Used when the snapshot
84 // is a mirror root
85 bool ignoreLocalTransform;
Vishnu Nair8fc721b2022-12-22 20:06:32 +000086 gui::DropInputMode dropInputMode;
87 bool isTrustedOverlay;
Vishnu Naircfb2d252023-01-19 04:44:02 +000088 gui::GameMode gameMode;
89 scheduler::LayerInfo::FrameRate frameRate;
Vishnu Nair30515cb2023-10-19 21:54:08 -070090 scheduler::LayerInfo::FrameRate inheritedFrameRate;
Rachel Lee58cc90d2023-09-05 18:50:20 -070091 scheduler::LayerInfo::FrameRateSelectionStrategy frameRateSelectionStrategy;
Vishnu Nair80e8cfe2023-09-29 17:03:45 -070092 scheduler::FrameRateCompatibility defaultFrameRateCompatibility =
93 scheduler::FrameRateCompatibility::Default;
Vishnu Naircfb2d252023-01-19 04:44:02 +000094 ui::Transform::RotationFlags fixedTransformHint;
Vishnu Nairb76d99a2023-03-19 18:22:31 -070095 std::optional<ui::Transform::RotationFlags> transformHint;
Vishnu Naira9c43762023-01-27 19:10:25 +000096 bool handleSkipScreenshotFlag = false;
Vishnu Nair3d8565a2023-06-30 07:23:24 +000097 int32_t frameRateSelectionPriority = -1;
Vishnu Nair92990e22023-02-24 20:01:05 +000098 LayerHierarchy::TraversalPath mirrorRootPath;
Vishnu Nair29354ec2023-03-28 18:51:28 -070099 uint32_t touchCropId;
Vishnu Naira02943f2023-06-03 13:44:46 -0700100 gui::Uid uid = gui::Uid::INVALID;
101 gui::Pid pid = gui::Pid::INVALID;
Vishnu Naira02943f2023-06-03 13:44:46 -0700102 enum class Reachablilty : uint32_t {
103 // Can traverse the hierarchy from a root node and reach this snapshot
104 Reachable,
105 // Cannot traverse the hierarchy from a root node and reach this snapshot
106 Unreachable,
107 // Can only reach this node from a relative parent. This means the nodes parents are
108 // not reachable.
109 // See example scenario:
110 // ROOT
111 // ├── 1
112 // │ ├── 11
113 // │ │ └── 111
114 // │ ├── 12
115 // │ │ └ - 111 (relative)
116 // │ ├── 13
117 // │ └── 14
118 // │ └ * 12 (mirroring)
119 // └── 2
120 // 111 will create two snapshots, first when visited from 1 -> 12 or 1 -> 11 and the
121 // second when visited from 1 -> 14 -> 12. Because its parent 11 doesn't exist in the
122 // mirrored hierarchy, the second snapshot will be marked as ReachableByRelativeParent.
123 // This snapshot doesn't have any valid properties because it cannot inherit from its
124 // parent. Therefore, snapshots that are not reachable will be ignored for composition
125 // and input.
126 ReachableByRelativeParent
127 };
128 Reachablilty reachablilty;
Arthur Hung69f95222023-10-04 07:39:02 +0000129 // True when the surfaceDamage is recognized as a small area update.
130 bool isSmallDirty = false;
Vishnu Nair8fc721b2022-12-22 20:06:32 +0000131
132 static bool isOpaqueFormat(PixelFormat format);
133 static bool isTransformValid(const ui::Transform& t);
134
135 bool canReceiveInput() const;
136 bool drawShadows() const;
137 bool fillsColor() const;
138 bool getIsVisible() const;
139 bool hasBlur() const;
140 bool hasBufferOrSidebandStream() const;
141 bool hasEffect() const;
142 bool hasSomethingToDraw() const;
143 bool isContentOpaque() const;
144 bool isHiddenByPolicy() const;
145 std::string getDebugString() const;
146 std::string getIsVisibleReason() const;
Vishnu Naircfb2d252023-01-19 04:44:02 +0000147 bool hasInputInfo() const;
Vishnu Nair781d7252023-01-30 18:16:01 +0000148 FloatRect sourceBounds() const;
Alec Mouri89f5d4e2023-10-20 17:12:49 +0000149 bool isFrontBuffered() const;
Vishnu Naira02943f2023-06-03 13:44:46 -0700150 Hwc2::IComposerClient::BlendMode getBlendMode(const RequestedLayerState& requested) const;
Vishnu Nair3cc15a42023-06-30 06:20:22 +0000151 friend std::ostream& operator<<(std::ostream& os, const LayerSnapshot& obj);
Vishnu Naira02943f2023-06-03 13:44:46 -0700152 void merge(const RequestedLayerState& requested, bool forceUpdate, bool displayChanges,
153 bool forceFullDamage, uint32_t displayRotationFlags);
Vishnu Nair8fc721b2022-12-22 20:06:32 +0000154};
155
156} // namespace android::surfaceflinger::frontend