| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2012 Google Inc. | 2 * Copyright 2012 Google Inc. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
| 5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
| 6 */ | 6 */ |
| 7 | 7 |
| 8 #include "GrCaps.h" | 8 #include "GrCaps.h" |
| 9 #include "GrContext.h" | 9 #include "GrContext.h" |
| 10 #include "GrDrawContext.h" | 10 #include "GrDrawContext.h" |
| 11 #include "GrImageIDTextureAdjuster.h" | 11 #include "GrImageIDTextureAdjuster.h" |
| 12 #include "effects/GrYUVEffect.h" | 12 #include "effects/GrYUVEffect.h" |
| 13 #include "SkCanvas.h" | 13 #include "SkCanvas.h" |
| 14 #include "SkBitmapCache.h" | 14 #include "SkBitmapCache.h" |
| 15 #include "SkGpuDevice.h" | 15 #include "SkGpuDevice.h" |
| 16 #include "SkGrPixelRef.h" | 16 #include "SkGrPixelRef.h" |
| 17 #include "SkGrPriv.h" | 17 #include "SkGrPriv.h" |
| 18 #include "SkImageFilter.h" | 18 #include "SkImageFilter.h" |
| 19 #include "SkImage_Gpu.h" | 19 #include "SkImage_Gpu.h" |
| 20 #include "SkPixelRef.h" | 20 #include "SkPixelRef.h" |
| 21 | 21 |
| 22 SkImage_Gpu::SkImage_Gpu(int w, int h, uint32_t uniqueID, SkAlphaType at, GrText
ure* tex, | 22 SkImage_Gpu::SkImage_Gpu(int w, int h, uint32_t uniqueID, SkAlphaType at, GrText
ure* tex, |
| 23 SkSurface::Budgeted budgeted) | 23 SkBudgeted budgeted) |
| 24 : INHERITED(w, h, uniqueID) | 24 : INHERITED(w, h, uniqueID) |
| 25 , fTexture(SkRef(tex)) | 25 , fTexture(SkRef(tex)) |
| 26 , fAlphaType(at) | 26 , fAlphaType(at) |
| 27 , fBudgeted(budgeted) | 27 , fBudgeted(budgeted) |
| 28 , fAddedRasterVersionToCache(false) | 28 , fAddedRasterVersionToCache(false) |
| 29 { | 29 { |
| 30 SkASSERT(tex->width() == w); | 30 SkASSERT(tex->width() == w); |
| 31 SkASSERT(tex->height() == h); | 31 SkASSERT(tex->height() == h); |
| 32 } | 32 } |
| 33 | 33 |
| (...skipping 99 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 133 } | 133 } |
| 134 return true; | 134 return true; |
| 135 } | 135 } |
| 136 | 136 |
| 137 SkImage* SkImage_Gpu::onNewSubset(const SkIRect& subset) const { | 137 SkImage* SkImage_Gpu::onNewSubset(const SkIRect& subset) const { |
| 138 GrContext* ctx = fTexture->getContext(); | 138 GrContext* ctx = fTexture->getContext(); |
| 139 GrSurfaceDesc desc = fTexture->desc(); | 139 GrSurfaceDesc desc = fTexture->desc(); |
| 140 desc.fWidth = subset.width(); | 140 desc.fWidth = subset.width(); |
| 141 desc.fHeight = subset.height(); | 141 desc.fHeight = subset.height(); |
| 142 | 142 |
| 143 GrTexture* subTx = ctx->textureProvider()->createTexture(desc, | 143 GrTexture* subTx = ctx->textureProvider()->createTexture(desc, fBudgeted); |
| 144 SkSurface::kYes_Bud
geted == fBudgeted); | |
| 145 if (!subTx) { | 144 if (!subTx) { |
| 146 return nullptr; | 145 return nullptr; |
| 147 } | 146 } |
| 148 ctx->copySurface(subTx, fTexture, subset, SkIPoint::Make(0, 0)); | 147 ctx->copySurface(subTx, fTexture, subset, SkIPoint::Make(0, 0)); |
| 149 return new SkImage_Gpu(desc.fWidth, desc.fHeight, kNeedNewImageUniqueID, fAl
phaType, subTx, | 148 return new SkImage_Gpu(desc.fWidth, desc.fHeight, kNeedNewImageUniqueID, fAl
phaType, subTx, |
| 150 fBudgeted); | 149 fBudgeted); |
| 151 } | 150 } |
| 152 | 151 |
| 153 ////////////////////////////////////////////////////////////////////////////////
/////////////////// | 152 ////////////////////////////////////////////////////////////////////////////////
/////////////////// |
| 154 | 153 |
| 155 static SkImage* new_wrapped_texture_common(GrContext* ctx, const GrBackendTextur
eDesc& desc, | 154 static SkImage* new_wrapped_texture_common(GrContext* ctx, const GrBackendTextur
eDesc& desc, |
| 156 SkAlphaType at, GrWrapOwnership owner
ship, | 155 SkAlphaType at, GrWrapOwnership owner
ship, |
| 157 SkImage::TextureReleaseProc releasePr
oc, | 156 SkImage::TextureReleaseProc releasePr
oc, |
| 158 SkImage::ReleaseContext releaseCtx) { | 157 SkImage::ReleaseContext releaseCtx) { |
| 159 if (desc.fWidth <= 0 || desc.fHeight <= 0) { | 158 if (desc.fWidth <= 0 || desc.fHeight <= 0) { |
| 160 return nullptr; | 159 return nullptr; |
| 161 } | 160 } |
| 162 SkAutoTUnref<GrTexture> tex(ctx->textureProvider()->wrapBackendTexture(desc,
ownership)); | 161 SkAutoTUnref<GrTexture> tex(ctx->textureProvider()->wrapBackendTexture(desc,
ownership)); |
| 163 if (!tex) { | 162 if (!tex) { |
| 164 return nullptr; | 163 return nullptr; |
| 165 } | 164 } |
| 166 if (releaseProc) { | 165 if (releaseProc) { |
| 167 tex->setRelease(releaseProc, releaseCtx); | 166 tex->setRelease(releaseProc, releaseCtx); |
| 168 } | 167 } |
| 169 | 168 |
| 170 const SkSurface::Budgeted budgeted = SkSurface::kNo_Budgeted; | 169 const SkBudgeted budgeted = SkBudgeted::kNo; |
| 171 return new SkImage_Gpu(desc.fWidth, desc.fHeight, kNeedNewImageUniqueID, at,
tex, budgeted); | 170 return new SkImage_Gpu(desc.fWidth, desc.fHeight, kNeedNewImageUniqueID, at,
tex, budgeted); |
| 172 } | 171 } |
| 173 | 172 |
| 174 SkImage* SkImage::NewFromTexture(GrContext* ctx, const GrBackendTextureDesc& des
c, SkAlphaType at, | 173 SkImage* SkImage::NewFromTexture(GrContext* ctx, const GrBackendTextureDesc& des
c, SkAlphaType at, |
| 175 TextureReleaseProc releaseP, ReleaseContext rel
easeC) { | 174 TextureReleaseProc releaseP, ReleaseContext rel
easeC) { |
| 176 return new_wrapped_texture_common(ctx, desc, at, kBorrow_GrWrapOwnership, re
leaseP, releaseC); | 175 return new_wrapped_texture_common(ctx, desc, at, kBorrow_GrWrapOwnership, re
leaseP, releaseC); |
| 177 } | 176 } |
| 178 | 177 |
| 179 SkImage* SkImage::NewFromAdoptedTexture(GrContext* ctx, const GrBackendTextureDe
sc& desc, | 178 SkImage* SkImage::NewFromAdoptedTexture(GrContext* ctx, const GrBackendTextureDe
sc& desc, |
| 180 SkAlphaType at) { | 179 SkAlphaType at) { |
| 181 return new_wrapped_texture_common(ctx, desc, at, kAdopt_GrWrapOwnership, nul
lptr, nullptr); | 180 return new_wrapped_texture_common(ctx, desc, at, kAdopt_GrWrapOwnership, nul
lptr, nullptr); |
| 182 } | 181 } |
| 183 | 182 |
| 184 SkImage* SkImage::NewFromTextureCopy(GrContext* ctx, const GrBackendTextureDesc&
desc, | 183 SkImage* SkImage::NewFromTextureCopy(GrContext* ctx, const GrBackendTextureDesc&
desc, |
| 185 SkAlphaType at) { | 184 SkAlphaType at) { |
| 186 if (desc.fWidth <= 0 || desc.fHeight <= 0) { | 185 if (desc.fWidth <= 0 || desc.fHeight <= 0) { |
| 187 return nullptr; | 186 return nullptr; |
| 188 } | 187 } |
| 189 | 188 |
| 190 SkAutoTUnref<GrTexture> src(ctx->textureProvider()->wrapBackendTexture( | 189 SkAutoTUnref<GrTexture> src(ctx->textureProvider()->wrapBackendTexture( |
| 191 desc, kBorrow_GrWrapOwnership)); | 190 desc, kBorrow_GrWrapOwnership)); |
| 192 if (!src) { | 191 if (!src) { |
| 193 return nullptr; | 192 return nullptr; |
| 194 } | 193 } |
| 195 | 194 |
| 196 const bool isBudgeted = true; | 195 SkAutoTUnref<GrTexture> dst(GrDeepCopyTexture(src, SkBudgeted::kYes)); |
| 197 SkAutoTUnref<GrTexture> dst(GrDeepCopyTexture(src, isBudgeted)); | |
| 198 if (!dst) { | 196 if (!dst) { |
| 199 return nullptr; | 197 return nullptr; |
| 200 } | 198 } |
| 201 | 199 |
| 202 const SkSurface::Budgeted budgeted = SkSurface::kYes_Budgeted; | |
| 203 return new SkImage_Gpu(desc.fWidth, desc.fHeight, kNeedNewImageUniqueID, at,
dst, | 200 return new SkImage_Gpu(desc.fWidth, desc.fHeight, kNeedNewImageUniqueID, at,
dst, |
| 204 budgeted); | 201 SkBudgeted::kYes); |
| 205 } | 202 } |
| 206 | 203 |
| 207 SkImage* SkImage::NewFromYUVTexturesCopy(GrContext* ctx , SkYUVColorSpace colorS
pace, | 204 SkImage* SkImage::NewFromYUVTexturesCopy(GrContext* ctx , SkYUVColorSpace colorS
pace, |
| 208 const GrBackendObject yuvTextureHandles
[3], | 205 const GrBackendObject yuvTextureHandles
[3], |
| 209 const SkISize yuvSizes[3], | 206 const SkISize yuvSizes[3], |
| 210 GrSurfaceOrigin origin) { | 207 GrSurfaceOrigin origin) { |
| 211 const SkSurface::Budgeted budgeted = SkSurface::kYes_Budgeted; | 208 const SkBudgeted budgeted = SkBudgeted::kYes; |
| 212 | 209 |
| 213 if (yuvSizes[0].fWidth <= 0 || yuvSizes[0].fHeight <= 0 || | 210 if (yuvSizes[0].fWidth <= 0 || yuvSizes[0].fHeight <= 0 || |
| 214 yuvSizes[1].fWidth <= 0 || yuvSizes[1].fHeight <= 0 || | 211 yuvSizes[1].fWidth <= 0 || yuvSizes[1].fHeight <= 0 || |
| 215 yuvSizes[2].fWidth <= 0 || yuvSizes[2].fHeight <= 0) { | 212 yuvSizes[2].fWidth <= 0 || yuvSizes[2].fHeight <= 0) { |
| 216 return nullptr; | 213 return nullptr; |
| 217 } | 214 } |
| 218 static const GrPixelConfig kConfig = kAlpha_8_GrPixelConfig; | 215 static const GrPixelConfig kConfig = kAlpha_8_GrPixelConfig; |
| 219 GrBackendTextureDesc yDesc; | 216 GrBackendTextureDesc yDesc; |
| 220 yDesc.fConfig = kConfig; | 217 yDesc.fConfig = kConfig; |
| 221 yDesc.fOrigin = origin; | 218 yDesc.fOrigin = origin; |
| (...skipping 30 matching lines...) Expand all Loading... |
| 252 | 249 |
| 253 GrSurfaceDesc dstDesc; | 250 GrSurfaceDesc dstDesc; |
| 254 // Needs to be a render target in order to draw to it for the yuv->rgb conve
rsion. | 251 // Needs to be a render target in order to draw to it for the yuv->rgb conve
rsion. |
| 255 dstDesc.fFlags = kRenderTarget_GrSurfaceFlag; | 252 dstDesc.fFlags = kRenderTarget_GrSurfaceFlag; |
| 256 dstDesc.fOrigin = origin; | 253 dstDesc.fOrigin = origin; |
| 257 dstDesc.fWidth = yuvSizes[0].fWidth; | 254 dstDesc.fWidth = yuvSizes[0].fWidth; |
| 258 dstDesc.fHeight = yuvSizes[0].fHeight; | 255 dstDesc.fHeight = yuvSizes[0].fHeight; |
| 259 dstDesc.fConfig = kRGBA_8888_GrPixelConfig; | 256 dstDesc.fConfig = kRGBA_8888_GrPixelConfig; |
| 260 dstDesc.fSampleCnt = 0; | 257 dstDesc.fSampleCnt = 0; |
| 261 | 258 |
| 262 SkAutoTUnref<GrTexture> dst(ctx->textureProvider()->createTexture(dstDesc, t
rue)); | 259 SkAutoTUnref<GrTexture> dst(ctx->textureProvider()->createTexture(dstDesc, S
kBudgeted::kYes)); |
| 263 if (!dst) { | 260 if (!dst) { |
| 264 return nullptr; | 261 return nullptr; |
| 265 } | 262 } |
| 266 | 263 |
| 267 GrPaint paint; | 264 GrPaint paint; |
| 268 paint.setPorterDuffXPFactory(SkXfermode::kSrc_Mode); | 265 paint.setPorterDuffXPFactory(SkXfermode::kSrc_Mode); |
| 269 paint.addColorFragmentProcessor(GrYUVEffect::CreateYUVToRGB(yTex, uTex, vTex
, yuvSizes, | 266 paint.addColorFragmentProcessor(GrYUVEffect::CreateYUVToRGB(yTex, uTex, vTex
, yuvSizes, |
| 270 colorSpace))->un
ref(); | 267 colorSpace))->un
ref(); |
| 271 | 268 |
| 272 const SkRect rect = SkRect::MakeWH(SkIntToScalar(dstDesc.fWidth), | 269 const SkRect rect = SkRect::MakeWH(SkIntToScalar(dstDesc.fWidth), |
| 273 SkIntToScalar(dstDesc.fHeight)); | 270 SkIntToScalar(dstDesc.fHeight)); |
| 274 SkAutoTUnref<GrDrawContext> drawContext(ctx->drawContext(dst->asRenderTarget
())); | 271 SkAutoTUnref<GrDrawContext> drawContext(ctx->drawContext(dst->asRenderTarget
())); |
| 275 if (!drawContext) { | 272 if (!drawContext) { |
| 276 return nullptr; | 273 return nullptr; |
| 277 } | 274 } |
| 278 | 275 |
| 279 drawContext->drawRect(GrClip::WideOpen(), paint, SkMatrix::I(), rect); | 276 drawContext->drawRect(GrClip::WideOpen(), paint, SkMatrix::I(), rect); |
| 280 ctx->flushSurfaceWrites(dst); | 277 ctx->flushSurfaceWrites(dst); |
| 281 return new SkImage_Gpu(dstDesc.fWidth, dstDesc.fHeight, kNeedNewImageUniqueI
D, | 278 return new SkImage_Gpu(dstDesc.fWidth, dstDesc.fHeight, kNeedNewImageUniqueI
D, |
| 282 kOpaque_SkAlphaType, dst, budgeted); | 279 kOpaque_SkAlphaType, dst, budgeted); |
| 283 } | 280 } |
| 284 | 281 |
| 285 static SkImage* create_image_from_maker(GrTextureMaker* maker, SkAlphaType at, u
int32_t id) { | 282 static SkImage* create_image_from_maker(GrTextureMaker* maker, SkAlphaType at, u
int32_t id) { |
| 286 SkAutoTUnref<GrTexture> texture(maker->refTextureForParams(GrTextureParams::
ClampNoFilter())); | 283 SkAutoTUnref<GrTexture> texture(maker->refTextureForParams(GrTextureParams::
ClampNoFilter())); |
| 287 if (!texture) { | 284 if (!texture) { |
| 288 return nullptr; | 285 return nullptr; |
| 289 } | 286 } |
| 290 return new SkImage_Gpu(texture->width(), texture->height(), id, at, texture, | 287 return new SkImage_Gpu(texture->width(), texture->height(), id, at, texture, |
| 291 SkSurface::kNo_Budgeted); | 288 SkBudgeted::kNo); |
| 292 } | 289 } |
| 293 | 290 |
| 294 SkImage* SkImage::newTextureImage(GrContext *context) const { | 291 SkImage* SkImage::newTextureImage(GrContext *context) const { |
| 295 if (!context) { | 292 if (!context) { |
| 296 return nullptr; | 293 return nullptr; |
| 297 } | 294 } |
| 298 if (GrTexture* peek = as_IB(this)->peekTexture()) { | 295 if (GrTexture* peek = as_IB(this)->peekTexture()) { |
| 299 return peek->getContext() == context ? SkRef(const_cast<SkImage*>(this))
: nullptr; | 296 return peek->getContext() == context ? SkRef(const_cast<SkImage*>(this))
: nullptr; |
| 300 } | 297 } |
| 301 // No way to check whether a image is premul or not? | 298 // No way to check whether a image is premul or not? |
| 302 SkAlphaType at = this->isOpaque() ? kOpaque_SkAlphaType : kPremul_SkAlphaTyp
e; | 299 SkAlphaType at = this->isOpaque() ? kOpaque_SkAlphaType : kPremul_SkAlphaTyp
e; |
| 303 | 300 |
| 304 if (SkImageCacherator* cacher = as_IB(this)->peekCacherator()) { | 301 if (SkImageCacherator* cacher = as_IB(this)->peekCacherator()) { |
| 305 GrImageTextureMaker maker(context, cacher, this, kDisallow_CachingHint); | 302 GrImageTextureMaker maker(context, cacher, this, kDisallow_CachingHint); |
| 306 return create_image_from_maker(&maker, at, this->uniqueID()); | 303 return create_image_from_maker(&maker, at, this->uniqueID()); |
| 307 } | 304 } |
| 308 SkBitmap bmp; | 305 SkBitmap bmp; |
| 309 if (!this->asLegacyBitmap(&bmp, kRO_LegacyBitmapMode)) { | 306 if (!this->asLegacyBitmap(&bmp, kRO_LegacyBitmapMode)) { |
| 310 return nullptr; | 307 return nullptr; |
| 311 } | 308 } |
| 312 GrBitmapTextureMaker maker(context, bmp); | 309 GrBitmapTextureMaker maker(context, bmp); |
| 313 return create_image_from_maker(&maker, at, this->uniqueID()); | 310 return create_image_from_maker(&maker, at, this->uniqueID()); |
| 314 } | 311 } |
| 315 | 312 |
| 316 ////////////////////////////////////////////////////////////////////////////////
/////////////////// | 313 ////////////////////////////////////////////////////////////////////////////////
/////////////////// |
| 317 | 314 |
| 318 GrTexture* GrDeepCopyTexture(GrTexture* src, bool budgeted) { | 315 GrTexture* GrDeepCopyTexture(GrTexture* src, SkBudgeted budgeted) { |
| 319 GrContext* ctx = src->getContext(); | 316 GrContext* ctx = src->getContext(); |
| 320 | 317 |
| 321 GrSurfaceDesc desc = src->desc(); | 318 GrSurfaceDesc desc = src->desc(); |
| 322 GrTexture* dst = ctx->textureProvider()->createTexture(desc, budgeted, nullp
tr, 0); | 319 GrTexture* dst = ctx->textureProvider()->createTexture(desc, budgeted, nullp
tr, 0); |
| 323 if (!dst) { | 320 if (!dst) { |
| 324 return nullptr; | 321 return nullptr; |
| 325 } | 322 } |
| 326 | 323 |
| 327 const SkIRect srcR = SkIRect::MakeWH(desc.fWidth, desc.fHeight); | 324 const SkIRect srcR = SkIRect::MakeWH(desc.fWidth, desc.fHeight); |
| 328 const SkIPoint dstP = SkIPoint::Make(0, 0); | 325 const SkIPoint dstP = SkIPoint::Make(0, 0); |
| 329 ctx->copySurface(dst, src, srcR, dstP); | 326 ctx->copySurface(dst, src, srcR, dstP); |
| 330 ctx->flushSurfaceWrites(dst); | 327 ctx->flushSurfaceWrites(dst); |
| 331 return dst; | 328 return dst; |
| 332 } | 329 } |
| 333 | 330 |
| OLD | NEW |