blob: 2ccd3014f8f8588086e849ca2f7fa0cacf1e5f83 [file] [log] [blame]
epoger@google.comec3ed6a2011-07-28 14:26:00 +00001
reed@google.comac10a2d2010-12-22 21:39:39 +00002/*
epoger@google.comec3ed6a2011-07-28 14:26:00 +00003 * Copyright 2011 Google Inc.
4 *
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
reed@google.comac10a2d2010-12-22 21:39:39 +00007 */
8
reed@google.comac10a2d2010-12-22 21:39:39 +00009#ifndef GrTexture_DEFINED
10#define GrTexture_DEFINED
11
robertphillips@google.com7d501ab2012-06-21 21:09:06 +000012#include "GrSurface.h"
robertphillips@google.com46a86002012-08-08 10:42:44 +000013#include "GrCacheID.h"
reed@google.comac10a2d2010-12-22 21:39:39 +000014
bsalomon@google.comaa5b6732011-07-29 15:13:20 +000015class GrRenderTarget;
robertphillips@google.coma1e57952012-06-04 20:05:28 +000016class GrResourceKey;
bsalomon@google.comb8670992012-07-25 21:27:09 +000017class GrTextureParams;
reed@google.comac10a2d2010-12-22 21:39:39 +000018
robertphillips@google.com75b3c962012-06-07 12:08:45 +000019/*
20 * All uncached textures should have this value as their fClientCacheID
21 */
22static const uint64_t kUncached_CacheID = 0xAAAAAAAA;
23
24/*
25 * Scratch textures should all have this value as their fClientCacheID
26 */
27static const uint64_t kScratch_CacheID = 0xBBBBBBBB;
28
29
robertphillips@google.com7d501ab2012-06-21 21:09:06 +000030class GrTexture : public GrSurface {
bsalomon@google.com8fe72472011-03-30 21:26:44 +000031
reed@google.comac10a2d2010-12-22 21:39:39 +000032public:
robertphillips@google.com4d73ac22012-06-13 18:54:08 +000033 SK_DECLARE_INST_COUNT(GrTexture)
robertphillips@google.com46a86002012-08-08 10:42:44 +000034 GR_DECLARE_RESOURCE_CACHE_TYPE()
robertphillips@google.com4d73ac22012-06-13 18:54:08 +000035
robertphillips@google.com7d501ab2012-06-21 21:09:06 +000036 // from GrResource
reed@google.comac10a2d2010-12-22 21:39:39 +000037 /**
robertphillips@google.com15c0fea2012-06-22 12:41:43 +000038 * Informational texture flags
39 */
40 enum FlagBits {
41 kFirstBit = (kLastPublic_GrTextureFlagBit << 1),
42
43 /**
44 * This texture should be returned to the texture cache when
45 * it is no longer reffed
46 */
47 kReturnToCache_FlagBit = kFirstBit,
48 };
49
50 void setFlag(GrTextureFlags flags) {
51 fDesc.fFlags = fDesc.fFlags | flags;
52 }
53 void resetFlag(GrTextureFlags flags) {
54 fDesc.fFlags = fDesc.fFlags & ~flags;
55 }
56 bool isSetFlag(GrTextureFlags flags) const {
57 return 0 != (fDesc.fFlags & flags);
58 }
59
60 /**
bsalomon@google.comc6cf7232011-02-17 16:43:10 +000061 * Approximate number of bytes used by the texture
reed@google.comac10a2d2010-12-22 21:39:39 +000062 */
robertphillips@google.com7d501ab2012-06-21 21:09:06 +000063 virtual size_t sizeInBytes() const SK_OVERRIDE {
robertphillips@google.com32716282012-06-04 12:48:45 +000064 return (size_t) fDesc.fWidth *
65 fDesc.fHeight *
66 GrBytesPerPixel(fDesc.fConfig);
reed@google.comac10a2d2010-12-22 21:39:39 +000067 }
68
robertphillips@google.com7d501ab2012-06-21 21:09:06 +000069 // from GrSurface
reed@google.comac10a2d2010-12-22 21:39:39 +000070 /**
bsalomon@google.com6f379512011-11-16 20:36:03 +000071 * Read a rectangle of pixels from the texture.
bsalomon@google.com669fdc42011-04-05 17:08:27 +000072 * @param left left edge of the rectangle to read (inclusive)
73 * @param top top edge of the rectangle to read (inclusive)
74 * @param width width of rectangle to read in pixels.
75 * @param height height of rectangle to read in pixels.
76 * @param config the pixel config of the destination buffer
77 * @param buffer memory to read the rectangle into.
bsalomon@google.com6f379512011-11-16 20:36:03 +000078 * @param rowBytes number of bytes bewtween consecutive rows. Zero
79 * means rows are tightly packed.
bsalomon@google.com669fdc42011-04-05 17:08:27 +000080 *
81 * @return true if the read succeeded, false if not. The read can fail
82 * because of a unsupported pixel config.
83 */
robertphillips@google.com7d501ab2012-06-21 21:09:06 +000084 virtual bool readPixels(int left, int top, int width, int height,
85 GrPixelConfig config, void* buffer,
86 size_t rowBytes) SK_OVERRIDE;
bsalomon@google.com6f379512011-11-16 20:36:03 +000087
88 /**
89 * Writes a rectangle of pixels to the texture.
90 * @param left left edge of the rectangle to write (inclusive)
91 * @param top top edge of the rectangle to write (inclusive)
92 * @param width width of rectangle to write in pixels.
93 * @param height height of rectangle to write in pixels.
94 * @param config the pixel config of the source buffer
95 * @param buffer memory to read pixels from
robertphillips@google.com09042b82012-04-06 20:01:46 +000096 * @param rowBytes number of bytes between consecutive rows. Zero
bsalomon@google.com6f379512011-11-16 20:36:03 +000097 * means rows are tightly packed.
98 */
robertphillips@google.com7d501ab2012-06-21 21:09:06 +000099 virtual void writePixels(int left, int top, int width, int height,
100 GrPixelConfig config, const void* buffer,
101 size_t rowBytes) SK_OVERRIDE;
102
103 /**
104 * @return this texture
105 */
106 virtual GrTexture* asTexture() SK_OVERRIDE { return this; }
107 virtual const GrTexture* asTexture() const SK_OVERRIDE { return this; }
bsalomon@google.com669fdc42011-04-05 17:08:27 +0000108
109 /**
reed@google.comac10a2d2010-12-22 21:39:39 +0000110 * Retrieves the render target underlying this texture that can be passed to
111 * GrGpu::setRenderTarget().
112 *
bsalomon@google.com6dcf4992011-04-05 21:16:14 +0000113 * @return handle to render target or NULL if the texture is not a
reed@google.comac10a2d2010-12-22 21:39:39 +0000114 * render target
115 */
robertphillips@google.com7d501ab2012-06-21 21:09:06 +0000116 virtual GrRenderTarget* asRenderTarget() SK_OVERRIDE {
117 return fRenderTarget;
118 }
119 virtual const GrRenderTarget* asRenderTarget() const SK_OVERRIDE {
120 return fRenderTarget;
121 }
122
123 // GrTexture
124 /**
125 * Convert from texels to normalized texture coords for POT textures
126 * only.
127 */
128 GrFixed normalizeFixedX(GrFixed x) const {
129 GrAssert(GrIsPow2(fDesc.fWidth));
130 return x >> fShiftFixedX;
131 }
132 GrFixed normalizeFixedY(GrFixed y) const {
133 GrAssert(GrIsPow2(fDesc.fHeight));
134 return y >> fShiftFixedY;
135 }
reed@google.comac10a2d2010-12-22 21:39:39 +0000136
137 /**
bsalomon@google.com1da07462011-03-10 14:51:57 +0000138 * Removes the reference on the associated GrRenderTarget held by this
bsalomon@google.com8fe72472011-03-30 21:26:44 +0000139 * texture. Afterwards asRenderTarget() will return NULL. The
bsalomon@google.com1da07462011-03-10 14:51:57 +0000140 * GrRenderTarget survives the release if another ref is held on it.
reed@google.comac10a2d2010-12-22 21:39:39 +0000141 */
bsalomon@google.comaa5b6732011-07-29 15:13:20 +0000142 void releaseRenderTarget();
reed@google.comac10a2d2010-12-22 21:39:39 +0000143
144 /**
145 * Return the native ID or handle to the texture, depending on the
146 * platform. e.g. on opengl, return the texture ID.
147 */
bsalomon@google.comcee661a2011-07-26 12:32:36 +0000148 virtual intptr_t getTextureHandle() const = 0;
reed@google.comac10a2d2010-12-22 21:39:39 +0000149
junov@chromium.org957ebdd2012-06-12 13:58:36 +0000150 /**
151 * Call this when the state of the native API texture object is
152 * altered directly, without being tracked by skia.
153 */
154 virtual void invalidateCachedState() = 0;
155
reed@google.comac10a2d2010-12-22 21:39:39 +0000156#if GR_DEBUG
157 void validate() const {
158 this->INHERITED::validate();
robertphillips@google.com32716282012-06-04 12:48:45 +0000159
160 this->validateDesc();
reed@google.comac10a2d2010-12-22 21:39:39 +0000161 }
162#else
163 void validate() const {}
164#endif
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000165
robertphillips@google.coma1e57952012-06-04 20:05:28 +0000166 static GrResourceKey ComputeKey(const GrGpu* gpu,
bsalomon@google.comb8670992012-07-25 21:27:09 +0000167 const GrTextureParams* sampler,
robertphillips@google.coma1e57952012-06-04 20:05:28 +0000168 const GrTextureDesc& desc,
169 bool scratch);
170
171 static bool NeedsResizing(const GrResourceKey& key);
172 static bool IsScratchTexture(const GrResourceKey& key);
173 static bool NeedsFiltering(const GrResourceKey& key);
174
bsalomon@google.com6dcf4992011-04-05 21:16:14 +0000175protected:
176 GrRenderTarget* fRenderTarget; // texture refs its rt representation
177 // base class cons sets to NULL
178 // subclass cons can create and set
179
robertphillips@google.com32716282012-06-04 12:48:45 +0000180 GrTexture(GrGpu* gpu, const GrTextureDesc& desc)
robertphillips@google.com7d501ab2012-06-21 21:09:06 +0000181 : INHERITED(gpu, desc)
182 , fRenderTarget(NULL) {
robertphillips@google.com32716282012-06-04 12:48:45 +0000183
bsalomon@google.com6dcf4992011-04-05 21:16:14 +0000184 // only make sense if alloc size is pow2
robertphillips@google.com32716282012-06-04 12:48:45 +0000185 fShiftFixedX = 31 - Gr_clz(fDesc.fWidth);
186 fShiftFixedY = 31 - Gr_clz(fDesc.fHeight);
bsalomon@google.com6dcf4992011-04-05 21:16:14 +0000187 }
bsalomon@google.comcee661a2011-07-26 12:32:36 +0000188
bsalomon@google.com6dcf4992011-04-05 21:16:14 +0000189 // GrResource overrides
robertphillips@google.com15c0fea2012-06-22 12:41:43 +0000190 virtual void onRelease() SK_OVERRIDE;
191 virtual void onAbandon() SK_OVERRIDE;
bsalomon@google.com6dcf4992011-04-05 21:16:14 +0000192
robertphillips@google.com32716282012-06-04 12:48:45 +0000193 void validateDesc() const;
194
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000195private:
reed@google.comac10a2d2010-12-22 21:39:39 +0000196 // these two shift a fixed-point value into normalized coordinates
197 // for this texture if the texture is power of two sized.
robertphillips@google.com32716282012-06-04 12:48:45 +0000198 int fShiftFixedX;
199 int fShiftFixedY;
reed@google.comac10a2d2010-12-22 21:39:39 +0000200
robertphillips@google.com15c0fea2012-06-22 12:41:43 +0000201 virtual void internal_dispose() const SK_OVERRIDE;
202
robertphillips@google.com7d501ab2012-06-21 21:09:06 +0000203 typedef GrSurface INHERITED;
reed@google.comac10a2d2010-12-22 21:39:39 +0000204};
205
206#endif
207