blob: 712a323337a78b42427361de823276528d9f3523 [file] [log] [blame]
Mathias Agopiane3c697f2013-02-14 17:11:02 -08001/*
2 * Copyright (C) 2007 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#ifndef ANDROID_GUI_SURFACE_CONTROL_H
18#define ANDROID_GUI_SURFACE_CONTROL_H
19
20#include <stdint.h>
21#include <sys/types.h>
22
23#include <utils/KeyedVector.h>
24#include <utils/RefBase.h>
25#include <utils/threads.h>
26
Svetoslavd85084b2014-03-20 10:28:31 -070027#include <ui/FrameStats.h>
Mathias Agopiane3c697f2013-02-14 17:11:02 -080028#include <ui/PixelFormat.h>
29#include <ui/Region.h>
30
Mathias Agopiane3c697f2013-02-14 17:11:02 -080031#include <gui/ISurfaceComposerClient.h>
32
33namespace android {
34
35// ---------------------------------------------------------------------------
36
37class IGraphicBufferProducer;
38class Surface;
39class SurfaceComposerClient;
40
41// ---------------------------------------------------------------------------
42
43class SurfaceControl : public RefBase
44{
45public:
46 static bool isValid(const sp<SurfaceControl>& surface) {
47 return (surface != 0) && surface->isValid();
48 }
Mathias Agopian4d9b8222013-03-12 17:11:48 -070049
Mathias Agopiane3c697f2013-02-14 17:11:02 -080050 bool isValid() {
Mathias Agopian4d9b8222013-03-12 17:11:48 -070051 return mHandle!=0 && mClient!=0;
Mathias Agopiane3c697f2013-02-14 17:11:02 -080052 }
Mathias Agopian4d9b8222013-03-12 17:11:48 -070053
Mathias Agopiane3c697f2013-02-14 17:11:02 -080054 static bool isSameSurface(
55 const sp<SurfaceControl>& lhs, const sp<SurfaceControl>& rhs);
Svetoslavd85084b2014-03-20 10:28:31 -070056
Mathias Agopiane3c697f2013-02-14 17:11:02 -080057 // release surface data from java
58 void clear();
Svetoslavd85084b2014-03-20 10:28:31 -070059
Chong Zhang1b3a9ac2016-02-29 16:47:47 -080060 // disconnect any api that's connected
61 void disconnect();
62
Dan Stozad723bd72014-11-18 10:24:03 -080063 status_t setLayerStack(uint32_t layerStack);
Robert Carrae060832016-11-28 10:51:00 -080064 status_t setLayer(int32_t layer);
Robert Carrdb66e622017-04-10 16:55:57 -070065
66 // Sets a Z order relative to the Surface specified by "relativeTo" but
67 // without becoming a full child of the relative. Z-ordering works exactly
68 // as if it were a child however.
69 //
70 // As a nod to sanity, only non-child surfaces may have a relative Z-order.
71 //
72 // This overrides any previous and is overriden by any future calls
73 // to setLayer.
74 //
75 // If the relative dissapears, the Surface will have no layer and be
76 // invisible, until the next time set(Relative)Layer is called.
77 //
78 // TODO: This is probably a hack. Currently it exists only to work around
79 // some framework usage of the hidden APPLICATION_MEDIA_OVERLAY window type
80 // which allows inserting a window between a SurfaceView and it's main application
81 // window. However, since we are using child windows for the SurfaceView, but not using
82 // child windows elsewhere in O, the WindowManager can't set the layer appropriately.
83 // This is only used by the "TvInputService" and following the port of ViewRootImpl
84 // to child surfaces, we can then port this and remove this method.
85 status_t setRelativeLayer(const sp<IBinder>& relativeTo, int32_t layer);
Ramanan Rajeswarand6480c02013-03-21 15:49:59 +000086 status_t setPosition(float x, float y);
Mathias Agopiane3c697f2013-02-14 17:11:02 -080087 status_t setSize(uint32_t w, uint32_t h);
88 status_t hide();
89 status_t show();
90 status_t setFlags(uint32_t flags, uint32_t mask);
91 status_t setTransparentRegionHint(const Region& transparent);
92 status_t setAlpha(float alpha=1.0f);
Robert Carrcb6e1e32017-02-21 19:48:26 -080093 status_t setMatrix(float dsdx, float dtdx, float dtdy, float dsdy);
Mathias Agopiane3c697f2013-02-14 17:11:02 -080094 status_t setCrop(const Rect& crop);
Pablo Ceballosacbe6782016-03-04 17:54:21 +000095 status_t setFinalCrop(const Rect& crop);
Mathias Agopiane3c697f2013-02-14 17:11:02 -080096
Robert Carr99e27f02016-06-16 15:18:02 -070097 // If the size changes in this transaction, all geometry updates specified
Robert Carr82364e32016-05-15 11:27:47 -070098 // in this transaction will not complete until a buffer of the new size
Robert Carr99e27f02016-06-16 15:18:02 -070099 // arrives. As some elements normally apply immediately, this enables
100 // freezing the total geometry of a surface until a resize is completed.
101 status_t setGeometryAppliesWithResize();
Robert Carr82364e32016-05-15 11:27:47 -0700102
Dan Stoza7dde5992015-05-22 09:51:44 -0700103 // Defers applying any changes made in this transaction until the Layer
Robert Carr0d480722017-01-10 16:42:54 -0800104 // identified by handle reaches the given frameNumber. If the Layer identified
105 // by handle is removed, then we will apply this transaction regardless of
106 // what frame number has been reached.
Robert Carr1db73f62016-12-21 12:58:51 -0800107 status_t deferTransactionUntil(const sp<IBinder>& handle, uint64_t frameNumber);
Robert Carr0d480722017-01-10 16:42:54 -0800108
109 // A variant of deferTransactionUntil which identifies the Layer we wait for by
110 // Surface instead of Handle. Useful for clients which may not have the
111 // SurfaceControl for some of their Surfaces. Otherwise behaves identically.
112 status_t deferTransactionUntil(const sp<Surface>& barrier, uint64_t frameNumber);
113
Robert Carr1db73f62016-12-21 12:58:51 -0800114 // Reparents all children of this layer to the new parent handle.
115 status_t reparentChildren(const sp<IBinder>& newParentHandle);
Dan Stoza7dde5992015-05-22 09:51:44 -0700116
Robert Carr9524cb32017-02-13 11:32:32 -0800117 // Detaches all child surfaces (and their children recursively)
118 // from their SurfaceControl.
119 // The child SurfaceControl's will not throw exceptions or return errors,
120 // but transactions will have no effect.
121 // The child surfaces will continue to follow their parent surfaces,
122 // and remain eligible for rendering, but their relative state will be
123 // frozen. We use this in the WindowManager, in app shutdown/relaunch
124 // scenarios, where the app would otherwise clean up its child Surfaces.
125 // Sometimes the WindowManager needs to extend their lifetime slightly
126 // in order to perform an exit animation or prevent flicker.
127 status_t detachChildren();
128
Robert Carrc3574f72016-03-24 12:19:32 -0700129 // Set an override scaling mode as documented in <system/window.h>
130 // the override scaling mode will take precedence over any client
131 // specified scaling mode. -1 will clear the override scaling mode.
132 status_t setOverrideScalingMode(int32_t overrideScalingMode);
133
Mathias Agopiane3c697f2013-02-14 17:11:02 -0800134 static status_t writeSurfaceToParcel(
135 const sp<SurfaceControl>& control, Parcel* parcel);
136
137 sp<Surface> getSurface() const;
Dan Stoza7dde5992015-05-22 09:51:44 -0700138 sp<IBinder> getHandle() const;
Mathias Agopiane3c697f2013-02-14 17:11:02 -0800139
Svetoslavd85084b2014-03-20 10:28:31 -0700140 status_t clearLayerFrameStats() const;
141 status_t getLayerFrameStats(FrameStats* outStats) const;
142
Mathias Agopiane3c697f2013-02-14 17:11:02 -0800143private:
144 // can't be copied
145 SurfaceControl& operator = (SurfaceControl& rhs);
146 SurfaceControl(const SurfaceControl& rhs);
147
148 friend class SurfaceComposerClient;
149 friend class Surface;
150
151 SurfaceControl(
152 const sp<SurfaceComposerClient>& client,
Mathias Agopian4d9b8222013-03-12 17:11:48 -0700153 const sp<IBinder>& handle,
154 const sp<IGraphicBufferProducer>& gbp);
Mathias Agopiane3c697f2013-02-14 17:11:02 -0800155
156 ~SurfaceControl();
157
158 status_t validate() const;
159 void destroy();
Svetoslavd85084b2014-03-20 10:28:31 -0700160
Mathias Agopiane3c697f2013-02-14 17:11:02 -0800161 sp<SurfaceComposerClient> mClient;
Mathias Agopian4d9b8222013-03-12 17:11:48 -0700162 sp<IBinder> mHandle;
Mathias Agopiane3c697f2013-02-14 17:11:02 -0800163 sp<IGraphicBufferProducer> mGraphicBufferProducer;
164 mutable Mutex mLock;
165 mutable sp<Surface> mSurfaceData;
166};
167
168}; // namespace android
169
170#endif // ANDROID_GUI_SURFACE_CONTROL_H