Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(143)

Side by Side Diff: content/common/gpu/client/gl_helper.h

Issue 63253002: Rename WebKit namespace to blink (part 3) (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CONTENT_COMMON_GPU_CLIENT_GL_HELPER_H_ 5 #ifndef CONTENT_COMMON_GPU_CLIENT_GL_HELPER_H_
6 #define CONTENT_COMMON_GPU_CLIENT_GL_HELPER_H_ 6 #define CONTENT_COMMON_GPU_CLIENT_GL_HELPER_H_
7 7
8 #include "base/atomicops.h" 8 #include "base/atomicops.h"
9 #include "base/basictypes.h" 9 #include "base/basictypes.h"
10 #include "base/callback.h" 10 #include "base/callback.h"
(...skipping 16 matching lines...) Expand all
27 }; 27 };
28 28
29 class SkRegion; 29 class SkRegion;
30 30
31 namespace content { 31 namespace content {
32 32
33 class GLHelperScaling; 33 class GLHelperScaling;
34 34
35 class ScopedWebGLId { 35 class ScopedWebGLId {
36 public: 36 public:
37 typedef void (WebKit::WebGraphicsContext3D::*DeleteFunc)(WebGLId); 37 typedef void (blink::WebGraphicsContext3D::*DeleteFunc)(WebGLId);
38 ScopedWebGLId(WebKit::WebGraphicsContext3D* context, 38 ScopedWebGLId(blink::WebGraphicsContext3D* context,
39 WebGLId id, 39 WebGLId id,
40 DeleteFunc delete_func) 40 DeleteFunc delete_func)
41 : context_(context), 41 : context_(context),
42 id_(id), 42 id_(id),
43 delete_func_(delete_func) { 43 delete_func_(delete_func) {
44 } 44 }
45 45
46 operator WebGLId() const { 46 operator WebGLId() const {
47 return id_; 47 return id_;
48 } 48 }
49 49
50 WebGLId id() const { return id_; } 50 WebGLId id() const { return id_; }
51 51
52 WebGLId Detach() { 52 WebGLId Detach() {
53 WebGLId id = id_; 53 WebGLId id = id_;
54 id_ = 0; 54 id_ = 0;
55 return id; 55 return id;
56 } 56 }
57 57
58 ~ScopedWebGLId() { 58 ~ScopedWebGLId() {
59 if (id_ != 0) { 59 if (id_ != 0) {
60 (context_->*delete_func_)(id_); 60 (context_->*delete_func_)(id_);
61 } 61 }
62 } 62 }
63 63
64 private: 64 private:
65 WebKit::WebGraphicsContext3D* context_; 65 blink::WebGraphicsContext3D* context_;
66 WebGLId id_; 66 WebGLId id_;
67 DeleteFunc delete_func_; 67 DeleteFunc delete_func_;
68 68
69 DISALLOW_COPY_AND_ASSIGN(ScopedWebGLId); 69 DISALLOW_COPY_AND_ASSIGN(ScopedWebGLId);
70 }; 70 };
71 71
72 class ScopedBuffer : public ScopedWebGLId { 72 class ScopedBuffer : public ScopedWebGLId {
73 public: 73 public:
74 ScopedBuffer(WebKit::WebGraphicsContext3D* context, 74 ScopedBuffer(blink::WebGraphicsContext3D* context,
75 WebGLId id) 75 WebGLId id)
76 : ScopedWebGLId(context, 76 : ScopedWebGLId(context,
77 id, 77 id,
78 &WebKit::WebGraphicsContext3D::deleteBuffer) {} 78 &blink::WebGraphicsContext3D::deleteBuffer) {}
79 }; 79 };
80 80
81 class ScopedFramebuffer : public ScopedWebGLId { 81 class ScopedFramebuffer : public ScopedWebGLId {
82 public: 82 public:
83 ScopedFramebuffer(WebKit::WebGraphicsContext3D* context, 83 ScopedFramebuffer(blink::WebGraphicsContext3D* context,
84 WebGLId id) 84 WebGLId id)
85 : ScopedWebGLId(context, 85 : ScopedWebGLId(context,
86 id, 86 id,
87 &WebKit::WebGraphicsContext3D::deleteFramebuffer) {} 87 &blink::WebGraphicsContext3D::deleteFramebuffer) {}
88 }; 88 };
89 89
90 class ScopedProgram : public ScopedWebGLId { 90 class ScopedProgram : public ScopedWebGLId {
91 public: 91 public:
92 ScopedProgram(WebKit::WebGraphicsContext3D* context, 92 ScopedProgram(blink::WebGraphicsContext3D* context,
93 WebGLId id) 93 WebGLId id)
94 : ScopedWebGLId(context, 94 : ScopedWebGLId(context,
95 id, 95 id,
96 &WebKit::WebGraphicsContext3D::deleteProgram) {} 96 &blink::WebGraphicsContext3D::deleteProgram) {}
97 }; 97 };
98 98
99 class ScopedShader : public ScopedWebGLId { 99 class ScopedShader : public ScopedWebGLId {
100 public: 100 public:
101 ScopedShader(WebKit::WebGraphicsContext3D* context, 101 ScopedShader(blink::WebGraphicsContext3D* context,
102 WebGLId id) 102 WebGLId id)
103 : ScopedWebGLId(context, 103 : ScopedWebGLId(context,
104 id, 104 id,
105 &WebKit::WebGraphicsContext3D::deleteShader) {} 105 &blink::WebGraphicsContext3D::deleteShader) {}
106 }; 106 };
107 107
108 class ScopedTexture : public ScopedWebGLId { 108 class ScopedTexture : public ScopedWebGLId {
109 public: 109 public:
110 ScopedTexture(WebKit::WebGraphicsContext3D* context, 110 ScopedTexture(blink::WebGraphicsContext3D* context,
111 WebGLId id) 111 WebGLId id)
112 : ScopedWebGLId(context, 112 : ScopedWebGLId(context,
113 id, 113 id,
114 &WebKit::WebGraphicsContext3D::deleteTexture) {} 114 &blink::WebGraphicsContext3D::deleteTexture) {}
115 }; 115 };
116 116
117 template <WebKit::WGC3Denum target> 117 template <blink::WGC3Denum target>
118 class ScopedBinder { 118 class ScopedBinder {
119 public: 119 public:
120 typedef void (WebKit::WebGraphicsContext3D::*BindFunc)(WebKit::WGC3Denum, 120 typedef void (blink::WebGraphicsContext3D::*BindFunc)(blink::WGC3Denum,
121 WebGLId); 121 WebGLId);
122 ScopedBinder(WebKit::WebGraphicsContext3D* context, 122 ScopedBinder(blink::WebGraphicsContext3D* context,
123 WebGLId id, 123 WebGLId id,
124 BindFunc bind_func) 124 BindFunc bind_func)
125 : context_(context), 125 : context_(context),
126 bind_func_(bind_func) { 126 bind_func_(bind_func) {
127 (context_->*bind_func_)(target, id); 127 (context_->*bind_func_)(target, id);
128 } 128 }
129 129
130 virtual ~ScopedBinder() { 130 virtual ~ScopedBinder() {
131 (context_->*bind_func_)(target, 0); 131 (context_->*bind_func_)(target, 0);
132 } 132 }
133 133
134 private: 134 private:
135 WebKit::WebGraphicsContext3D* context_; 135 blink::WebGraphicsContext3D* context_;
136 BindFunc bind_func_; 136 BindFunc bind_func_;
137 137
138 DISALLOW_COPY_AND_ASSIGN(ScopedBinder); 138 DISALLOW_COPY_AND_ASSIGN(ScopedBinder);
139 }; 139 };
140 140
141 template <WebKit::WGC3Denum target> 141 template <blink::WGC3Denum target>
142 class ScopedBufferBinder : ScopedBinder<target> { 142 class ScopedBufferBinder : ScopedBinder<target> {
143 public: 143 public:
144 ScopedBufferBinder(WebKit::WebGraphicsContext3D* context, 144 ScopedBufferBinder(blink::WebGraphicsContext3D* context,
145 WebGLId id) 145 WebGLId id)
146 : ScopedBinder<target>( 146 : ScopedBinder<target>(
147 context, 147 context,
148 id, 148 id,
149 &WebKit::WebGraphicsContext3D::bindBuffer) {} 149 &blink::WebGraphicsContext3D::bindBuffer) {}
150 }; 150 };
151 151
152 template <WebKit::WGC3Denum target> 152 template <blink::WGC3Denum target>
153 class ScopedFramebufferBinder : ScopedBinder<target> { 153 class ScopedFramebufferBinder : ScopedBinder<target> {
154 public: 154 public:
155 ScopedFramebufferBinder(WebKit::WebGraphicsContext3D* context, 155 ScopedFramebufferBinder(blink::WebGraphicsContext3D* context,
156 WebGLId id) 156 WebGLId id)
157 : ScopedBinder<target>( 157 : ScopedBinder<target>(
158 context, 158 context,
159 id, 159 id,
160 &WebKit::WebGraphicsContext3D::bindFramebuffer) {} 160 &blink::WebGraphicsContext3D::bindFramebuffer) {}
161 }; 161 };
162 162
163 template <WebKit::WGC3Denum target> 163 template <blink::WGC3Denum target>
164 class ScopedTextureBinder : ScopedBinder<target> { 164 class ScopedTextureBinder : ScopedBinder<target> {
165 public: 165 public:
166 ScopedTextureBinder(WebKit::WebGraphicsContext3D* context, 166 ScopedTextureBinder(blink::WebGraphicsContext3D* context,
167 WebGLId id) 167 WebGLId id)
168 : ScopedBinder<target>( 168 : ScopedBinder<target>(
169 context, 169 context,
170 id, 170 id,
171 &WebKit::WebGraphicsContext3D::bindTexture) {} 171 &blink::WebGraphicsContext3D::bindTexture) {}
172 }; 172 };
173 173
174 class ScopedFlush { 174 class ScopedFlush {
175 public: 175 public:
176 explicit ScopedFlush(WebKit::WebGraphicsContext3D* context) 176 explicit ScopedFlush(blink::WebGraphicsContext3D* context)
177 : context_(context) { 177 : context_(context) {
178 } 178 }
179 179
180 ~ScopedFlush() { 180 ~ScopedFlush() {
181 context_->flush(); 181 context_->flush();
182 } 182 }
183 183
184 private: 184 private:
185 WebKit::WebGraphicsContext3D* context_; 185 blink::WebGraphicsContext3D* context_;
186 186
187 DISALLOW_COPY_AND_ASSIGN(ScopedFlush); 187 DISALLOW_COPY_AND_ASSIGN(ScopedFlush);
188 }; 188 };
189 189
190 190
191 class ReadbackYUVInterface; 191 class ReadbackYUVInterface;
192 192
193 // Provides higher level operations on top of the WebKit::WebGraphicsContext3D 193 // Provides higher level operations on top of the blink::WebGraphicsContext3D
194 // interfaces. 194 // interfaces.
195 class CONTENT_EXPORT GLHelper { 195 class CONTENT_EXPORT GLHelper {
196 public: 196 public:
197 GLHelper(WebKit::WebGraphicsContext3D* context, 197 GLHelper(blink::WebGraphicsContext3D* context,
198 gpu::ContextSupport* context_support); 198 gpu::ContextSupport* context_support);
199 ~GLHelper(); 199 ~GLHelper();
200 200
201 enum ScalerQuality { 201 enum ScalerQuality {
202 // Bilinear single pass, fastest possible. 202 // Bilinear single pass, fastest possible.
203 SCALER_QUALITY_FAST = 1, 203 SCALER_QUALITY_FAST = 1,
204 204
205 // Bilinear upscale + N * 50% bilinear downscales. 205 // Bilinear upscale + N * 50% bilinear downscales.
206 // This is still fast enough for most purposes and 206 // This is still fast enough for most purposes and
207 // Image quality is nearly as good as the BEST option. 207 // Image quality is nearly as good as the BEST option.
208 SCALER_QUALITY_GOOD = 2, 208 SCALER_QUALITY_GOOD = 2,
209 209
210 // Bicubic upscale + N * 50% bicubic downscales. 210 // Bicubic upscale + N * 50% bicubic downscales.
211 // Produces very good quality scaled images, but it's 211 // Produces very good quality scaled images, but it's
212 // 2-8x slower than the "GOOD" quality, so it's not always 212 // 2-8x slower than the "GOOD" quality, so it's not always
213 // worth it. 213 // worth it.
214 SCALER_QUALITY_BEST = 3, 214 SCALER_QUALITY_BEST = 3,
215 }; 215 };
216 216
217 217
218 // Copies the block of pixels specified with |src_subrect| from |src_texture|, 218 // Copies the block of pixels specified with |src_subrect| from |src_texture|,
219 // scales it to |dst_size|, and writes it into |out|. 219 // scales it to |dst_size|, and writes it into |out|.
220 // |src_size| is the size of |src_texture|. The result is of format GL_BGRA 220 // |src_size| is the size of |src_texture|. The result is of format GL_BGRA
221 // and is potentially flipped vertically to make it a correct image 221 // and is potentially flipped vertically to make it a correct image
222 // representation. |callback| is invoked with the copy result when the copy 222 // representation. |callback| is invoked with the copy result when the copy
223 // operation has completed. 223 // operation has completed.
224 // Note that the src_texture will have the min/mag filter set to GL_LINEAR 224 // Note that the src_texture will have the min/mag filter set to GL_LINEAR
225 // and wrap_s/t set to CLAMP_TO_EDGE in this call. 225 // and wrap_s/t set to CLAMP_TO_EDGE in this call.
226 void CropScaleReadbackAndCleanTexture( 226 void CropScaleReadbackAndCleanTexture(
227 WebKit::WebGLId src_texture, 227 blink::WebGLId src_texture,
228 const gfx::Size& src_size, 228 const gfx::Size& src_size,
229 const gfx::Rect& src_subrect, 229 const gfx::Rect& src_subrect,
230 const gfx::Size& dst_size, 230 const gfx::Size& dst_size,
231 unsigned char* out, 231 unsigned char* out,
232 const base::Callback<void(bool)>& callback); 232 const base::Callback<void(bool)>& callback);
233 233
234 // Copies the block of pixels specified with |src_subrect| from |src_mailbox|, 234 // Copies the block of pixels specified with |src_subrect| from |src_mailbox|,
235 // scales it to |dst_size|, and writes it into |out|. 235 // scales it to |dst_size|, and writes it into |out|.
236 // |src_size| is the size of |src_mailbox|. The result is of format GL_BGRA 236 // |src_size| is the size of |src_mailbox|. The result is of format GL_BGRA
237 // and is potentially flipped vertically to make it a correct image 237 // and is potentially flipped vertically to make it a correct image
238 // representation. |callback| is invoked with the copy result when the copy 238 // representation. |callback| is invoked with the copy result when the copy
239 // operation has completed. 239 // operation has completed.
240 // Note that the texture bound to src_mailbox will have the min/mag filter set 240 // Note that the texture bound to src_mailbox will have the min/mag filter set
241 // to GL_LINEAR and wrap_s/t set to CLAMP_TO_EDGE in this call. src_mailbox is 241 // to GL_LINEAR and wrap_s/t set to CLAMP_TO_EDGE in this call. src_mailbox is
242 // assumed to be GL_TEXTURE_2D. 242 // assumed to be GL_TEXTURE_2D.
243 void CropScaleReadbackAndCleanMailbox( 243 void CropScaleReadbackAndCleanMailbox(
244 const gpu::Mailbox& src_mailbox, 244 const gpu::Mailbox& src_mailbox,
245 uint32 sync_point, 245 uint32 sync_point,
246 const gfx::Size& src_size, 246 const gfx::Size& src_size,
247 const gfx::Rect& src_subrect, 247 const gfx::Rect& src_subrect,
248 const gfx::Size& dst_size, 248 const gfx::Size& dst_size,
249 unsigned char* out, 249 unsigned char* out,
250 const base::Callback<void(bool)>& callback); 250 const base::Callback<void(bool)>& callback);
251 251
252 // Copies the texture data out of |texture| into |out|. |size| is the 252 // Copies the texture data out of |texture| into |out|. |size| is the
253 // size of the texture. No post processing is applied to the pixels. The 253 // size of the texture. No post processing is applied to the pixels. The
254 // texture is assumed to have a format of GL_RGBA with a pixel type of 254 // texture is assumed to have a format of GL_RGBA with a pixel type of
255 // GL_UNSIGNED_BYTE. This is a blocking call that calls glReadPixels on this 255 // GL_UNSIGNED_BYTE. This is a blocking call that calls glReadPixels on this
256 // current context. 256 // current context.
257 void ReadbackTextureSync(WebKit::WebGLId texture, 257 void ReadbackTextureSync(blink::WebGLId texture,
258 const gfx::Rect& src_rect, 258 const gfx::Rect& src_rect,
259 unsigned char* out); 259 unsigned char* out);
260 260
261 // Creates a copy of the specified texture. |size| is the size of the texture. 261 // Creates a copy of the specified texture. |size| is the size of the texture.
262 // Note that the src_texture will have the min/mag filter set to GL_LINEAR 262 // Note that the src_texture will have the min/mag filter set to GL_LINEAR
263 // and wrap_s/t set to CLAMP_TO_EDGE in this call. 263 // and wrap_s/t set to CLAMP_TO_EDGE in this call.
264 WebKit::WebGLId CopyTexture(WebKit::WebGLId texture, 264 blink::WebGLId CopyTexture(blink::WebGLId texture,
265 const gfx::Size& size); 265 const gfx::Size& size);
266 266
267 // Creates a scaled copy of the specified texture. |src_size| is the size of 267 // Creates a scaled copy of the specified texture. |src_size| is the size of
268 // the texture and |dst_size| is the size of the resulting copy. 268 // the texture and |dst_size| is the size of the resulting copy.
269 // Note that the src_texture will have the min/mag filter set to GL_LINEAR 269 // Note that the src_texture will have the min/mag filter set to GL_LINEAR
270 // and wrap_s/t set to CLAMP_TO_EDGE in this call. 270 // and wrap_s/t set to CLAMP_TO_EDGE in this call.
271 WebKit::WebGLId CopyAndScaleTexture( 271 blink::WebGLId CopyAndScaleTexture(
272 WebKit::WebGLId texture, 272 blink::WebGLId texture,
273 const gfx::Size& src_size, 273 const gfx::Size& src_size,
274 const gfx::Size& dst_size, 274 const gfx::Size& dst_size,
275 bool vertically_flip_texture, 275 bool vertically_flip_texture,
276 ScalerQuality quality); 276 ScalerQuality quality);
277 277
278 // Returns the shader compiled from the source. 278 // Returns the shader compiled from the source.
279 WebKit::WebGLId CompileShaderFromSource(const WebKit::WGC3Dchar* source, 279 blink::WebGLId CompileShaderFromSource(const blink::WGC3Dchar* source,
280 WebKit::WGC3Denum type); 280 blink::WGC3Denum type);
281 281
282 // Copies all pixels from |previous_texture| into |texture| that are 282 // Copies all pixels from |previous_texture| into |texture| that are
283 // inside the region covered by |old_damage| but not part of |new_damage|. 283 // inside the region covered by |old_damage| but not part of |new_damage|.
284 void CopySubBufferDamage(WebKit::WebGLId texture, 284 void CopySubBufferDamage(blink::WebGLId texture,
285 WebKit::WebGLId previous_texture, 285 blink::WebGLId previous_texture,
286 const SkRegion& new_damage, 286 const SkRegion& new_damage,
287 const SkRegion& old_damage); 287 const SkRegion& old_damage);
288 288
289 // Simply creates a texture. 289 // Simply creates a texture.
290 WebKit::WebGLId CreateTexture(); 290 blink::WebGLId CreateTexture();
291 291
292 // Creates a texture and consumes a mailbox into it. Returns 0 on failure. 292 // Creates a texture and consumes a mailbox into it. Returns 0 on failure.
293 // Note the mailbox is assumed to be GL_TEXTURE_2D. 293 // Note the mailbox is assumed to be GL_TEXTURE_2D.
294 WebKit::WebGLId ConsumeMailboxToTexture(const gpu::Mailbox& mailbox, 294 blink::WebGLId ConsumeMailboxToTexture(const gpu::Mailbox& mailbox,
295 uint32 sync_point); 295 uint32 sync_point);
296 296
297 // Resizes the texture's size to |size|. 297 // Resizes the texture's size to |size|.
298 void ResizeTexture(WebKit::WebGLId texture, const gfx::Size& size); 298 void ResizeTexture(blink::WebGLId texture, const gfx::Size& size);
299 299
300 // Copies the framebuffer data given in |rect| to |texture|. 300 // Copies the framebuffer data given in |rect| to |texture|.
301 void CopyTextureSubImage(WebKit::WebGLId texture, const gfx::Rect& rect); 301 void CopyTextureSubImage(blink::WebGLId texture, const gfx::Rect& rect);
302 302
303 // Copies the all framebuffer data to |texture|. |size| specifies the 303 // Copies the all framebuffer data to |texture|. |size| specifies the
304 // size of the framebuffer. 304 // size of the framebuffer.
305 void CopyTextureFullImage(WebKit::WebGLId texture, const gfx::Size& size); 305 void CopyTextureFullImage(blink::WebGLId texture, const gfx::Size& size);
306 306
307 // A scaler will cache all intermediate textures and programs 307 // A scaler will cache all intermediate textures and programs
308 // needed to scale from a specified size to a destination size. 308 // needed to scale from a specified size to a destination size.
309 // If the source or destination sizes changes, you must create 309 // If the source or destination sizes changes, you must create
310 // a new scaler. 310 // a new scaler.
311 class CONTENT_EXPORT ScalerInterface { 311 class CONTENT_EXPORT ScalerInterface {
312 public: 312 public:
313 ScalerInterface() {} 313 ScalerInterface() {}
314 virtual ~ScalerInterface() {} 314 virtual ~ScalerInterface() {}
315 315
316 // Note that the src_texture will have the min/mag filter set to GL_LINEAR 316 // Note that the src_texture will have the min/mag filter set to GL_LINEAR
317 // and wrap_s/t set to CLAMP_TO_EDGE in this call. 317 // and wrap_s/t set to CLAMP_TO_EDGE in this call.
318 virtual void Scale(WebKit::WebGLId source_texture, 318 virtual void Scale(blink::WebGLId source_texture,
319 WebKit::WebGLId dest_texture) = 0; 319 blink::WebGLId dest_texture) = 0;
320 virtual const gfx::Size& SrcSize() = 0; 320 virtual const gfx::Size& SrcSize() = 0;
321 virtual const gfx::Rect& SrcSubrect() = 0; 321 virtual const gfx::Rect& SrcSubrect() = 0;
322 virtual const gfx::Size& DstSize() = 0; 322 virtual const gfx::Size& DstSize() = 0;
323 }; 323 };
324 324
325 // Note that the quality may be adjusted down if texture 325 // Note that the quality may be adjusted down if texture
326 // allocations fail or hardware doesn't support the requtested 326 // allocations fail or hardware doesn't support the requtested
327 // quality. Note that ScalerQuality enum is arranged in 327 // quality. Note that ScalerQuality enum is arranged in
328 // numerical order for simplicity. 328 // numerical order for simplicity.
329 ScalerInterface* CreateScaler(ScalerQuality quality, 329 ScalerInterface* CreateScaler(ScalerQuality quality,
(...skipping 15 matching lines...) Expand all
345 ScalerQuality quality, 345 ScalerQuality quality,
346 const gfx::Size& src_size, 346 const gfx::Size& src_size,
347 const gfx::Rect& src_subrect, 347 const gfx::Rect& src_subrect,
348 const gfx::Size& dst_size, 348 const gfx::Size& dst_size,
349 const gfx::Rect& dst_subrect, 349 const gfx::Rect& dst_subrect,
350 bool flip_vertically, 350 bool flip_vertically,
351 bool use_mrt); 351 bool use_mrt);
352 352
353 // Returns the maximum number of draw buffers available, 353 // Returns the maximum number of draw buffers available,
354 // 0 if GL_EXT_draw_buffers is not available. 354 // 0 if GL_EXT_draw_buffers is not available.
355 WebKit::WGC3Dint MaxDrawBuffers(); 355 blink::WGC3Dint MaxDrawBuffers();
356 356
357 protected: 357 protected:
358 class CopyTextureToImpl; 358 class CopyTextureToImpl;
359 359
360 // Creates |copy_texture_to_impl_| if NULL. 360 // Creates |copy_texture_to_impl_| if NULL.
361 void InitCopyTextToImpl(); 361 void InitCopyTextToImpl();
362 // Creates |scaler_impl_| if NULL. 362 // Creates |scaler_impl_| if NULL.
363 void InitScalerImpl(); 363 void InitScalerImpl();
364 364
365 WebKit::WebGraphicsContext3D* context_; 365 blink::WebGraphicsContext3D* context_;
366 gpu::ContextSupport* context_support_; 366 gpu::ContextSupport* context_support_;
367 scoped_ptr<CopyTextureToImpl> copy_texture_to_impl_; 367 scoped_ptr<CopyTextureToImpl> copy_texture_to_impl_;
368 scoped_ptr<GLHelperScaling> scaler_impl_; 368 scoped_ptr<GLHelperScaling> scaler_impl_;
369 369
370 DISALLOW_COPY_AND_ASSIGN(GLHelper); 370 DISALLOW_COPY_AND_ASSIGN(GLHelper);
371 }; 371 };
372 372
373 // Similar to a ScalerInterface, a yuv readback pipeline will 373 // Similar to a ScalerInterface, a yuv readback pipeline will
374 // cache a scaler and all intermediate textures and frame buffers 374 // cache a scaler and all intermediate textures and frame buffers
375 // needed to scale, crop, letterbox and read back a texture from 375 // needed to scale, crop, letterbox and read back a texture from
(...skipping 11 matching lines...) Expand all
387 const gpu::Mailbox& mailbox, 387 const gpu::Mailbox& mailbox,
388 uint32 sync_point, 388 uint32 sync_point,
389 const scoped_refptr<media::VideoFrame>& target, 389 const scoped_refptr<media::VideoFrame>& target,
390 const base::Callback<void(bool)>& callback) = 0; 390 const base::Callback<void(bool)>& callback) = 0;
391 virtual GLHelper::ScalerInterface* scaler() = 0; 391 virtual GLHelper::ScalerInterface* scaler() = 0;
392 }; 392 };
393 393
394 } // namespace content 394 } // namespace content
395 395
396 #endif // CONTENT_COMMON_GPU_CLIENT_GL_HELPER_H_ 396 #endif // CONTENT_COMMON_GPU_CLIENT_GL_HELPER_H_
OLDNEW
« no previous file with comments | « content/common/gpu/client/context_provider_command_buffer_browsertest.cc ('k') | content/common/gpu/client/gl_helper.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698