Vishnu Nair | 8fc721b | 2022-12-22 20:06:32 +0000 | [diff] [blame] | 1 | /* |
| 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 Nair | a02943f | 2023-06-03 13:44:46 -0700 | [diff] [blame] | 21 | #include "DisplayHardware/ComposerHal.h" |
Vishnu Nair | 8fc721b | 2022-12-22 20:06:32 +0000 | [diff] [blame] | 22 | #include "LayerHierarchy.h" |
| 23 | #include "RequestedLayerState.h" |
Vishnu Nair | cfb2d25 | 2023-01-19 04:44:02 +0000 | [diff] [blame] | 24 | #include "Scheduler/LayerInfo.h" |
Vishnu Nair | 8fc721b | 2022-12-22 20:06:32 +0000 | [diff] [blame] | 25 | #include "android-base/stringprintf.h" |
| 26 | |
| 27 | namespace android::surfaceflinger::frontend { |
| 28 | |
| 29 | struct 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. |
| 47 | struct 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 Nair | a02943f | 2023-06-03 13:44:46 -0700 | [diff] [blame] | 57 | uint64_t clientChanges = 0; |
Vishnu Nair | 93b8b79 | 2023-02-27 19:40:24 +0000 | [diff] [blame] | 58 | // 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 Nair | 8fc721b | 2022-12-22 20:06:32 +0000 | [diff] [blame] | 64 | int32_t sequence; |
| 65 | std::string name; |
Vishnu Nair | 3cc15a4 | 2023-06-30 06:20:22 +0000 | [diff] [blame] | 66 | std::string debugName; |
Vishnu Nair | 8fc721b | 2022-12-22 20:06:32 +0000 | [diff] [blame] | 67 | bool contentOpaque; |
| 68 | bool layerOpaqueFlagSet; |
| 69 | RoundedCornerState roundedCorner; |
| 70 | FloatRect transformedBounds; |
Vishnu Nair | cfb2d25 | 2023-01-19 04:44:02 +0000 | [diff] [blame] | 71 | Rect transformedBoundsWithoutTransparentRegion; |
Vishnu Nair | 8fc721b | 2022-12-22 20:06:32 +0000 | [diff] [blame] | 72 | renderengine::ShadowSettings shadowSettings; |
| 73 | bool premultipliedAlpha; |
Vishnu Nair | 8fc721b | 2022-12-22 20:06:32 +0000 | [diff] [blame] | 74 | ui::Transform parentTransform; |
| 75 | Rect bufferSize; |
| 76 | Rect croppedBufferSize; |
| 77 | std::shared_ptr<renderengine::ExternalTexture> externalTexture; |
| 78 | gui::LayerMetadata layerMetadata; |
| 79 | gui::LayerMetadata relativeLayerMetadata; |
Vishnu Nair | 6f209e2 | 2023-08-04 16:33:23 +0000 | [diff] [blame] | 80 | bool hasReadyFrame; // used in post composition to check if there is another frame ready |
Vishnu Nair | 8fc721b | 2022-12-22 20:06:32 +0000 | [diff] [blame] | 81 | ui::Transform localTransformInverse; |
| 82 | gui::WindowInfo inputInfo; |
| 83 | ui::Transform localTransform; |
| 84 | gui::DropInputMode dropInputMode; |
| 85 | bool isTrustedOverlay; |
Vishnu Nair | cfb2d25 | 2023-01-19 04:44:02 +0000 | [diff] [blame] | 86 | gui::GameMode gameMode; |
| 87 | scheduler::LayerInfo::FrameRate frameRate; |
Rachel Lee | 58cc90d | 2023-09-05 18:50:20 -0700 | [diff] [blame] | 88 | scheduler::LayerInfo::FrameRateSelectionStrategy frameRateSelectionStrategy; |
Vishnu Nair | 80e8cfe | 2023-09-29 17:03:45 -0700 | [diff] [blame^] | 89 | scheduler::FrameRateCompatibility defaultFrameRateCompatibility = |
| 90 | scheduler::FrameRateCompatibility::Default; |
Vishnu Nair | cfb2d25 | 2023-01-19 04:44:02 +0000 | [diff] [blame] | 91 | ui::Transform::RotationFlags fixedTransformHint; |
Vishnu Nair | b76d99a | 2023-03-19 18:22:31 -0700 | [diff] [blame] | 92 | std::optional<ui::Transform::RotationFlags> transformHint; |
Vishnu Nair | a9c4376 | 2023-01-27 19:10:25 +0000 | [diff] [blame] | 93 | bool handleSkipScreenshotFlag = false; |
Vishnu Nair | 3d8565a | 2023-06-30 07:23:24 +0000 | [diff] [blame] | 94 | int32_t frameRateSelectionPriority = -1; |
Vishnu Nair | 92990e2 | 2023-02-24 20:01:05 +0000 | [diff] [blame] | 95 | LayerHierarchy::TraversalPath mirrorRootPath; |
Vishnu Nair | 29354ec | 2023-03-28 18:51:28 -0700 | [diff] [blame] | 96 | uint32_t touchCropId; |
Vishnu Nair | a02943f | 2023-06-03 13:44:46 -0700 | [diff] [blame] | 97 | gui::Uid uid = gui::Uid::INVALID; |
| 98 | gui::Pid pid = gui::Pid::INVALID; |
Vishnu Nair | a02943f | 2023-06-03 13:44:46 -0700 | [diff] [blame] | 99 | enum class Reachablilty : uint32_t { |
| 100 | // Can traverse the hierarchy from a root node and reach this snapshot |
| 101 | Reachable, |
| 102 | // Cannot traverse the hierarchy from a root node and reach this snapshot |
| 103 | Unreachable, |
| 104 | // Can only reach this node from a relative parent. This means the nodes parents are |
| 105 | // not reachable. |
| 106 | // See example scenario: |
| 107 | // ROOT |
| 108 | // ├── 1 |
| 109 | // │ ├── 11 |
| 110 | // │ │ └── 111 |
| 111 | // │ ├── 12 |
| 112 | // │ │ └ - 111 (relative) |
| 113 | // │ ├── 13 |
| 114 | // │ └── 14 |
| 115 | // │ └ * 12 (mirroring) |
| 116 | // └── 2 |
| 117 | // 111 will create two snapshots, first when visited from 1 -> 12 or 1 -> 11 and the |
| 118 | // second when visited from 1 -> 14 -> 12. Because its parent 11 doesn't exist in the |
| 119 | // mirrored hierarchy, the second snapshot will be marked as ReachableByRelativeParent. |
| 120 | // This snapshot doesn't have any valid properties because it cannot inherit from its |
| 121 | // parent. Therefore, snapshots that are not reachable will be ignored for composition |
| 122 | // and input. |
| 123 | ReachableByRelativeParent |
| 124 | }; |
| 125 | Reachablilty reachablilty; |
Vishnu Nair | 8fc721b | 2022-12-22 20:06:32 +0000 | [diff] [blame] | 126 | |
| 127 | static bool isOpaqueFormat(PixelFormat format); |
| 128 | static bool isTransformValid(const ui::Transform& t); |
| 129 | |
| 130 | bool canReceiveInput() const; |
| 131 | bool drawShadows() const; |
| 132 | bool fillsColor() const; |
| 133 | bool getIsVisible() const; |
| 134 | bool hasBlur() const; |
| 135 | bool hasBufferOrSidebandStream() const; |
| 136 | bool hasEffect() const; |
| 137 | bool hasSomethingToDraw() const; |
| 138 | bool isContentOpaque() const; |
| 139 | bool isHiddenByPolicy() const; |
| 140 | std::string getDebugString() const; |
| 141 | std::string getIsVisibleReason() const; |
Vishnu Nair | cfb2d25 | 2023-01-19 04:44:02 +0000 | [diff] [blame] | 142 | bool hasInputInfo() const; |
Vishnu Nair | 781d725 | 2023-01-30 18:16:01 +0000 | [diff] [blame] | 143 | FloatRect sourceBounds() const; |
Vishnu Nair | a02943f | 2023-06-03 13:44:46 -0700 | [diff] [blame] | 144 | Hwc2::IComposerClient::BlendMode getBlendMode(const RequestedLayerState& requested) const; |
Vishnu Nair | 3cc15a4 | 2023-06-30 06:20:22 +0000 | [diff] [blame] | 145 | friend std::ostream& operator<<(std::ostream& os, const LayerSnapshot& obj); |
Vishnu Nair | a02943f | 2023-06-03 13:44:46 -0700 | [diff] [blame] | 146 | void merge(const RequestedLayerState& requested, bool forceUpdate, bool displayChanges, |
| 147 | bool forceFullDamage, uint32_t displayRotationFlags); |
Vishnu Nair | 8fc721b | 2022-12-22 20:06:32 +0000 | [diff] [blame] | 148 | }; |
| 149 | |
| 150 | } // namespace android::surfaceflinger::frontend |