1 /* 2 * Copyright (C) 2011 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_HWUI_DRAW_GL_INFO_H 18 #define ANDROID_HWUI_DRAW_GL_INFO_H 19 20 namespace android { 21 namespace uirenderer { 22 23 /** 24 * Structure used by OpenGLRenderer::callDrawGLFunction() to pass and 25 * receive data from OpenGL functors. 26 */ 27 struct DrawGlInfo { 28 // Input: current clip rect 29 int clipLeft; 30 int clipTop; 31 int clipRight; 32 int clipBottom; 33 34 // Input: current width/height of destination surface 35 int width; 36 int height; 37 38 // Input: is the render target an FBO 39 bool isLayer; 40 41 // Input: current transform matrix, in OpenGL format 42 float transform[16]; 43 44 // Output: dirty region to redraw 45 float dirtyLeft; 46 float dirtyTop; 47 float dirtyRight; 48 float dirtyBottom; 49 50 /** 51 * Values used as the "what" parameter of the functor. 52 */ 53 enum Mode { 54 // Indicates that the functor is called to perform a draw 55 kModeDraw, 56 // Indicates the the functor is called only to perform 57 // processing and that no draw should be attempted 58 kModeProcess 59 }; 60 61 /** 62 * Values used by OpenGL functors to tell the framework 63 * what to do next. 64 */ 65 enum Status { 66 // The functor is done 67 kStatusDone = 0x0, 68 // The functor is requesting a redraw (the clip rect 69 // used by the redraw is specified by DrawGlInfo.) 70 // The rest of the UI might redraw too. 71 kStatusDraw = 0x1, 72 // The functor needs to be invoked again but will 73 // not redraw. Only the functor is invoked again 74 // (unless another functor requests a redraw.) 75 kStatusInvoke = 0x2, 76 // DisplayList actually issued GL drawing commands. 77 // This is used to signal the HardwareRenderer that the 78 // buffers should be flipped - otherwise, there were no 79 // changes to the buffer, so no need to flip. Some hardware 80 // has issues with stale buffer contents when no GL 81 // commands are issued. 82 kStatusDrew = 0x4 83 }; 84 }; // struct DrawGlInfo 85 86 }; // namespace uirenderer 87 }; // namespace android 88 89 #endif // ANDROID_HWUI_DRAW_GL_INFO_H 90