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 |