diff options
author | Derek Sollenberger <djsollen@google.com> | 2012-03-06 09:06:43 -0500 |
---|---|---|
committer | Derek Sollenberger <derek@android.com> | 2012-03-06 09:44:47 -0500 |
commit | 4f1dae40e24d57d647db01443b8bf2410514b8b5 (patch) | |
tree | 594df3f3fc6c1d90a76691a75763ae1beacfdf98 /src/gpu/gl/GrGLTexture.cpp | |
parent | 1cab2921ab279367f8206cdadc9259d12e603548 (diff) | |
download | external_skia-4f1dae40e24d57d647db01443b8bf2410514b8b5.zip external_skia-4f1dae40e24d57d647db01443b8bf2410514b8b5.tar.gz external_skia-4f1dae40e24d57d647db01443b8bf2410514b8b5.tar.bz2 |
Skia Merge (revision 3312)
This CL also includes changes made to Android's copy of
Skia in their J release branch.
Change-Id: Ib2baecf48004951a3ad4a1574cdc38790c814cbc
Diffstat (limited to 'src/gpu/gl/GrGLTexture.cpp')
-rw-r--r-- | src/gpu/gl/GrGLTexture.cpp | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/src/gpu/gl/GrGLTexture.cpp b/src/gpu/gl/GrGLTexture.cpp new file mode 100644 index 0000000..0a38da3 --- /dev/null +++ b/src/gpu/gl/GrGLTexture.cpp @@ -0,0 +1,90 @@ + +/* + * Copyright 2011 Google Inc. + * + * Use of this source code is governed by a BSD-style license that can be + * found in the LICENSE file. + */ + + +#include "GrGLTexture.h" + +#include "GrGpuGL.h" + +#define GPUGL static_cast<GrGpuGL*>(getGpu()) + +#define GL_CALL(X) GR_GL_CALL(GPUGL->glInterface(), X) + +const GrGLenum* GrGLTexture::WrapMode2GLWrap() { + static const GrGLenum repeatModes[] = { + GR_GL_CLAMP_TO_EDGE, + GR_GL_REPEAT, + GR_GL_MIRRORED_REPEAT + }; + return repeatModes; +}; + +void GrGLTexture::init(GrGpuGL* gpu, + const Desc& textureDesc, + const GrGLRenderTarget::Desc* rtDesc) { + + GrAssert(0 != textureDesc.fTextureID); + + fTexParams.invalidate(); + fTexParamsTimestamp = GrGpu::kExpiredTimestamp; + fTexIDObj = new GrGLTexID(GPUGL->glInterface(), + textureDesc.fTextureID, + textureDesc.fOwnsID); + fOrientation = textureDesc.fOrientation; + + if (NULL != rtDesc) { + // we render to the top left + GrGLIRect vp; + vp.fLeft = 0; + vp.fWidth = textureDesc.fWidth; + vp.fBottom = 0; + vp.fHeight = textureDesc.fHeight; + + fRenderTarget = new GrGLRenderTarget(gpu, *rtDesc, vp, fTexIDObj, this); + } +} + +GrGLTexture::GrGLTexture(GrGpuGL* gpu, + const Desc& textureDesc) + : INHERITED(gpu, + textureDesc.fWidth, + textureDesc.fHeight, + textureDesc.fConfig) { + this->init(gpu, textureDesc, NULL); +} + +GrGLTexture::GrGLTexture(GrGpuGL* gpu, + const Desc& textureDesc, + const GrGLRenderTarget::Desc& rtDesc) + : INHERITED(gpu, + textureDesc.fWidth, + textureDesc.fHeight, + textureDesc.fConfig) { + this->init(gpu, textureDesc, &rtDesc); +} + +void GrGLTexture::onRelease() { + INHERITED::onRelease(); + GPUGL->notifyTextureDelete(this); + if (NULL != fTexIDObj) { + fTexIDObj->unref(); + fTexIDObj = NULL; + } +} + +void GrGLTexture::onAbandon() { + INHERITED::onAbandon(); + if (NULL != fTexIDObj) { + fTexIDObj->abandon(); + } +} + +intptr_t GrGLTexture::getTextureHandle() const { + return fTexIDObj->id(); +} + |