| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2011 Google Inc. | 2 * Copyright 2011 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 "SkGpuDevice.h" | 8 #include "SkGpuDevice.h" |
| 9 | 9 |
| 10 #include "GrContext.h" | 10 #include "GrContext.h" |
| (...skipping 1713 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1724 // must be pushed upstack. | 1724 // must be pushed upstack. |
| 1725 AutoBitmapTexture abt(fContext, src, NULL, &texture); | 1725 AutoBitmapTexture abt(fContext, src, NULL, &texture); |
| 1726 if (!texture) { | 1726 if (!texture) { |
| 1727 return false; | 1727 return false; |
| 1728 } | 1728 } |
| 1729 | 1729 |
| 1730 return this->filterTexture(fContext, texture, src.width(), src.height(), | 1730 return this->filterTexture(fContext, texture, src.width(), src.height(), |
| 1731 filter, ctx, result, offset); | 1731 filter, ctx, result, offset); |
| 1732 } | 1732 } |
| 1733 | 1733 |
| 1734 static SkImageInfo make_info(GrTexture* tex, int w, int h, bool isOpaque) { | |
| 1735 const GrPixelConfig config = tex->config(); | |
| 1736 SkColorType ct; | |
| 1737 SkAlphaType at = isOpaque ? kOpaque_SkAlphaType : kPremul_SkAlphaType; | |
| 1738 if (!GrPixelConfig2ColorAndProfileType(config, &ct, NULL)) { | |
| 1739 ct = kUnknown_SkColorType; | |
| 1740 } | |
| 1741 return SkImageInfo::Make(w, h, ct, at); | |
| 1742 } | |
| 1743 | |
| 1744 static bool wrap_as_bm(const SkImage* image, SkBitmap* bm) { | 1734 static bool wrap_as_bm(const SkImage* image, SkBitmap* bm) { |
| 1745 GrTexture* tex = image->getTexture(); | 1735 GrTexture* tex = image->getTexture(); |
| 1746 if (tex) { | 1736 if (tex) { |
| 1747 // TODO: handle the GrTexture directly, and skip GrPixelRef | 1737 GrWrapTextureInBitmap(tex, image->width(), image->height(), image->isOpa
que(), bm); |
| 1748 const SkImageInfo info = make_info(tex, image->width(), image->height(),
image->isOpaque()); | 1738 return true; |
| 1749 bm->setInfo(info); | |
| 1750 bm->setPixelRef(SkNEW_ARGS(SkGrPixelRef, (info, tex)))->unref(); | |
| 1751 } else { | 1739 } else { |
| 1752 if (!as_IB(image)->getROPixels(bm)) { | 1740 return as_IB(image)->getROPixels(bm); |
| 1753 return false; | |
| 1754 } | |
| 1755 } | 1741 } |
| 1756 return true; | |
| 1757 } | 1742 } |
| 1758 | 1743 |
| 1759 void SkGpuDevice::drawImage(const SkDraw& draw, const SkImage* image, SkScalar x
, SkScalar y, | 1744 void SkGpuDevice::drawImage(const SkDraw& draw, const SkImage* image, SkScalar x
, SkScalar y, |
| 1760 const SkPaint& paint) { | 1745 const SkPaint& paint) { |
| 1761 SkBitmap bm; | 1746 SkBitmap bm; |
| 1762 if (wrap_as_bm(image, &bm)) { | 1747 if (wrap_as_bm(image, &bm)) { |
| 1763 this->drawBitmap(draw, bm, SkMatrix::MakeTrans(x, y), paint); | 1748 this->drawBitmap(draw, bm, SkMatrix::MakeTrans(x, y), paint); |
| 1764 } | 1749 } |
| 1765 } | 1750 } |
| 1766 | 1751 |
| (...skipping 305 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2072 #endif | 2057 #endif |
| 2073 } | 2058 } |
| 2074 | 2059 |
| 2075 SkImageFilter::Cache* SkGpuDevice::getImageFilterCache() { | 2060 SkImageFilter::Cache* SkGpuDevice::getImageFilterCache() { |
| 2076 // We always return a transient cache, so it is freed after each | 2061 // We always return a transient cache, so it is freed after each |
| 2077 // filter traversal. | 2062 // filter traversal. |
| 2078 return SkImageFilter::Cache::Create(kDefaultImageFilterCacheSize); | 2063 return SkImageFilter::Cache::Create(kDefaultImageFilterCacheSize); |
| 2079 } | 2064 } |
| 2080 | 2065 |
| 2081 #endif | 2066 #endif |
| OLD | NEW |