diff options
author | Greg Daniel <egdaniel@google.com> | 2018-06-12 16:39:59 -0400 |
---|---|---|
committer | Skia Commit-Bot <skia-commit-bot@chromium.org> | 2018-06-13 13:55:56 +0000 |
commit | 5f4b09d523a761a3a5c622bb01eeba47905da5f0 (patch) | |
tree | 899574a311503375d911ee6486894eb921138550 /src/gpu/GrTextureProducer.h | |
parent | ed8ed91ec8c0eb523262eb7bb91558399c7e591f (diff) |
Allow caller to specify if the want mip maps in makeTextureImage call.
Since Ganesh no longer will allocate mips late, this gives the clients a
way to tell skia that they want the texture they will be using to have mips.
It also supports allowing a client to take a non mipped texture backed
image and turn it into a new image which is mipped and texture backed.
Bug: chromium:834837
Change-Id: I1781ce618c22023b6309f248e7ee49e69bd3c6df
Reviewed-on: https://skia-review.googlesource.com/134323
Commit-Queue: Greg Daniel <egdaniel@google.com>
Reviewed-by: Eric Karl <ericrk@chromium.org>
Reviewed-by: Cary Clark <caryclark@google.com>
Reviewed-by: Brian Salomon <bsalomon@google.com>
Diffstat (limited to 'src/gpu/GrTextureProducer.h')
-rw-r--r-- | src/gpu/GrTextureProducer.h | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/src/gpu/GrTextureProducer.h b/src/gpu/GrTextureProducer.h index 467948dfa6..c458d4fbe6 100644 --- a/src/gpu/GrTextureProducer.h +++ b/src/gpu/GrTextureProducer.h @@ -98,6 +98,21 @@ public: proxyColorSpace, scaleAdjust); } + /** + * Returns a texture that is safe for use with the dstColorSpace. If willNeedMips is true then + * the returned texture is guaranteed to have allocated mip map levels. This can be a + * performance win if future draws with the texture require mip maps. + * + * Places the color space of the texture in (*proxyColorSpace). + */ + // TODO: Once we remove support for npot textures, we should add a flag for must support repeat + // wrap mode. To support that flag now would require us to support scaleAdjust array like in + // refTextureProxyForParams, however the current public API that uses this call does not expose + // that array. + sk_sp<GrTextureProxy> refTextureProxy(GrMipMapped willNeedMips, + SkColorSpace* dstColorSpace, + sk_sp<SkColorSpace>* proxyColorSpace); + virtual ~GrTextureProducer() {} int width() const { return fWidth; } |