 Chromium Code Reviews
 Chromium Code Reviews Issue 695813003:
  Add class GrGLTextureRenderTarget for GL texture/rendertarget objects  (Closed) 
  Base URL: https://skia.googlesource.com/skia.git@master
    
  
    Issue 695813003:
  Add class GrGLTextureRenderTarget for GL texture/rendertarget objects  (Closed) 
  Base URL: https://skia.googlesource.com/skia.git@master| Index: src/gpu/gl/GrGLRenderTarget.h | 
| diff --git a/src/gpu/gl/GrGLRenderTarget.h b/src/gpu/gl/GrGLRenderTarget.h | 
| index 116862bd0b388d48a33bbb6fe57c6f0a56741aba..cce9d0efa3de3ecc0e1c9759b874d81f214a4cd4 100644 | 
| --- a/src/gpu/gl/GrGLRenderTarget.h | 
| +++ b/src/gpu/gl/GrGLRenderTarget.h | 
| @@ -14,11 +14,8 @@ | 
| #include "SkScalar.h" | 
| class GrGpuGL; | 
| -class GrGLTexture; | 
| -class GrGLTexID; | 
| class GrGLRenderTarget : public GrRenderTarget { | 
| - | 
| public: | 
| // set fTexFBOID to this value to indicate that it is multisampled but | 
| // Gr doesn't know how to resolve it. | 
| @@ -31,12 +28,7 @@ public: | 
| bool fIsWrapped; | 
| }; | 
| - // creates a GrGLRenderTarget associated with a texture | 
| - GrGLRenderTarget(GrGpuGL*, const IDDesc&, const GrGLIRect& viewport, | 
| - GrGLTexID*, GrGLTexture*); | 
| - | 
| - // creates an independent GrGLRenderTarget | 
| - GrGLRenderTarget(GrGpuGL*, const GrSurfaceDesc&, const IDDesc&, const GrGLIRect& viewport); | 
| + GrGLRenderTarget(GrGpuGL*, const GrSurfaceDesc&, const IDDesc&); | 
| virtual ~GrGLRenderTarget() { this->release(); } | 
| @@ -52,14 +44,9 @@ public: | 
| GrGLuint textureFBOID() const { return fTexFBOID; } | 
| // override of GrRenderTarget | 
| - virtual GrBackendObject getRenderTargetHandle() const { | 
| - return this->renderFBOID(); | 
| - } | 
| - virtual GrBackendObject getRenderTargetResolvedHandle() const { | 
| - return this->textureFBOID(); | 
| - } | 
| + virtual GrBackendObject getRenderTargetHandle() const { return this->renderFBOID(); } | 
| + virtual GrBackendObject getRenderTargetResolvedHandle() const { return this->textureFBOID(); } | 
| virtual ResolveType getResolveType() const { | 
| - | 
| if (!this->isMultisampled() || | 
| fRTFBOID == fTexFBOID) { | 
| // catches FBO 0 and non MSAA case | 
| @@ -71,26 +58,32 @@ public: | 
| } | 
| } | 
| 
robertphillips
2014/11/03 13:58:54
SK_OVERRIDE ?
 
bsalomon
2014/11/03 15:20:14
Done.
 | 
| + virtual size_t gpuMemorySize() const; | 
| + | 
| protected: | 
| - // override of GrResource | 
| + // The public constructor registers this object with the cache. However, only the most derived | 
| + // class should register with the cache. This constructor does not do the registration and | 
| + // rather moves that burden onto the derived class. | 
| + enum Derived { kDerived }; | 
| + GrGLRenderTarget(GrGpuGL* gpu, const GrSurfaceDesc&, const IDDesc&, Derived); | 
| + | 
| virtual void onAbandon() SK_OVERRIDE; | 
| virtual void onRelease() SK_OVERRIDE; | 
| private: | 
| GrGLuint fRTFBOID; | 
| GrGLuint fTexFBOID; | 
| - | 
| GrGLuint fMSColorRenderbufferID; | 
| // when we switch to this render target we want to set the viewport to | 
| - // only render to to content area (as opposed to the whole allocation) and | 
| + // only render to content area (as opposed to the whole allocation) and | 
| // we want the rendering to be at top left (GL has origin in bottom left) | 
| GrGLIRect fViewport; | 
| - // non-NULL if this RT was created by Gr with an associated GrGLTexture. | 
| - SkAutoTUnref<GrGLTexID> fTexIDObj; | 
| - | 
| - void init(const GrSurfaceDesc&, const IDDesc&, const GrGLIRect& viewport, GrGLTexID*); | 
| + // gpuMemorySize() needs to know what how many color values are owned per pixel. However, | 
| + // abandon and release zero out the IDs and the cache needs to know the size even after those | 
| + // actions. | 
| + uint8_t fColorValuesPerPixel; | 
| typedef GrRenderTarget INHERITED; | 
| }; |