| Romain Guy | e4d0112 | 2010-06-16 18:44:05 -0700 | [diff] [blame] | 1 | /* | 
|  | 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 Guy | 5b3b352 | 2010-10-27 18:57:51 -0700 | [diff] [blame] | 17 | #ifndef ANDROID_HWUI_OPENGL_RENDERER_H | 
|  | 18 | #define ANDROID_HWUI_OPENGL_RENDERER_H | 
| Romain Guy | 9d5316e | 2010-06-24 19:30:36 -0700 | [diff] [blame] | 19 |  | 
|  | 20 | #include <GLES2/gl2.h> | 
|  | 21 | #include <GLES2/gl2ext.h> | 
| Romain Guy | 85bf02f | 2010-06-22 13:11:24 -0700 | [diff] [blame] | 22 |  | 
| Romain Guy | ce0537b | 2010-06-29 21:05:21 -0700 | [diff] [blame] | 23 | #include <SkBitmap.h> | 
| Romain Guy | f6a11b8 | 2010-06-23 17:47:49 -0700 | [diff] [blame] | 24 | #include <SkMatrix.h> | 
| Romain Guy | ce0537b | 2010-06-29 21:05:21 -0700 | [diff] [blame] | 25 | #include <SkPaint.h> | 
| Romain Guy | 079ba2c | 2010-07-16 14:12:24 -0700 | [diff] [blame] | 26 | #include <SkRegion.h> | 
| Romain Guy | d27977d | 2010-07-14 19:18:51 -0700 | [diff] [blame] | 27 | #include <SkShader.h> | 
| Romain Guy | 85bf02f | 2010-06-22 13:11:24 -0700 | [diff] [blame] | 28 | #include <SkXfermode.h> | 
| Romain Guy | e4d0112 | 2010-06-16 18:44:05 -0700 | [diff] [blame] | 29 |  | 
| Chet Haase | daf98e9 | 2011-01-10 14:10:36 -0800 | [diff] [blame] | 30 | #include <utils/Functor.h> | 
| Romain Guy | bb9524b | 2010-06-22 18:56:38 -0700 | [diff] [blame] | 31 | #include <utils/RefBase.h> | 
| Romain Guy | ba6be8a | 2012-04-23 18:22:09 -0700 | [diff] [blame] | 32 | #include <utils/SortedVector.h> | 
| Romain Guy | 8694230 | 2010-09-12 13:02:16 -0700 | [diff] [blame] | 33 | #include <utils/Vector.h> | 
| Romain Guy | bb9524b | 2010-06-22 18:56:38 -0700 | [diff] [blame] | 34 |  | 
| Romain Guy | 7953745 | 2011-10-12 13:48:51 -0700 | [diff] [blame] | 35 | #include <cutils/compiler.h> | 
|  | 36 |  | 
| Romain Guy | c15008e | 2010-11-10 11:59:15 -0800 | [diff] [blame] | 37 | #include "Debug.h" | 
| Romain Guy | 51769a6 | 2010-07-23 00:28:00 -0700 | [diff] [blame] | 38 | #include "Extensions.h" | 
| Romain Guy | f6a11b8 | 2010-06-23 17:47:49 -0700 | [diff] [blame] | 39 | #include "Matrix.h" | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 40 | #include "Program.h" | 
| Romain Guy | bb9524b | 2010-06-22 18:56:38 -0700 | [diff] [blame] | 41 | #include "Rect.h" | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 42 | #include "Snapshot.h" | 
| Romain Guy | f7f9355 | 2010-07-08 19:17:03 -0700 | [diff] [blame] | 43 | #include "Vertex.h" | 
| Romain Guy | 06f96e2 | 2010-07-30 19:18:16 -0700 | [diff] [blame] | 44 | #include "SkiaShader.h" | 
| Romain Guy | db1938e | 2010-08-02 18:50:22 -0700 | [diff] [blame] | 45 | #include "SkiaColorFilter.h" | 
| Romain Guy | fb8b763 | 2010-08-23 21:05:08 -0700 | [diff] [blame] | 46 | #include "Caches.h" | 
| Romain Guy | bb9524b | 2010-06-22 18:56:38 -0700 | [diff] [blame] | 47 |  | 
| Romain Guy | e4d0112 | 2010-06-16 18:44:05 -0700 | [diff] [blame] | 48 | namespace android { | 
| Romain Guy | 9d5316e | 2010-06-24 19:30:36 -0700 | [diff] [blame] | 49 | namespace uirenderer { | 
| Romain Guy | e4d0112 | 2010-06-16 18:44:05 -0700 | [diff] [blame] | 50 |  | 
| Romain Guy | f6a11b8 | 2010-06-23 17:47:49 -0700 | [diff] [blame] | 51 | /////////////////////////////////////////////////////////////////////////////// | 
| Romain Guy | f6a11b8 | 2010-06-23 17:47:49 -0700 | [diff] [blame] | 52 | // Renderer | 
|  | 53 | /////////////////////////////////////////////////////////////////////////////// | 
|  | 54 |  | 
| Romain Guy | 0fe478e | 2010-11-08 12:08:41 -0800 | [diff] [blame] | 55 | class DisplayList; | 
| Romain Guy | b051e89 | 2010-09-28 19:09:36 -0700 | [diff] [blame] | 56 |  | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 57 | /** | 
|  | 58 | * OpenGL renderer used to draw accelerated 2D graphics. The API is a | 
|  | 59 | * simplified version of Skia's Canvas API. | 
|  | 60 | */ | 
| Romain Guy | 85bf02f | 2010-06-22 13:11:24 -0700 | [diff] [blame] | 61 | class OpenGLRenderer { | 
| Romain Guy | e4d0112 | 2010-06-16 18:44:05 -0700 | [diff] [blame] | 62 | public: | 
| Romain Guy | 7953745 | 2011-10-12 13:48:51 -0700 | [diff] [blame] | 63 | ANDROID_API OpenGLRenderer(); | 
| Romain Guy | e2d345e | 2010-09-24 18:39:22 -0700 | [diff] [blame] | 64 | virtual ~OpenGLRenderer(); | 
| Romain Guy | e4d0112 | 2010-06-16 18:44:05 -0700 | [diff] [blame] | 65 |  | 
| Romain Guy | 49c5fc0 | 2012-05-15 11:10:01 -0700 | [diff] [blame] | 66 | virtual bool isDeferred(); | 
|  | 67 |  | 
| Romain Guy | b051e89 | 2010-09-28 19:09:36 -0700 | [diff] [blame] | 68 | virtual void setViewport(int width, int height); | 
| Romain Guy | e2d345e | 2010-09-24 18:39:22 -0700 | [diff] [blame] | 69 |  | 
| Chet Haase | 44b2fe3 | 2012-06-06 19:03:58 -0700 | [diff] [blame] | 70 | ANDROID_API int prepare(bool opaque); | 
|  | 71 | virtual int prepareDirty(float left, float top, float right, float bottom, bool opaque); | 
| Romain Guy | e2d345e | 2010-09-24 18:39:22 -0700 | [diff] [blame] | 72 | virtual void finish(); | 
|  | 73 |  | 
| Romain Guy | 6c319ca | 2011-01-11 14:29:25 -0800 | [diff] [blame] | 74 | // These two calls must not be recorded in display lists | 
| Chet Haase | daf98e9 | 2011-01-10 14:10:36 -0800 | [diff] [blame] | 75 | virtual void interrupt(); | 
|  | 76 | virtual void resume(); | 
| Romain Guy | 6c319ca | 2011-01-11 14:29:25 -0800 | [diff] [blame] | 77 |  | 
| Romain Guy | 8f3b8e3 | 2012-03-27 16:33:45 -0700 | [diff] [blame] | 78 | ANDROID_API status_t invokeFunctors(Rect& dirty); | 
| Romain Guy | ba6be8a | 2012-04-23 18:22:09 -0700 | [diff] [blame] | 79 | ANDROID_API void detachFunctor(Functor* functor); | 
|  | 80 | ANDROID_API void attachFunctor(Functor* functor); | 
| Romain Guy | 8f3b8e3 | 2012-03-27 16:33:45 -0700 | [diff] [blame] | 81 | virtual status_t callDrawGLFunction(Functor* functor, Rect& dirty); | 
| Romain Guy | 08ae317 | 2010-06-21 19:35:50 -0700 | [diff] [blame] | 82 |  | 
| Romain Guy | 7953745 | 2011-10-12 13:48:51 -0700 | [diff] [blame] | 83 | ANDROID_API int getSaveCount() const; | 
| Romain Guy | 4aa9057 | 2010-09-26 18:40:37 -0700 | [diff] [blame] | 84 | virtual int save(int flags); | 
|  | 85 | virtual void restore(); | 
|  | 86 | virtual void restoreToCount(int saveCount); | 
| Romain Guy | bb9524b | 2010-06-22 18:56:38 -0700 | [diff] [blame] | 87 |  | 
| Romain Guy | e2d345e | 2010-09-24 18:39:22 -0700 | [diff] [blame] | 88 | virtual int saveLayer(float left, float top, float right, float bottom, | 
| Chet Haase | 5c13d89 | 2010-10-08 08:37:55 -0700 | [diff] [blame] | 89 | SkPaint* p, int flags); | 
| Romain Guy | e2d345e | 2010-09-24 18:39:22 -0700 | [diff] [blame] | 90 | virtual int saveLayerAlpha(float left, float top, float right, float bottom, | 
|  | 91 | int alpha, int flags); | 
| Romain Guy | bd6b79b | 2010-06-26 00:13:53 -0700 | [diff] [blame] | 92 |  | 
| Romain Guy | f26c8be | 2012-05-18 10:58:45 -0700 | [diff] [blame] | 93 | void setAlpha(float alpha) { | 
| Chet Haase | db8c9a6 | 2012-03-21 18:54:18 -0700 | [diff] [blame] | 94 | mSnapshot->alpha = alpha; | 
|  | 95 | } | 
|  | 96 |  | 
| Romain Guy | 4aa9057 | 2010-09-26 18:40:37 -0700 | [diff] [blame] | 97 | virtual void translate(float dx, float dy); | 
|  | 98 | virtual void rotate(float degrees); | 
|  | 99 | virtual void scale(float sx, float sy); | 
| Romain Guy | 807daf7 | 2011-01-18 11:19:19 -0800 | [diff] [blame] | 100 | virtual void skew(float sx, float sy); | 
| Romain Guy | f6a11b8 | 2010-06-23 17:47:49 -0700 | [diff] [blame] | 101 |  | 
| Romain Guy | 7953745 | 2011-10-12 13:48:51 -0700 | [diff] [blame] | 102 | ANDROID_API void getMatrix(SkMatrix* matrix); | 
| Romain Guy | 4aa9057 | 2010-09-26 18:40:37 -0700 | [diff] [blame] | 103 | virtual void setMatrix(SkMatrix* matrix); | 
|  | 104 | virtual void concatMatrix(SkMatrix* matrix); | 
| Romain Guy | f6a11b8 | 2010-06-23 17:47:49 -0700 | [diff] [blame] | 105 |  | 
| Romain Guy | 7953745 | 2011-10-12 13:48:51 -0700 | [diff] [blame] | 106 | ANDROID_API const Rect& getClipBounds(); | 
|  | 107 | ANDROID_API bool quickReject(float left, float top, float right, float bottom); | 
| Romain Guy | 4aa9057 | 2010-09-26 18:40:37 -0700 | [diff] [blame] | 108 | virtual bool clipRect(float left, float top, float right, float bottom, SkRegion::Op op); | 
| Chet Haase | a23eed8 | 2012-04-12 15:19:04 -0700 | [diff] [blame] | 109 | virtual Rect* getClipRect(); | 
| Romain Guy | bb9524b | 2010-06-22 18:56:38 -0700 | [diff] [blame] | 110 |  | 
| Chet Haase | 1271e2c | 2012-04-20 09:54:27 -0700 | [diff] [blame] | 111 | virtual status_t drawDisplayList(DisplayList* displayList, Rect& dirty, int32_t flags, | 
|  | 112 | uint32_t level = 0); | 
| Chet Haase | ed30fd8 | 2011-04-22 16:18:45 -0700 | [diff] [blame] | 113 | virtual void outputDisplayList(DisplayList* displayList, uint32_t level = 0); | 
| Chet Haase | 4865909 | 2012-05-31 15:21:51 -0700 | [diff] [blame] | 114 | virtual status_t drawLayer(Layer* layer, float x, float y, SkPaint* paint); | 
|  | 115 | virtual status_t drawBitmap(SkBitmap* bitmap, float left, float top, SkPaint* paint); | 
|  | 116 | virtual status_t drawBitmap(SkBitmap* bitmap, SkMatrix* matrix, SkPaint* paint); | 
|  | 117 | virtual status_t drawBitmap(SkBitmap* bitmap, float srcLeft, float srcTop, | 
| Romain Guy | e2d345e | 2010-09-24 18:39:22 -0700 | [diff] [blame] | 118 | float srcRight, float srcBottom, float dstLeft, float dstTop, | 
| Chet Haase | 5c13d89 | 2010-10-08 08:37:55 -0700 | [diff] [blame] | 119 | float dstRight, float dstBottom, SkPaint* paint); | 
| Chet Haase | 4865909 | 2012-05-31 15:21:51 -0700 | [diff] [blame] | 120 | virtual status_t drawBitmapData(SkBitmap* bitmap, float left, float top, SkPaint* paint); | 
|  | 121 | virtual status_t drawBitmapMesh(SkBitmap* bitmap, int meshWidth, int meshHeight, | 
| Romain Guy | 5a7b466 | 2011-01-20 19:09:30 -0800 | [diff] [blame] | 122 | float* vertices, int* colors, SkPaint* paint); | 
| Chet Haase | 4865909 | 2012-05-31 15:21:51 -0700 | [diff] [blame] | 123 | virtual status_t drawPatch(SkBitmap* bitmap, const int32_t* xDivs, const int32_t* yDivs, | 
| Romain Guy | 4bb9420 | 2010-10-12 15:59:26 -0700 | [diff] [blame] | 124 | const uint32_t* colors, uint32_t width, uint32_t height, int8_t numColors, | 
| Chet Haase | 5c13d89 | 2010-10-08 08:37:55 -0700 | [diff] [blame] | 125 | float left, float top, float right, float bottom, SkPaint* paint); | 
| Chet Haase | 4865909 | 2012-05-31 15:21:51 -0700 | [diff] [blame] | 126 | virtual status_t drawColor(int color, SkXfermode::Mode mode); | 
|  | 127 | virtual status_t drawRect(float left, float top, float right, float bottom, SkPaint* paint); | 
|  | 128 | virtual status_t drawRoundRect(float left, float top, float right, float bottom, | 
| Romain Guy | 01d58e4 | 2011-01-19 21:54:02 -0800 | [diff] [blame] | 129 | float rx, float ry, SkPaint* paint); | 
| Chet Haase | 4865909 | 2012-05-31 15:21:51 -0700 | [diff] [blame] | 130 | virtual status_t drawCircle(float x, float y, float radius, SkPaint* paint); | 
|  | 131 | virtual status_t drawOval(float left, float top, float right, float bottom, SkPaint* paint); | 
|  | 132 | virtual status_t drawArc(float left, float top, float right, float bottom, | 
| Romain Guy | 8b2f526 | 2011-01-23 16:15:02 -0800 | [diff] [blame] | 133 | float startAngle, float sweepAngle, bool useCenter, SkPaint* paint); | 
| Chet Haase | 4865909 | 2012-05-31 15:21:51 -0700 | [diff] [blame] | 134 | virtual status_t drawPath(SkPath* path, SkPaint* paint); | 
|  | 135 | virtual status_t drawLines(float* points, int count, SkPaint* paint); | 
|  | 136 | virtual status_t drawPoints(float* points, int count, SkPaint* paint); | 
|  | 137 | virtual status_t drawText(const char* text, int bytesCount, int count, float x, float y, | 
| Romain Guy | cac5fd3 | 2011-12-01 20:08:50 -0800 | [diff] [blame] | 138 | SkPaint* paint, float length = -1.0f); | 
| Chet Haase | 4865909 | 2012-05-31 15:21:51 -0700 | [diff] [blame] | 139 | virtual status_t drawTextOnPath(const char* text, int bytesCount, int count, SkPath* path, | 
| Romain Guy | 325740f | 2012-02-24 16:48:34 -0800 | [diff] [blame] | 140 | float hOffset, float vOffset, SkPaint* paint); | 
| Chet Haase | 4865909 | 2012-05-31 15:21:51 -0700 | [diff] [blame] | 141 | virtual status_t drawPosText(const char* text, int bytesCount, int count, | 
| Romain Guy | 325740f | 2012-02-24 16:48:34 -0800 | [diff] [blame] | 142 | const float* positions, SkPaint* paint); | 
| Romain Guy | 08ae317 | 2010-06-21 19:35:50 -0700 | [diff] [blame] | 143 |  | 
| Romain Guy | 4aa9057 | 2010-09-26 18:40:37 -0700 | [diff] [blame] | 144 | virtual void resetShader(); | 
|  | 145 | virtual void setupShader(SkiaShader* shader); | 
| Romain Guy | d27977d | 2010-07-14 19:18:51 -0700 | [diff] [blame] | 146 |  | 
| Romain Guy | 4aa9057 | 2010-09-26 18:40:37 -0700 | [diff] [blame] | 147 | virtual void resetColorFilter(); | 
|  | 148 | virtual void setupColorFilter(SkiaColorFilter* filter); | 
| Romain Guy | db1938e | 2010-08-02 18:50:22 -0700 | [diff] [blame] | 149 |  | 
| Romain Guy | 4aa9057 | 2010-09-26 18:40:37 -0700 | [diff] [blame] | 150 | virtual void resetShadow(); | 
|  | 151 | virtual void setupShadow(float radius, float dx, float dy, int color); | 
| Romain Guy | 1e45aae | 2010-08-13 19:39:53 -0700 | [diff] [blame] | 152 |  | 
| Romain Guy | 5ff9df6 | 2012-01-23 17:09:05 -0800 | [diff] [blame] | 153 | virtual void resetPaintFilter(); | 
|  | 154 | virtual void setupPaintFilter(int clearBits, int setBits); | 
|  | 155 |  | 
|  | 156 | SkPaint* filterPaint(SkPaint* paint); | 
|  | 157 |  | 
| Romain Guy | 530041d | 2012-01-25 18:56:29 -0800 | [diff] [blame] | 158 | ANDROID_API static uint32_t getStencilSize(); | 
|  | 159 |  | 
| Romain Guy | 13631f3 | 2012-01-30 17:41:55 -0800 | [diff] [blame] | 160 | void startMark(const char* name) const; | 
|  | 161 | void endMark() const; | 
|  | 162 |  | 
| Romain Guy | e2d345e | 2010-09-24 18:39:22 -0700 | [diff] [blame] | 163 | protected: | 
|  | 164 | /** | 
|  | 165 | * Compose the layer defined in the current snapshot with the layer | 
|  | 166 | * defined by the previous snapshot. | 
|  | 167 | * | 
|  | 168 | * The current snapshot *must* be a layer (flag kFlagIsLayer set.) | 
|  | 169 | * | 
|  | 170 | * @param curent The current snapshot containing the layer to compose | 
|  | 171 | * @param previous The previous snapshot to compose the current layer with | 
|  | 172 | */ | 
|  | 173 | virtual void composeLayer(sp<Snapshot> current, sp<Snapshot> previous); | 
| Romain Guy | 694b519 | 2010-07-21 21:33:20 -0700 | [diff] [blame] | 174 |  | 
| Romain Guy | ada830f | 2011-01-13 12:13:20 -0800 | [diff] [blame] | 175 | /** | 
| Romain Guy | f219da5 | 2011-01-16 12:54:25 -0800 | [diff] [blame] | 176 | * Marks the specified region as dirty at the specified bounds. | 
| Romain Guy | ada830f | 2011-01-13 12:13:20 -0800 | [diff] [blame] | 177 | */ | 
| Romain Guy | f219da5 | 2011-01-16 12:54:25 -0800 | [diff] [blame] | 178 | void dirtyLayerUnchecked(Rect& bounds, Region* region); | 
| Romain Guy | ada830f | 2011-01-13 12:13:20 -0800 | [diff] [blame] | 179 |  | 
|  | 180 | /** | 
| Romain Guy | f219da5 | 2011-01-16 12:54:25 -0800 | [diff] [blame] | 181 | * Returns the current snapshot. | 
| Romain Guy | ada830f | 2011-01-13 12:13:20 -0800 | [diff] [blame] | 182 | */ | 
| Romain Guy | f219da5 | 2011-01-16 12:54:25 -0800 | [diff] [blame] | 183 | sp<Snapshot> getSnapshot() { | 
|  | 184 | return mSnapshot; | 
|  | 185 | } | 
| Romain Guy | ada830f | 2011-01-13 12:13:20 -0800 | [diff] [blame] | 186 |  | 
| Romain Guy | 42f3a4b | 2011-01-19 13:42:26 -0800 | [diff] [blame] | 187 | /** | 
|  | 188 | * Returns the region of the current layer. | 
|  | 189 | */ | 
| Romain Guy | f219da5 | 2011-01-16 12:54:25 -0800 | [diff] [blame] | 190 | virtual Region* getRegion() { | 
|  | 191 | return mSnapshot->region; | 
|  | 192 | } | 
|  | 193 |  | 
| Romain Guy | 42f3a4b | 2011-01-19 13:42:26 -0800 | [diff] [blame] | 194 | /** | 
|  | 195 | * Indicates whether rendering is currently targeted at a layer. | 
|  | 196 | */ | 
| Romain Guy | f219da5 | 2011-01-16 12:54:25 -0800 | [diff] [blame] | 197 | virtual bool hasLayer() { | 
|  | 198 | return (mSnapshot->flags & Snapshot::kFlagFboTarget) && mSnapshot->region; | 
|  | 199 | } | 
| Romain Guy | 1bd1bad | 2011-01-14 20:07:20 -0800 | [diff] [blame] | 200 |  | 
| Romain Guy | 42f3a4b | 2011-01-19 13:42:26 -0800 | [diff] [blame] | 201 | /** | 
|  | 202 | * Returns the name of the FBO this renderer is rendering into. | 
|  | 203 | */ | 
|  | 204 | virtual GLint getTargetFbo() { | 
|  | 205 | return 0; | 
|  | 206 | } | 
|  | 207 |  | 
| Romain Guy | 77a8116 | 2011-06-14 16:45:55 -0700 | [diff] [blame] | 208 | /** | 
|  | 209 | * Renders the specified layer as a textured quad. | 
|  | 210 | * | 
|  | 211 | * @param layer The layer to render | 
|  | 212 | * @param rect The bounds of the layer | 
|  | 213 | */ | 
|  | 214 | void drawTextureLayer(Layer* layer, const Rect& rect); | 
|  | 215 |  | 
| Romain Guy | 85bf02f | 2010-06-22 13:11:24 -0700 | [diff] [blame] | 216 | private: | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 217 | /** | 
| Romain Guy | ddf7437 | 2012-05-22 14:07:07 -0700 | [diff] [blame] | 218 | * Ensures the state of the renderer is the same as the state of | 
|  | 219 | * the GL context. | 
|  | 220 | */ | 
|  | 221 | void syncState(); | 
|  | 222 |  | 
|  | 223 | /** | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 224 | * Saves the current state of the renderer as a new snapshot. | 
|  | 225 | * The new snapshot is saved in mSnapshot and the previous snapshot | 
|  | 226 | * is linked from mSnapshot->previous. | 
|  | 227 | * | 
| Romain Guy | 8aef54f | 2010-09-01 15:13:49 -0700 | [diff] [blame] | 228 | * @param flags The save flags; see SkCanvas for more information | 
|  | 229 | * | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 230 | * @return The new save count. This value can be passed to #restoreToCount() | 
|  | 231 | */ | 
| Romain Guy | 8aef54f | 2010-09-01 15:13:49 -0700 | [diff] [blame] | 232 | int saveSnapshot(int flags); | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 233 |  | 
|  | 234 | /** | 
|  | 235 | * Restores the current snapshot; mSnapshot becomes mSnapshot->previous. | 
|  | 236 | * | 
| Romain Guy | 2542d19 | 2010-08-18 11:47:12 -0700 | [diff] [blame] | 237 | * @return True if the clip was modified. | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 238 | */ | 
| Romain Guy | bb9524b | 2010-06-22 18:56:38 -0700 | [diff] [blame] | 239 | bool restoreSnapshot(); | 
|  | 240 |  | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 241 | /** | 
|  | 242 | * Sets the clipping rectangle using glScissor. The clip is defined by | 
|  | 243 | * the current snapshot's clipRect member. | 
|  | 244 | */ | 
| Romain Guy | bb9524b | 2010-06-22 18:56:38 -0700 | [diff] [blame] | 245 | void setScissorFromClip(); | 
|  | 246 |  | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 247 | /** | 
| Romain Guy | d55a861 | 2010-06-28 17:42:46 -0700 | [diff] [blame] | 248 | * Creates a new layer stored in the specified snapshot. | 
|  | 249 | * | 
|  | 250 | * @param snapshot The snapshot associated with the new layer | 
|  | 251 | * @param left The left coordinate of the layer | 
|  | 252 | * @param top The top coordinate of the layer | 
|  | 253 | * @param right The right coordinate of the layer | 
|  | 254 | * @param bottom The bottom coordinate of the layer | 
|  | 255 | * @param alpha The translucency of the layer | 
|  | 256 | * @param mode The blending mode of the layer | 
|  | 257 | * @param flags The layer save flags | 
| Romain Guy | eb99356 | 2010-10-05 18:14:38 -0700 | [diff] [blame] | 258 | * @param previousFbo The name of the current framebuffer | 
| Romain Guy | d55a861 | 2010-06-28 17:42:46 -0700 | [diff] [blame] | 259 | * | 
|  | 260 | * @return True if the layer was successfully created, false otherwise | 
|  | 261 | */ | 
|  | 262 | bool createLayer(sp<Snapshot> snapshot, float left, float top, float right, float bottom, | 
| Romain Guy | eb99356 | 2010-10-05 18:14:38 -0700 | [diff] [blame] | 263 | int alpha, SkXfermode::Mode mode, int flags, GLuint previousFbo); | 
| Romain Guy | d55a861 | 2010-06-28 17:42:46 -0700 | [diff] [blame] | 264 |  | 
|  | 265 | /** | 
| Romain Guy | 5b3b352 | 2010-10-27 18:57:51 -0700 | [diff] [blame] | 266 | * Creates a new layer stored in the specified snapshot as an FBO. | 
|  | 267 | * | 
|  | 268 | * @param layer The layer to store as an FBO | 
|  | 269 | * @param snapshot The snapshot associated with the new layer | 
|  | 270 | * @param bounds The bounds of the layer | 
|  | 271 | * @param previousFbo The name of the current framebuffer | 
|  | 272 | */ | 
|  | 273 | bool createFboLayer(Layer* layer, Rect& bounds, sp<Snapshot> snapshot, | 
|  | 274 | GLuint previousFbo); | 
|  | 275 |  | 
|  | 276 | /** | 
|  | 277 | * Compose the specified layer as a region. | 
|  | 278 | * | 
|  | 279 | * @param layer The layer to compose | 
|  | 280 | * @param rect The layer's bounds | 
|  | 281 | */ | 
|  | 282 | void composeLayerRegion(Layer* layer, const Rect& rect); | 
|  | 283 |  | 
|  | 284 | /** | 
|  | 285 | * Compose the specified layer as a simple rectangle. | 
|  | 286 | * | 
|  | 287 | * @param layer The layer to compose | 
|  | 288 | * @param rect The layer's bounds | 
|  | 289 | * @param swap If true, the source and destination are swapped | 
|  | 290 | */ | 
|  | 291 | void composeLayerRect(Layer* layer, const Rect& rect, bool swap = false); | 
|  | 292 |  | 
| Romain Guy | 54be1cd | 2011-06-13 19:04:27 -0700 | [diff] [blame] | 293 | /** | 
|  | 294 | * Clears all the regions corresponding to the current list of layers. | 
|  | 295 | * This method MUST be invoked before any drawing operation. | 
|  | 296 | */ | 
|  | 297 | void clearLayerRegions(); | 
|  | 298 |  | 
|  | 299 | /** | 
| Romain Guy | f219da5 | 2011-01-16 12:54:25 -0800 | [diff] [blame] | 300 | * Mark the layer as dirty at the specified coordinates. The coordinates | 
|  | 301 | * are transformed with the supplied matrix. | 
|  | 302 | */ | 
|  | 303 | void dirtyLayer(const float left, const float top, | 
|  | 304 | const float right, const float bottom, const mat4 transform); | 
|  | 305 |  | 
|  | 306 | /** | 
|  | 307 | * Mark the layer as dirty at the specified coordinates. | 
|  | 308 | */ | 
|  | 309 | void dirtyLayer(const float left, const float top, | 
|  | 310 | const float right, const float bottom); | 
|  | 311 |  | 
|  | 312 | /** | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 313 | * Draws a colored rectangle with the specified color. The specified coordinates | 
|  | 314 | * are transformed by the current snapshot's transform matrix. | 
|  | 315 | * | 
|  | 316 | * @param left The left coordinate of the rectangle | 
|  | 317 | * @param top The top coordinate of the rectangle | 
|  | 318 | * @param right The right coordinate of the rectangle | 
|  | 319 | * @param bottom The bottom coordinate of the rectangle | 
|  | 320 | * @param color The rectangle's ARGB color, defined as a packed 32 bits word | 
| Romain Guy | 026c5e16 | 2010-06-28 17:12:22 -0700 | [diff] [blame] | 321 | * @param mode The Skia xfermode to use | 
| Romain Guy | 3d58c03 | 2010-07-14 16:34:53 -0700 | [diff] [blame] | 322 | * @param ignoreTransform True if the current transform should be ignored | 
| Romain Guy | 5b3b352 | 2010-10-27 18:57:51 -0700 | [diff] [blame] | 323 | * @param ignoreBlending True if the blending is set by the caller | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 324 | */ | 
| Romain Guy | 026c5e16 | 2010-06-28 17:12:22 -0700 | [diff] [blame] | 325 | void drawColorRect(float left, float top, float right, float bottom, | 
| Romain Guy | 1c740bc | 2010-09-13 18:00:09 -0700 | [diff] [blame] | 326 | int color, SkXfermode::Mode mode, bool ignoreTransform = false); | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 327 |  | 
| Romain Guy | 54be1cd | 2011-06-13 19:04:27 -0700 | [diff] [blame] | 328 | /** | 
|  | 329 | * Draws the shape represented by the specified path texture. | 
|  | 330 | * This method invokes drawPathTexture() but takes into account | 
|  | 331 | * the extra left/top offset and the texture offset to correctly | 
|  | 332 | * position the final shape. | 
|  | 333 | * | 
|  | 334 | * @param left The left coordinate of the shape to render | 
|  | 335 | * @param top The top coordinate of the shape to render | 
|  | 336 | * @param texture The texture reprsenting the shape | 
|  | 337 | * @param paint The paint to draw the shape with | 
|  | 338 | */ | 
| Chet Haase | 4865909 | 2012-05-31 15:21:51 -0700 | [diff] [blame] | 339 | status_t drawShape(float left, float top, const PathTexture* texture, SkPaint* paint); | 
| Romain Guy | 54be1cd | 2011-06-13 19:04:27 -0700 | [diff] [blame] | 340 |  | 
|  | 341 | /** | 
|  | 342 | * Renders the rect defined by the specified bounds as a shape. | 
|  | 343 | * This will render the rect using a path texture, which is used to render | 
|  | 344 | * rects with stroke effects. | 
|  | 345 | * | 
|  | 346 | * @param left The left coordinate of the rect to draw | 
|  | 347 | * @param top The top coordinate of the rect to draw | 
|  | 348 | * @param right The right coordinate of the rect to draw | 
|  | 349 | * @param bottom The bottom coordinate of the rect to draw | 
|  | 350 | * @param p The paint to draw the rect with | 
|  | 351 | */ | 
| Chet Haase | 4865909 | 2012-05-31 15:21:51 -0700 | [diff] [blame] | 352 | status_t drawRectAsShape(float left, float top, float right, float bottom, SkPaint* p); | 
| Romain Guy | c1cd9ba3 | 2011-01-23 14:18:41 -0800 | [diff] [blame] | 353 |  | 
| Romain Guy | 54be1cd | 2011-06-13 19:04:27 -0700 | [diff] [blame] | 354 | /** | 
|  | 355 | * Draws the specified texture as an alpha bitmap. Alpha bitmaps obey | 
|  | 356 | * different compositing rules. | 
|  | 357 | * | 
|  | 358 | * @param texture The texture to draw with | 
|  | 359 | * @param left The x coordinate of the bitmap | 
|  | 360 | * @param top The y coordinate of the bitmap | 
|  | 361 | * @param paint The paint to render with | 
|  | 362 | */ | 
| Romain Guy | a168d73 | 2011-03-18 16:50:13 -0700 | [diff] [blame] | 363 | void drawAlphaBitmap(Texture* texture, float left, float top, SkPaint* paint); | 
|  | 364 |  | 
| Romain Guy | 54be1cd | 2011-06-13 19:04:27 -0700 | [diff] [blame] | 365 | /** | 
|  | 366 | * Renders the rect defined by the specified bounds as an anti-aliased rect. | 
|  | 367 | * | 
|  | 368 | * @param left The left coordinate of the rect to draw | 
|  | 369 | * @param top The top coordinate of the rect to draw | 
|  | 370 | * @param right The right coordinate of the rect to draw | 
|  | 371 | * @param bottom The bottom coordinate of the rect to draw | 
|  | 372 | * @param color The color of the rect | 
|  | 373 | * @param mode The blending mode to draw the rect | 
|  | 374 | */ | 
| Chet Haase | 858aa93 | 2011-05-12 09:06:00 -0700 | [diff] [blame] | 375 | void drawAARect(float left, float top, float right, float bottom, | 
|  | 376 | int color, SkXfermode::Mode mode); | 
|  | 377 |  | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 378 | /** | 
|  | 379 | * Draws a textured rectangle with the specified texture. The specified coordinates | 
|  | 380 | * are transformed by the current snapshot's transform matrix. | 
|  | 381 | * | 
|  | 382 | * @param left The left coordinate of the rectangle | 
|  | 383 | * @param top The top coordinate of the rectangle | 
|  | 384 | * @param right The right coordinate of the rectangle | 
|  | 385 | * @param bottom The bottom coordinate of the rectangle | 
|  | 386 | * @param texture The texture name to map onto the rectangle | 
|  | 387 | * @param alpha An additional translucency parameter, between 0.0f and 1.0f | 
| Romain Guy | d55a861 | 2010-06-28 17:42:46 -0700 | [diff] [blame] | 388 | * @param mode The blending mode | 
| Romain Guy | c1396e9 | 2010-06-30 17:56:19 -0700 | [diff] [blame] | 389 | * @param blend True if the texture contains an alpha channel | 
| Romain Guy | 5cbbce5 | 2010-06-27 22:59:20 -0700 | [diff] [blame] | 390 | */ | 
| Romain Guy | bd6b79b | 2010-06-26 00:13:53 -0700 | [diff] [blame] | 391 | void drawTextureRect(float left, float top, float right, float bottom, GLuint texture, | 
| Romain Guy | a979474 | 2010-07-13 11:37:54 -0700 | [diff] [blame] | 392 | float alpha, SkXfermode::Mode mode, bool blend); | 
| Romain Guy | c7d5349 | 2010-06-25 13:41:57 -0700 | [diff] [blame] | 393 |  | 
| Romain Guy | 026c5e16 | 2010-06-28 17:12:22 -0700 | [diff] [blame] | 394 | /** | 
| Romain Guy | 82ba814 | 2010-07-09 13:25:56 -0700 | [diff] [blame] | 395 | * Draws a textured rectangle with the specified texture. The specified coordinates | 
|  | 396 | * are transformed by the current snapshot's transform matrix. | 
|  | 397 | * | 
|  | 398 | * @param left The left coordinate of the rectangle | 
|  | 399 | * @param top The top coordinate of the rectangle | 
|  | 400 | * @param right The right coordinate of the rectangle | 
|  | 401 | * @param bottom The bottom coordinate of the rectangle | 
|  | 402 | * @param texture The texture to use | 
|  | 403 | * @param paint The paint containing the alpha, blending mode, etc. | 
| Romain Guy | 82ba814 | 2010-07-09 13:25:56 -0700 | [diff] [blame] | 404 | */ | 
| Romain Guy | a979474 | 2010-07-13 11:37:54 -0700 | [diff] [blame] | 405 | void drawTextureRect(float left, float top, float right, float bottom, | 
| Romain Guy | 8164c2d | 2010-10-25 18:03:28 -0700 | [diff] [blame] | 406 | Texture* texture, SkPaint* paint); | 
| Romain Guy | 82ba814 | 2010-07-09 13:25:56 -0700 | [diff] [blame] | 407 |  | 
|  | 408 | /** | 
| Romain Guy | 03750a0 | 2010-10-18 14:06:08 -0700 | [diff] [blame] | 409 | * Draws a textured mesh with the specified texture. If the indices are omitted, | 
|  | 410 | * the mesh is drawn as a simple quad. The mesh pointers become offsets when a | 
|  | 411 | * VBO is bound. | 
| Romain Guy | 82ba814 | 2010-07-09 13:25:56 -0700 | [diff] [blame] | 412 | * | 
|  | 413 | * @param left The left coordinate of the rectangle | 
|  | 414 | * @param top The top coordinate of the rectangle | 
|  | 415 | * @param right The right coordinate of the rectangle | 
|  | 416 | * @param bottom The bottom coordinate of the rectangle | 
|  | 417 | * @param texture The texture name to map onto the rectangle | 
|  | 418 | * @param alpha An additional translucency parameter, between 0.0f and 1.0f | 
|  | 419 | * @param mode The blending mode | 
|  | 420 | * @param blend True if the texture contains an alpha channel | 
| Romain Guy | 82ba814 | 2010-07-09 13:25:56 -0700 | [diff] [blame] | 421 | * @param vertices The vertices that define the mesh | 
|  | 422 | * @param texCoords The texture coordinates of each vertex | 
| Romain Guy | 82ba814 | 2010-07-09 13:25:56 -0700 | [diff] [blame] | 423 | * @param elementsCount The number of elements in the mesh, required by indices | 
| Romain Guy | f607bdc | 2010-09-10 19:20:06 -0700 | [diff] [blame] | 424 | * @param swapSrcDst Whether or not the src and dst blending operations should be swapped | 
|  | 425 | * @param ignoreTransform True if the current transform should be ignored | 
| Romain Guy | 03750a0 | 2010-10-18 14:06:08 -0700 | [diff] [blame] | 426 | * @param vbo The VBO used to draw the mesh | 
| Romain Guy | 5b3b352 | 2010-10-27 18:57:51 -0700 | [diff] [blame] | 427 | * @param ignoreScale True if the model view matrix should not be scaled | 
|  | 428 | * @param dirty True if calling this method should dirty the current layer | 
| Romain Guy | f7f9355 | 2010-07-08 19:17:03 -0700 | [diff] [blame] | 429 | */ | 
|  | 430 | void drawTextureMesh(float left, float top, float right, float bottom, GLuint texture, | 
| Romain Guy | a979474 | 2010-07-13 11:37:54 -0700 | [diff] [blame] | 431 | float alpha, SkXfermode::Mode mode, bool blend, | 
| Romain Guy | 6820ac8 | 2010-09-15 18:11:50 -0700 | [diff] [blame] | 432 | GLvoid* vertices, GLvoid* texCoords, GLenum drawMode, GLsizei elementsCount, | 
| Romain Guy | 5b3b352 | 2010-10-27 18:57:51 -0700 | [diff] [blame] | 433 | bool swapSrcDst = false, bool ignoreTransform = false, GLuint vbo = 0, | 
|  | 434 | bool ignoreScale = false, bool dirty = true); | 
| Romain Guy | f7f9355 | 2010-07-08 19:17:03 -0700 | [diff] [blame] | 435 |  | 
|  | 436 | /** | 
| Romain Guy | 0a41749 | 2010-08-16 20:26:20 -0700 | [diff] [blame] | 437 | * Draws text underline and strike-through if needed. | 
|  | 438 | * | 
|  | 439 | * @param text The text to decor | 
|  | 440 | * @param bytesCount The number of bytes in the text | 
|  | 441 | * @param length The length in pixels of the text, can be <= 0.0f to force a measurement | 
|  | 442 | * @param x The x coordinate where the text will be drawn | 
|  | 443 | * @param y The y coordinate where the text will be drawn | 
|  | 444 | * @param paint The paint to draw the text with | 
|  | 445 | */ | 
|  | 446 | void drawTextDecorations(const char* text, int bytesCount, float length, | 
|  | 447 | float x, float y, SkPaint* paint); | 
| Romain Guy | 1e45aae | 2010-08-13 19:39:53 -0700 | [diff] [blame] | 448 |  | 
| Romain Guy | 54be1cd | 2011-06-13 19:04:27 -0700 | [diff] [blame] | 449 | /** | 
|  | 450 | * Draws a path texture. Path textures are alpha8 bitmaps that need special | 
|  | 451 | * compositing to apply colors/filters/etc. | 
|  | 452 | * | 
|  | 453 | * @param texture The texture to render | 
|  | 454 | * @param x The x coordinate where the texture will be drawn | 
|  | 455 | * @param y The y coordinate where the texture will be drawn | 
|  | 456 | * @param paint The paint to draw the texture with | 
|  | 457 | */ | 
| Romain Guy | 01d58e4 | 2011-01-19 21:54:02 -0800 | [diff] [blame] | 458 | void drawPathTexture(const PathTexture* texture, float x, float y, SkPaint* paint); | 
|  | 459 |  | 
| Romain Guy | 1e45aae | 2010-08-13 19:39:53 -0700 | [diff] [blame] | 460 | /** | 
| Romain Guy | ac670c0 | 2010-07-27 17:39:27 -0700 | [diff] [blame] | 461 | * Resets the texture coordinates stored in mMeshVertices. Setting the values | 
| Romain Guy | 026c5e16 | 2010-06-28 17:12:22 -0700 | [diff] [blame] | 462 | * back to default is achieved by calling: | 
|  | 463 | * | 
| Romain Guy | 8ba548f | 2010-06-30 19:21:21 -0700 | [diff] [blame] | 464 | * resetDrawTextureTexCoords(0.0f, 0.0f, 1.0f, 1.0f); | 
| Romain Guy | 026c5e16 | 2010-06-28 17:12:22 -0700 | [diff] [blame] | 465 | * | 
|  | 466 | * @param u1 The left coordinate of the texture | 
|  | 467 | * @param v1 The bottom coordinate of the texture | 
|  | 468 | * @param u2 The right coordinate of the texture | 
|  | 469 | * @param v2 The top coordinate of the texture | 
|  | 470 | */ | 
|  | 471 | void resetDrawTextureTexCoords(float u1, float v1, float u2, float v2); | 
|  | 472 |  | 
| Romain Guy | 8ba548f | 2010-06-30 19:21:21 -0700 | [diff] [blame] | 473 | /** | 
|  | 474 | * Gets the alpha and xfermode out of a paint object. If the paint is null | 
|  | 475 | * alpha will be 255 and the xfermode will be SRC_OVER. | 
|  | 476 | * | 
|  | 477 | * @param paint The paint to extract values from | 
|  | 478 | * @param alpha Where to store the resulting alpha | 
|  | 479 | * @param mode Where to store the resulting xfermode | 
|  | 480 | */ | 
| Chet Haase | 5c13d89 | 2010-10-08 08:37:55 -0700 | [diff] [blame] | 481 | inline void getAlphaAndMode(SkPaint* paint, int* alpha, SkXfermode::Mode* mode); | 
| Romain Guy | 8ba548f | 2010-06-30 19:21:21 -0700 | [diff] [blame] | 482 |  | 
| Romain Guy | f7f9355 | 2010-07-08 19:17:03 -0700 | [diff] [blame] | 483 | /** | 
| Romain Guy | 746b740 | 2010-10-26 16:27:31 -0700 | [diff] [blame] | 484 | * Binds the specified texture. The texture unit must have been selected | 
|  | 485 | * prior to calling this method. | 
| Romain Guy | a1db574 | 2010-07-20 13:09:13 -0700 | [diff] [blame] | 486 | */ | 
| Romain Guy | 746b740 | 2010-10-26 16:27:31 -0700 | [diff] [blame] | 487 | inline void bindTexture(GLuint texture) { | 
|  | 488 | glBindTexture(GL_TEXTURE_2D, texture); | 
|  | 489 | } | 
|  | 490 |  | 
|  | 491 | /** | 
| Romain Guy | aa6c24c | 2011-04-28 18:40:04 -0700 | [diff] [blame] | 492 | * Binds the specified EGLImage texture. The texture unit must have been selected | 
|  | 493 | * prior to calling this method. | 
|  | 494 | */ | 
|  | 495 | inline void bindExternalTexture(GLuint texture) { | 
|  | 496 | glBindTexture(GL_TEXTURE_EXTERNAL_OES, texture); | 
|  | 497 | } | 
|  | 498 |  | 
|  | 499 | /** | 
| Romain Guy | 82ba814 | 2010-07-09 13:25:56 -0700 | [diff] [blame] | 500 | * Enable or disable blending as necessary. This function sets the appropriate | 
|  | 501 | * blend function based on the specified xfermode. | 
|  | 502 | */ | 
| Romain Guy | f607bdc | 2010-09-10 19:20:06 -0700 | [diff] [blame] | 503 | inline void chooseBlending(bool blend, SkXfermode::Mode mode, ProgramDescription& description, | 
|  | 504 | bool swapSrcDst = false); | 
| Romain Guy | a5aed0d | 2010-09-09 14:42:43 -0700 | [diff] [blame] | 505 |  | 
| Romain Guy | f607bdc | 2010-09-10 19:20:06 -0700 | [diff] [blame] | 506 | /** | 
|  | 507 | * Safely retrieves the mode from the specified xfermode. If the specified | 
|  | 508 | * xfermode is null, the mode is assumed to be SkXfermode::kSrcOver_Mode. | 
|  | 509 | */ | 
| Romain Guy | a5aed0d | 2010-09-09 14:42:43 -0700 | [diff] [blame] | 510 | inline SkXfermode::Mode getXfermode(SkXfermode* mode); | 
| Romain Guy | 82ba814 | 2010-07-09 13:25:56 -0700 | [diff] [blame] | 511 |  | 
| Romain Guy | 260e102 | 2010-07-12 14:41:06 -0700 | [diff] [blame] | 512 | /** | 
| Romain Guy | d27977d | 2010-07-14 19:18:51 -0700 | [diff] [blame] | 513 | * Use the specified program with the current GL context. If the program is already | 
|  | 514 | * in use, it will not be bound again. If it is not in use, the current program is | 
|  | 515 | * marked unused and the specified program becomes used and becomes the new | 
|  | 516 | * current program. | 
| Romain Guy | 6926c72 | 2010-07-12 20:20:03 -0700 | [diff] [blame] | 517 | * | 
| Romain Guy | d27977d | 2010-07-14 19:18:51 -0700 | [diff] [blame] | 518 | * @param program The program to use | 
|  | 519 | * | 
|  | 520 | * @return true If the specified program was already in use, false otherwise. | 
| Romain Guy | 260e102 | 2010-07-12 14:41:06 -0700 | [diff] [blame] | 521 | */ | 
| Romain Guy | 889f8d1 | 2010-07-29 14:37:42 -0700 | [diff] [blame] | 522 | inline bool useProgram(Program* program); | 
| Romain Guy | 260e102 | 2010-07-12 14:41:06 -0700 | [diff] [blame] | 523 |  | 
| Romain Guy | 746b740 | 2010-10-26 16:27:31 -0700 | [diff] [blame] | 524 | /** | 
|  | 525 | * Invoked before any drawing operation. This sets required state. | 
|  | 526 | */ | 
| Romain Guy | 54be1cd | 2011-06-13 19:04:27 -0700 | [diff] [blame] | 527 | void setupDraw(bool clear = true); | 
| Romain Guy | 70ca14e | 2010-12-13 18:24:33 -0800 | [diff] [blame] | 528 | /** | 
|  | 529 | * Various methods to setup OpenGL rendering. | 
|  | 530 | */ | 
|  | 531 | void setupDrawWithTexture(bool isAlpha8 = false); | 
| Romain Guy | aa6c24c | 2011-04-28 18:40:04 -0700 | [diff] [blame] | 532 | void setupDrawWithExternalTexture(); | 
| Romain Guy | 15bc643 | 2011-12-13 13:11:32 -0800 | [diff] [blame] | 533 | void setupDrawNoTexture(); | 
| Chet Haase | 5b0200b | 2011-04-13 17:58:08 -0700 | [diff] [blame] | 534 | void setupDrawAALine(); | 
| Romain Guy | ed6fcb0 | 2011-03-21 13:11:28 -0700 | [diff] [blame] | 535 | void setupDrawPoint(float pointSize); | 
| Romain Guy | 70ca14e | 2010-12-13 18:24:33 -0800 | [diff] [blame] | 536 | void setupDrawColor(int color); | 
| Romain Guy | 8d0d478 | 2010-12-14 20:13:35 -0800 | [diff] [blame] | 537 | void setupDrawColor(int color, int alpha); | 
| Romain Guy | 70ca14e | 2010-12-13 18:24:33 -0800 | [diff] [blame] | 538 | void setupDrawColor(float r, float g, float b, float a); | 
| Romain Guy | 8656819 | 2010-12-14 15:55:39 -0800 | [diff] [blame] | 539 | void setupDrawAlpha8Color(int color, int alpha); | 
|  | 540 | void setupDrawAlpha8Color(float r, float g, float b, float a); | 
| Romain Guy | 70ca14e | 2010-12-13 18:24:33 -0800 | [diff] [blame] | 541 | void setupDrawShader(); | 
|  | 542 | void setupDrawColorFilter(); | 
|  | 543 | void setupDrawBlending(SkXfermode::Mode mode = SkXfermode::kSrcOver_Mode, | 
|  | 544 | bool swapSrcDst = false); | 
|  | 545 | void setupDrawBlending(bool blend = true, SkXfermode::Mode mode = SkXfermode::kSrcOver_Mode, | 
|  | 546 | bool swapSrcDst = false); | 
|  | 547 | void setupDrawProgram(); | 
|  | 548 | void setupDrawDirtyRegionsDisabled(); | 
| Chet Haase | 8a5cc92 | 2011-04-26 07:28:09 -0700 | [diff] [blame] | 549 | void setupDrawModelViewIdentity(bool offset = false); | 
| Romain Guy | 70ca14e | 2010-12-13 18:24:33 -0800 | [diff] [blame] | 550 | void setupDrawModelView(float left, float top, float right, float bottom, | 
|  | 551 | bool ignoreTransform = false, bool ignoreModelView = false); | 
|  | 552 | void setupDrawModelViewTranslate(float left, float top, float right, float bottom, | 
|  | 553 | bool ignoreTransform = false); | 
| Romain Guy | ed6fcb0 | 2011-03-21 13:11:28 -0700 | [diff] [blame] | 554 | void setupDrawPointUniforms(); | 
| Romain Guy | 70ca14e | 2010-12-13 18:24:33 -0800 | [diff] [blame] | 555 | void setupDrawColorUniforms(); | 
| Romain Guy | 8656819 | 2010-12-14 15:55:39 -0800 | [diff] [blame] | 556 | void setupDrawPureColorUniforms(); | 
| Romain Guy | 8d0d478 | 2010-12-14 20:13:35 -0800 | [diff] [blame] | 557 | void setupDrawShaderIdentityUniforms(); | 
| Romain Guy | 70ca14e | 2010-12-13 18:24:33 -0800 | [diff] [blame] | 558 | void setupDrawShaderUniforms(bool ignoreTransform = false); | 
|  | 559 | void setupDrawColorFilterUniforms(); | 
|  | 560 | void setupDrawSimpleMesh(); | 
|  | 561 | void setupDrawTexture(GLuint texture); | 
| Romain Guy | aa6c24c | 2011-04-28 18:40:04 -0700 | [diff] [blame] | 562 | void setupDrawExternalTexture(GLuint texture); | 
| Romain Guy | 8f0095c | 2011-05-02 17:24:22 -0700 | [diff] [blame] | 563 | void setupDrawTextureTransform(); | 
|  | 564 | void setupDrawTextureTransformUniforms(mat4& transform); | 
| Romain Guy | 8d0d478 | 2010-12-14 20:13:35 -0800 | [diff] [blame] | 565 | void setupDrawMesh(GLvoid* vertices, GLvoid* texCoords = NULL, GLuint vbo = 0); | 
| Romain Guy | 15bc643 | 2011-12-13 13:11:32 -0800 | [diff] [blame] | 566 | void setupDrawMeshIndices(GLvoid* vertices, GLvoid* texCoords); | 
| Chet Haase | 5b0200b | 2011-04-13 17:58:08 -0700 | [diff] [blame] | 567 | void setupDrawVertices(GLvoid* vertices); | 
| Chet Haase | 99585ad | 2011-05-02 15:00:16 -0700 | [diff] [blame] | 568 | void setupDrawAALine(GLvoid* vertices, GLvoid* distanceCoords, GLvoid* lengthCoords, | 
| Romain Guy | 7b63142 | 2012-04-04 11:38:54 -0700 | [diff] [blame] | 569 | float strokeWidth, int& widthSlot, int& lengthSlot); | 
|  | 570 | void finishDrawAALine(const int widthSlot, const int lengthSlot); | 
| Romain Guy | 70ca14e | 2010-12-13 18:24:33 -0800 | [diff] [blame] | 571 | void finishDrawTexture(); | 
| Romain Guy | f09ef51 | 2011-05-27 11:43:46 -0700 | [diff] [blame] | 572 | void accountForClear(SkXfermode::Mode mode); | 
| Romain Guy | 746b740 | 2010-10-26 16:27:31 -0700 | [diff] [blame] | 573 |  | 
| Romain Guy | 3a3133d | 2011-02-01 22:59:58 -0800 | [diff] [blame] | 574 | void drawRegionRects(const Region& region); | 
|  | 575 |  | 
| Romain Guy | 746b740 | 2010-10-26 16:27:31 -0700 | [diff] [blame] | 576 | /** | 
|  | 577 | * Should be invoked every time the glScissor is modified. | 
|  | 578 | */ | 
|  | 579 | inline void dirtyClip() { | 
|  | 580 | mDirtyClip = true; | 
|  | 581 | } | 
|  | 582 |  | 
| Romain Guy | bb9524b | 2010-06-22 18:56:38 -0700 | [diff] [blame] | 583 | // Dimensions of the drawing surface | 
|  | 584 | int mWidth, mHeight; | 
|  | 585 |  | 
| Romain Guy | 85bf02f | 2010-06-22 13:11:24 -0700 | [diff] [blame] | 586 | // Matrix used for ortho projection in shaders | 
| Romain Guy | 260e102 | 2010-07-12 14:41:06 -0700 | [diff] [blame] | 587 | mat4 mOrthoMatrix; | 
| Romain Guy | bb9524b | 2010-06-22 18:56:38 -0700 | [diff] [blame] | 588 |  | 
| Romain Guy | c7d5349 | 2010-06-25 13:41:57 -0700 | [diff] [blame] | 589 | // Model-view matrix used to position/size objects | 
|  | 590 | mat4 mModelView; | 
|  | 591 |  | 
| Romain Guy | bb9524b | 2010-06-22 18:56:38 -0700 | [diff] [blame] | 592 | // Number of saved states | 
|  | 593 | int mSaveCount; | 
| Romain Guy | f6a11b8 | 2010-06-23 17:47:49 -0700 | [diff] [blame] | 594 | // Base state | 
| Romain Guy | ae5575b | 2010-07-29 18:48:04 -0700 | [diff] [blame] | 595 | sp<Snapshot> mFirstSnapshot; | 
| Romain Guy | bb9524b | 2010-06-22 18:56:38 -0700 | [diff] [blame] | 596 | // Current state | 
|  | 597 | sp<Snapshot> mSnapshot; | 
| Romain Guy | 9d5316e | 2010-06-24 19:30:36 -0700 | [diff] [blame] | 598 |  | 
|  | 599 | // Shaders | 
| Romain Guy | 06f96e2 | 2010-07-30 19:18:16 -0700 | [diff] [blame] | 600 | SkiaShader* mShader; | 
| Romain Guy | 026c5e16 | 2010-06-28 17:12:22 -0700 | [diff] [blame] | 601 |  | 
| Romain Guy | db1938e | 2010-08-02 18:50:22 -0700 | [diff] [blame] | 602 | // Color filters | 
|  | 603 | SkiaColorFilter* mColorFilter; | 
|  | 604 |  | 
| Romain Guy | 026c5e16 | 2010-06-28 17:12:22 -0700 | [diff] [blame] | 605 | // Used to draw textured quads | 
| Romain Guy | ac670c0 | 2010-07-27 17:39:27 -0700 | [diff] [blame] | 606 | TextureVertex mMeshVertices[4]; | 
| Romain Guy | ce0537b | 2010-06-29 21:05:21 -0700 | [diff] [blame] | 607 |  | 
| Romain Guy | 1e45aae | 2010-08-13 19:39:53 -0700 | [diff] [blame] | 608 | // Drop shadow | 
|  | 609 | bool mHasShadow; | 
|  | 610 | float mShadowRadius; | 
|  | 611 | float mShadowDx; | 
|  | 612 | float mShadowDy; | 
|  | 613 | int mShadowColor; | 
|  | 614 |  | 
| Romain Guy | 5ff9df6 | 2012-01-23 17:09:05 -0800 | [diff] [blame] | 615 | // Draw filters | 
|  | 616 | bool mHasDrawFilter; | 
|  | 617 | int mPaintFilterClearBits; | 
|  | 618 | int mPaintFilterSetBits; | 
|  | 619 | SkPaint mFilteredPaint; | 
|  | 620 |  | 
| Romain Guy | 82ba814 | 2010-07-09 13:25:56 -0700 | [diff] [blame] | 621 | // Various caches | 
| Romain Guy | fb8b763 | 2010-08-23 21:05:08 -0700 | [diff] [blame] | 622 | Caches& mCaches; | 
| Romain Guy | 8694230 | 2010-09-12 13:02:16 -0700 | [diff] [blame] | 623 |  | 
| Romain Guy | 8f3b8e3 | 2012-03-27 16:33:45 -0700 | [diff] [blame] | 624 | // List of rectangles to clear after saveLayer() is invoked | 
| Romain Guy | 54be1cd | 2011-06-13 19:04:27 -0700 | [diff] [blame] | 625 | Vector<Rect*> mLayers; | 
| Romain Guy | 8f3b8e3 | 2012-03-27 16:33:45 -0700 | [diff] [blame] | 626 | // List of functors to invoke after a frame is drawn | 
| Romain Guy | ba6be8a | 2012-04-23 18:22:09 -0700 | [diff] [blame] | 627 | SortedVector<Functor*> mFunctors; | 
| Romain Guy | 54be1cd | 2011-06-13 19:04:27 -0700 | [diff] [blame] | 628 |  | 
| Romain Guy | 99bcdc5 | 2010-10-13 15:17:00 -0700 | [diff] [blame] | 629 | // Indentity matrix | 
|  | 630 | const mat4 mIdentity; | 
|  | 631 |  | 
| Romain Guy | 746b740 | 2010-10-26 16:27:31 -0700 | [diff] [blame] | 632 | // Indicates whether the clip must be restored | 
|  | 633 | bool mDirtyClip; | 
|  | 634 |  | 
| Romain Guy | 70ca14e | 2010-12-13 18:24:33 -0800 | [diff] [blame] | 635 | // The following fields are used to setup drawing | 
|  | 636 | // Used to describe the shaders to generate | 
|  | 637 | ProgramDescription mDescription; | 
|  | 638 | // Color description | 
|  | 639 | bool mColorSet; | 
|  | 640 | float mColorA, mColorR, mColorG, mColorB; | 
|  | 641 | // Indicates that the shader should get a color | 
|  | 642 | bool mSetShaderColor; | 
|  | 643 | // Current texture unit | 
|  | 644 | GLuint mTextureUnit; | 
|  | 645 | // Track dirty regions, true by default | 
|  | 646 | bool mTrackDirtyRegions; | 
| Romain Guy | 70ca14e | 2010-12-13 18:24:33 -0800 | [diff] [blame] | 647 |  | 
| Romain Guy | b051e89 | 2010-09-28 19:09:36 -0700 | [diff] [blame] | 648 | friend class DisplayListRenderer; | 
|  | 649 |  | 
| Romain Guy | bb9524b | 2010-06-22 18:56:38 -0700 | [diff] [blame] | 650 | }; // class OpenGLRenderer | 
| Romain Guy | e4d0112 | 2010-06-16 18:44:05 -0700 | [diff] [blame] | 651 |  | 
| Romain Guy | 9d5316e | 2010-06-24 19:30:36 -0700 | [diff] [blame] | 652 | }; // namespace uirenderer | 
| Romain Guy | e4d0112 | 2010-06-16 18:44:05 -0700 | [diff] [blame] | 653 | }; // namespace android | 
|  | 654 |  | 
| Romain Guy | 5b3b352 | 2010-10-27 18:57:51 -0700 | [diff] [blame] | 655 | #endif // ANDROID_HWUI_OPENGL_RENDERER_H |