blob: 9b6205d31f28cc4dd18e4f234e2079da3cd805a0 [file] [log] [blame]
Romain Guydda57022010-07-06 11:39:32 -07001/*
2 * Copyright (C) 2010 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
Romain Guy5b3b3522010-10-27 18:57:51 -070017#ifndef ANDROID_HWUI_LAYER_H
18#define ANDROID_HWUI_LAYER_H
Romain Guydda57022010-07-06 11:39:32 -070019
Romain Guyf7f93552010-07-08 19:17:03 -070020#include <sys/types.h>
21
Romain Guydda57022010-07-06 11:39:32 -070022#include <GLES2/gl2.h>
23
Romain Guy5b3b3522010-10-27 18:57:51 -070024#include <ui/Region.h>
25
Romain Guydda57022010-07-06 11:39:32 -070026#include <SkXfermode.h>
27
28#include "Rect.h"
Romain Guy171c5922011-01-06 10:04:23 -080029#include "SkiaColorFilter.h"
Romain Guy9ace8f52011-07-07 20:50:11 -070030#include "Texture.h"
Romain Guyf219da52011-01-16 12:54:25 -080031#include "Vertex.h"
Romain Guydda57022010-07-06 11:39:32 -070032
33namespace android {
34namespace uirenderer {
35
Romain Guy8550c4c2010-10-08 15:49:53 -070036///////////////////////////////////////////////////////////////////////////////
37// Layers
38///////////////////////////////////////////////////////////////////////////////
Romain Guydda57022010-07-06 11:39:32 -070039
Romain Guy2bf68f02012-03-02 13:37:47 -080040// Forward declarations
41class OpenGLRenderer;
42class DisplayList;
43
Romain Guydda57022010-07-06 11:39:32 -070044/**
Romain Guyeb993562010-10-05 18:14:38 -070045 * A layer has dimensions and is backed by an OpenGL texture or FBO.
Romain Guydda57022010-07-06 11:39:32 -070046 */
47struct Layer {
Chet Haase603f6de2012-09-14 15:31:25 -070048 Layer(const uint32_t layerWidth, const uint32_t layerHeight);
Chet Haased15ebf22012-09-05 11:40:29 -070049 ~Layer();
Romain Guy8550c4c2010-10-08 15:49:53 -070050
Dave Burke56257af2012-09-25 20:30:09 -070051 void freeResourcesLocked();
52
Romain Guydda57022010-07-06 11:39:32 -070053 /**
Romain Guy9fc27812011-04-27 14:21:41 -070054 * Sets this layer's region to a rectangle. Computes the appropriate
55 * texture coordinates.
56 */
57 void setRegionAsRect() {
58 const android::Rect& bounds = region.getBounds();
59 regionRect.set(bounds.leftTop().x, bounds.leftTop().y,
60 bounds.rightBottom().x, bounds.rightBottom().y);
61
Romain Guy9ace8f52011-07-07 20:50:11 -070062 const float texX = 1.0f / float(texture.width);
63 const float texY = 1.0f / float(texture.height);
Romain Guy9fc27812011-04-27 14:21:41 -070064 const float height = layer.getHeight();
65 texCoords.set(
66 regionRect.left * texX, (height - regionRect.top) * texY,
67 regionRect.right * texX, (height - regionRect.bottom) * texY);
Romain Guy9ace8f52011-07-07 20:50:11 -070068
69 regionRect.translate(layer.left, layer.top);
70 }
71
Romain Guy2bf68f02012-03-02 13:37:47 -080072 void updateDeferred(OpenGLRenderer* renderer, DisplayList* displayList,
73 int left, int top, int right, int bottom) {
74 this->renderer = renderer;
75 this->displayList = displayList;
76 const Rect r(left, top, right, bottom);
77 dirtyRect.unionWith(r);
78 deferredUpdateScheduled = true;
79 }
80
Romain Guy9ace8f52011-07-07 20:50:11 -070081 inline uint32_t getWidth() {
82 return texture.width;
83 }
84
85 inline uint32_t getHeight() {
86 return texture.height;
87 }
88
89 void setSize(uint32_t width, uint32_t height) {
90 texture.width = width;
91 texture.height = height;
92 }
93
Chet Haased15ebf22012-09-05 11:40:29 -070094 ANDROID_API void setPaint(SkPaint* paint);
95
Romain Guy9ace8f52011-07-07 20:50:11 -070096 inline void setBlend(bool blend) {
97 texture.blend = blend;
98 }
99
100 inline bool isBlend() {
101 return texture.blend;
102 }
103
104 inline void setAlpha(int alpha) {
105 this->alpha = alpha;
106 }
107
108 inline void setAlpha(int alpha, SkXfermode::Mode mode) {
109 this->alpha = alpha;
110 this->mode = mode;
111 }
112
113 inline int getAlpha() {
114 return alpha;
115 }
116
117 inline SkXfermode::Mode getMode() {
118 return mode;
119 }
120
121 inline void setEmpty(bool empty) {
122 this->empty = empty;
123 }
124
125 inline bool isEmpty() {
126 return empty;
127 }
128
129 inline void setFbo(GLuint fbo) {
130 this->fbo = fbo;
131 }
132
133 inline GLuint getFbo() {
134 return fbo;
135 }
136
Romain Guy9ace8f52011-07-07 20:50:11 -0700137 inline GLuint getTexture() {
138 return texture.id;
139 }
140
141 inline GLenum getRenderTarget() {
142 return renderTarget;
143 }
144
145 inline void setRenderTarget(GLenum renderTarget) {
146 this->renderTarget = renderTarget;
147 }
148
Romain Guyd21b6e12011-11-30 20:21:23 -0800149 void setWrap(GLenum wrap, bool bindTexture = false, bool force = false) {
150 texture.setWrap(wrap, bindTexture, force, renderTarget);
Romain Guy9ace8f52011-07-07 20:50:11 -0700151 }
152
Romain Guyd21b6e12011-11-30 20:21:23 -0800153 void setFilter(GLenum filter, bool bindTexture = false, bool force = false) {
154 texture.setFilter(filter, bindTexture, force, renderTarget);
Romain Guy9ace8f52011-07-07 20:50:11 -0700155 }
156
157 inline bool isCacheable() {
158 return cacheable;
159 }
160
161 inline void setCacheable(bool cacheable) {
162 this->cacheable = cacheable;
163 }
164
165 inline bool isTextureLayer() {
166 return textureLayer;
167 }
168
169 inline void setTextureLayer(bool textureLayer) {
170 this->textureLayer = textureLayer;
171 }
172
173 inline SkiaColorFilter* getColorFilter() {
174 return colorFilter;
175 }
176
Chet Haased15ebf22012-09-05 11:40:29 -0700177 ANDROID_API void setColorFilter(SkiaColorFilter* filter);
Romain Guy9ace8f52011-07-07 20:50:11 -0700178
179 inline void bindTexture() {
Romain Guyef09a212012-09-25 12:17:14 -0700180 if (texture.id) {
181 glBindTexture(renderTarget, texture.id);
182 }
Romain Guy9ace8f52011-07-07 20:50:11 -0700183 }
184
185 inline void generateTexture() {
Romain Guyef09a212012-09-25 12:17:14 -0700186 if (!texture.id) {
187 glGenTextures(1, &texture.id);
188 }
Romain Guy9ace8f52011-07-07 20:50:11 -0700189 }
190
191 inline void deleteTexture() {
Romain Guyef09a212012-09-25 12:17:14 -0700192 if (texture.id) {
193 glDeleteTextures(1, &texture.id);
194 texture.id = 0;
195 }
196 }
197
198 /**
199 * When the caller frees the texture itself, the caller
200 * must call this method to tell this layer that it lost
201 * the texture.
202 */
203 void clearTexture() {
204 texture.id = 0;
Romain Guy9ace8f52011-07-07 20:50:11 -0700205 }
206
Romain Guy912a7b32011-07-26 18:57:28 -0700207 inline void deleteFbo() {
208 if (fbo) glDeleteFramebuffers(1, &fbo);
209 }
210
Romain Guy9ace8f52011-07-07 20:50:11 -0700211 inline void allocateTexture(GLenum format, GLenum storage) {
212 glTexImage2D(renderTarget, 0, format, getWidth(), getHeight(), 0, format, storage, NULL);
213 }
214
215 inline mat4& getTexTransform() {
216 return texTransform;
Romain Guy9fc27812011-04-27 14:21:41 -0700217 }
218
Romain Guy302a9df2011-08-16 13:55:02 -0700219 inline mat4& getTransform() {
220 return transform;
221 }
222
Romain Guy9fc27812011-04-27 14:21:41 -0700223 /**
Romain Guy8550c4c2010-10-08 15:49:53 -0700224 * Bounds of the layer.
Romain Guydda57022010-07-06 11:39:32 -0700225 */
226 Rect layer;
227 /**
Romain Guy8550c4c2010-10-08 15:49:53 -0700228 * Texture coordinates of the layer.
Romain Guydda57022010-07-06 11:39:32 -0700229 */
Romain Guy8550c4c2010-10-08 15:49:53 -0700230 Rect texCoords;
231
Romain Guydda57022010-07-06 11:39:32 -0700232 /**
Romain Guy5b3b3522010-10-27 18:57:51 -0700233 * Dirty region indicating what parts of the layer
234 * have been drawn.
235 */
236 Region region;
Romain Guy40667672011-03-18 14:34:03 -0700237 /**
238 * If the region is a rectangle, coordinates of the
239 * region are stored here.
240 */
241 Rect regionRect;
Romain Guy171c5922011-01-06 10:04:23 -0800242
243 /**
Romain Guyf219da52011-01-16 12:54:25 -0800244 * If the layer can be rendered as a mesh, this is non-null.
245 */
246 TextureVertex* mesh;
247 uint16_t* meshIndices;
248 GLsizei meshElementCount;
Romain Guyaa6c24c2011-04-28 18:40:04 -0700249
Romain Guy2bf68f02012-03-02 13:37:47 -0800250 /**
251 * Used for deferred updates.
252 */
253 bool deferredUpdateScheduled;
254 OpenGLRenderer* renderer;
255 DisplayList* displayList;
256 Rect dirtyRect;
257
Romain Guy9ace8f52011-07-07 20:50:11 -0700258private:
259 /**
260 * Name of the FBO used to render the layer. If the name is 0
261 * this layer is not backed by an FBO, but a simple texture.
262 */
263 GLuint fbo;
264
265 /**
266 * Indicates whether this layer has been used already.
267 */
268 bool empty;
269
270 /**
271 * The texture backing this layer.
272 */
273 Texture texture;
274
Romain Guyaa6c24c2011-04-28 18:40:04 -0700275 /**
276 * If set to true (by default), the layer can be reused.
277 */
Romain Guy9ace8f52011-07-07 20:50:11 -0700278 bool cacheable;
Romain Guyaa6c24c2011-04-28 18:40:04 -0700279
280 /**
281 * When set to true, this layer must be treated as a texture
282 * layer.
283 */
Romain Guy9ace8f52011-07-07 20:50:11 -0700284 bool textureLayer;
285
286 /**
287 * Indicates the render target.
288 */
289 GLenum renderTarget;
290
291 /**
292 * Color filter used to draw this layer. Optional.
293 */
294 SkiaColorFilter* colorFilter;
295
296 /**
297 * Opacity of the layer.
298 */
299 int alpha;
300 /**
301 * Blending mode of the layer.
302 */
303 SkXfermode::Mode mode;
Romain Guyaa6c24c2011-04-28 18:40:04 -0700304
305 /**
306 * Optional texture coordinates transform.
307 */
308 mat4 texTransform;
Romain Guy8f0095c2011-05-02 17:24:22 -0700309
Romain Guy302a9df2011-08-16 13:55:02 -0700310 /**
311 * Optional transform.
312 */
313 mat4 transform;
314
Romain Guydda57022010-07-06 11:39:32 -0700315}; // struct Layer
316
317}; // namespace uirenderer
318}; // namespace android
319
Romain Guy5b3b3522010-10-27 18:57:51 -0700320#endif // ANDROID_HWUI_LAYER_H