blob: fc0aa63d4ab15ce27fae4cbc5c2c82853039840f [file] [log] [blame]
reed8f343722015-08-13 13:32:39 -07001/*
Brian Osman3b655982017-03-07 16:58:08 -05002 * Copyright 2017 Google Inc.
reed8f343722015-08-13 13:32:39 -07003 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
Brian Osman3b655982017-03-07 16:58:08 -05008#ifndef SkGr_DEFINED
9#define SkGr_DEFINED
reed8f343722015-08-13 13:32:39 -070010
Ethan Nicholas052fd512017-01-27 15:34:34 +000011#include "GrBlend.h"
Brian Osman3b655982017-03-07 16:58:08 -050012#include "GrColor.h"
Brian Salomon2bbdcc42017-09-07 12:36:34 -040013#include "GrSamplerState.h"
Brian Salomon587e08f2017-01-27 10:59:27 -050014#include "GrTypes.h"
Brian Salomon2bbdcc42017-09-07 12:36:34 -040015#include "SkBlendModePriv.h"
Brian Salomon199fb872017-02-06 09:41:10 -050016#include "SkCanvas.h"
Brian Osman3b655982017-03-07 16:58:08 -050017#include "SkColor.h"
Cary Clarka4083c92017-09-15 11:59:23 -040018#include "SkColorData.h"
Brian Osman3b655982017-03-07 16:58:08 -050019#include "SkFilterQuality.h"
bsalomonf1b7a1d2015-09-28 06:26:28 -070020#include "SkImageInfo.h"
bsalomonafa95e22015-10-12 10:39:46 -070021#include "SkMatrix.h"
Brian Salomon587e08f2017-01-27 10:59:27 -050022#include "SkPM4f.h"
Mike Reed887cdf12017-04-03 11:11:09 -040023#include "SkVertices.h"
reed8f343722015-08-13 13:32:39 -070024
25class GrCaps;
Brian Salomonf3569f02017-10-24 12:52:33 -040026class GrColorSpaceInfo;
Brian Osman3b655982017-03-07 16:58:08 -050027class GrColorSpaceXform;
bsalomonf1b7a1d2015-09-28 06:26:28 -070028class GrContext;
29class GrFragmentProcessor;
30class GrPaint;
Robert Phillips26c90e02017-03-14 14:39:29 -040031class GrResourceProvider;
Robert Phillipse14d3052017-02-15 13:18:21 -050032class GrTextureProxy;
reed8f343722015-08-13 13:32:39 -070033class GrUniqueKey;
Brian Salomon6f1d36c2017-01-13 12:02:17 -050034class SkBitmap;
bsalomonafa95e22015-10-12 10:39:46 -070035class SkData;
bsalomonf1b7a1d2015-09-28 06:26:28 -070036class SkPaint;
bsalomonafa95e22015-10-12 10:39:46 -070037class SkPixelRef;
Brian Salomon6f1d36c2017-01-13 12:02:17 -050038class SkPixmap;
bsalomonf1b7a1d2015-09-28 06:26:28 -070039struct SkIRect;
reed8f343722015-08-13 13:32:39 -070040
Brian Osman3b655982017-03-07 16:58:08 -050041////////////////////////////////////////////////////////////////////////////////
42// Color type conversions
reed856e9d92015-09-30 12:21:45 -070043
Brian Osman3b655982017-03-07 16:58:08 -050044static inline GrColor SkColorToPremulGrColor(SkColor c) {
45 SkPMColor pm = SkPreMultiplyColor(c);
46 unsigned r = SkGetPackedR32(pm);
47 unsigned g = SkGetPackedG32(pm);
48 unsigned b = SkGetPackedB32(pm);
49 unsigned a = SkGetPackedA32(pm);
50 return GrColorPackRGBA(r, g, b, a);
51}
52
53static inline GrColor SkColorToUnpremulGrColor(SkColor c) {
54 unsigned r = SkColorGetR(c);
55 unsigned g = SkColorGetG(c);
56 unsigned b = SkColorGetB(c);
57 unsigned a = SkColorGetA(c);
58 return GrColorPackRGBA(r, g, b, a);
59}
60
Brian Salomon4cbb6e62017-10-25 15:12:19 -040061/** Transform an SkColor (sRGB bytes) to GrColor4f for the specified color space info. */
62GrColor4f SkColorToPremulGrColor4f(SkColor, const GrColorSpaceInfo&);
63GrColor4f SkColorToPremulGrColor4fLegacy(SkColor);
64GrColor4f SkColorToUnpremulGrColor4f(SkColor, const GrColorSpaceInfo&);
Brian Osman3b655982017-03-07 16:58:08 -050065
66/** Replicates the SkColor's alpha to all four channels of the GrColor. */
67static inline GrColor SkColorAlphaToGrColor(SkColor c) {
68 U8CPU a = SkColorGetA(c);
69 return GrColorPackRGBA(a, a, a, a);
70}
71
72//////////////////////////////////////////////////////////////////////////////
73
74static inline SkPM4f GrColor4fToSkPM4f(const GrColor4f& c) {
75 SkPM4f pm4f;
76 pm4f.fVec[SkPM4f::R] = c.fRGBA[0];
77 pm4f.fVec[SkPM4f::G] = c.fRGBA[1];
78 pm4f.fVec[SkPM4f::B] = c.fRGBA[2];
79 pm4f.fVec[SkPM4f::A] = c.fRGBA[3];
80 return pm4f;
81}
82
83static inline GrColor4f SkPM4fToGrColor4f(const SkPM4f& c) {
84 return GrColor4f{c.r(), c.g(), c.b(), c.a()};
85}
86
87////////////////////////////////////////////////////////////////////////////////
88// Paint conversion
bsalomonc55271f2015-11-09 11:55:57 -080089
bsalomonf1b7a1d2015-09-28 06:26:28 -070090/** Converts an SkPaint to a GrPaint for a given GrContext. The matrix is required in order
bsalomonaa48d362015-10-01 08:34:17 -070091 to convert the SkShader (if any) on the SkPaint. The primitive itself has no color. */
bsalomonf1b7a1d2015-09-28 06:26:28 -070092bool SkPaintToGrPaint(GrContext*,
Brian Salomonf3569f02017-10-24 12:52:33 -040093 const GrColorSpaceInfo& dstColorSpaceInfo,
bsalomonf1b7a1d2015-09-28 06:26:28 -070094 const SkPaint& skPaint,
95 const SkMatrix& viewM,
96 GrPaint* grPaint);
97
bsalomonaa48d362015-10-01 08:34:17 -070098/** Same as above but ignores the SkShader (if any) on skPaint. */
bsalomonf1b7a1d2015-09-28 06:26:28 -070099bool SkPaintToGrPaintNoShader(GrContext* context,
Brian Salomonf3569f02017-10-24 12:52:33 -0400100 const GrColorSpaceInfo& dstColorSpaceInfo,
bsalomonf1b7a1d2015-09-28 06:26:28 -0700101 const SkPaint& skPaint,
102 GrPaint* grPaint);
103
104/** Replaces the SkShader (if any) on skPaint with the passed in GrFragmentProcessor. The processor
bsalomonaa48d362015-10-01 08:34:17 -0700105 should expect an unpremul input color and produce a premultiplied output color. There is
106 no primitive color. */
bsalomonf1b7a1d2015-09-28 06:26:28 -0700107bool SkPaintToGrPaintReplaceShader(GrContext*,
Brian Salomonf3569f02017-10-24 12:52:33 -0400108 const GrColorSpaceInfo& dstColorSpaceInfo,
bsalomonf1b7a1d2015-09-28 06:26:28 -0700109 const SkPaint& skPaint,
Brian Salomonaff329b2017-08-11 09:40:37 -0400110 std::unique_ptr<GrFragmentProcessor> shaderFP,
bsalomonf1b7a1d2015-09-28 06:26:28 -0700111 GrPaint* grPaint);
112
113/** Blends the SkPaint's shader (or color if no shader) with the color which specified via a
Mike Reed185ba212017-04-28 12:31:05 -0400114 GrOp's GrPrimitiveProcesssor. */
bsalomonf1b7a1d2015-09-28 06:26:28 -0700115bool SkPaintToGrPaintWithXfermode(GrContext* context,
Brian Salomonf3569f02017-10-24 12:52:33 -0400116 const GrColorSpaceInfo& dstColorSpaceInfo,
bsalomonf1b7a1d2015-09-28 06:26:28 -0700117 const SkPaint& skPaint,
118 const SkMatrix& viewM,
Mike Reed7d954ad2016-10-28 15:42:34 -0400119 SkBlendMode primColorMode,
bsalomonf1b7a1d2015-09-28 06:26:28 -0700120 GrPaint* grPaint);
121
bsalomonaa48d362015-10-01 08:34:17 -0700122/** This is used when there is a primitive color, but the shader should be ignored. Currently,
123 the expectation is that the primitive color will be premultiplied, though it really should be
124 unpremultiplied so that interpolation is done in unpremul space. The paint's alpha will be
125 applied to the primitive color after interpolation. */
Brian Salomonf3569f02017-10-24 12:52:33 -0400126inline bool SkPaintToGrPaintWithPrimitiveColor(GrContext* context,
127 const GrColorSpaceInfo& dstColorSpaceInfo,
brianosman8fe485b2016-07-25 12:31:51 -0700128 const SkPaint& skPaint, GrPaint* grPaint) {
Brian Salomonf3569f02017-10-24 12:52:33 -0400129 return SkPaintToGrPaintWithXfermode(context, dstColorSpaceInfo, skPaint, SkMatrix::I(),
130 SkBlendMode::kDst, grPaint);
bsalomonaa48d362015-10-01 08:34:17 -0700131}
132
joshualitt33a5fce2015-11-18 13:28:51 -0800133/** This is used when there may or may not be a shader, and the caller wants to plugin a texture
134 lookup. If there is a shader, then its output will only be used if the texture is alpha8. */
135bool SkPaintToGrPaintWithTexture(GrContext* context,
Brian Salomonf3569f02017-10-24 12:52:33 -0400136 const GrColorSpaceInfo& dstColorSpaceInfo,
joshualitt33a5fce2015-11-18 13:28:51 -0800137 const SkPaint& paint,
138 const SkMatrix& viewM,
Brian Salomonaff329b2017-08-11 09:40:37 -0400139 std::unique_ptr<GrFragmentProcessor> fp,
joshualitt33a5fce2015-11-18 13:28:51 -0800140 bool textureIsAlphaOnly,
141 GrPaint* grPaint);
142
Brian Osman3b655982017-03-07 16:58:08 -0500143////////////////////////////////////////////////////////////////////////////////
144// Misc Sk to Gr type conversions
145
146GrSurfaceDesc GrImageInfoToSurfaceDesc(const SkImageInfo&, const GrCaps&);
Greg Daniel81e7bf82017-07-19 14:47:42 -0400147GrPixelConfig SkImageInfo2GrPixelConfig(const SkColorType, SkColorSpace*, const GrCaps& caps);
Brian Osman3b655982017-03-07 16:58:08 -0500148GrPixelConfig SkImageInfo2GrPixelConfig(const SkImageInfo& info, const GrCaps& caps);
149
150bool GrPixelConfigToColorType(GrPixelConfig, SkColorType*);
151
Brian Salomon2bbdcc42017-09-07 12:36:34 -0400152GrSamplerState::Filter GrSkFilterQualityToGrFilterMode(SkFilterQuality paintFilterQuality,
153 const SkMatrix& viewM,
154 const SkMatrix& localM,
Brian Osmandb78cba2018-02-15 10:09:48 -0500155 bool sharpenMipmappedTextures,
Brian Salomon2bbdcc42017-09-07 12:36:34 -0400156 bool* doBicubic);
Brian Osman3b655982017-03-07 16:58:08 -0500157
bsalomonf276ac52015-10-09 13:36:42 -0700158//////////////////////////////////////////////////////////////////////////////
159
Mike Reed887cdf12017-04-03 11:11:09 -0400160static inline GrPrimitiveType SkVertexModeToGrPrimitiveType(SkVertices::VertexMode mode) {
Brian Salomon199fb872017-02-06 09:41:10 -0500161 switch (mode) {
Mike Reed887cdf12017-04-03 11:11:09 -0400162 case SkVertices::kTriangles_VertexMode:
Chris Dalton3809bab2017-06-13 10:55:06 -0600163 return GrPrimitiveType::kTriangles;
Mike Reed887cdf12017-04-03 11:11:09 -0400164 case SkVertices::kTriangleStrip_VertexMode:
Chris Dalton3809bab2017-06-13 10:55:06 -0600165 return GrPrimitiveType::kTriangleStrip;
Mike Reed887cdf12017-04-03 11:11:09 -0400166 case SkVertices::kTriangleFan_VertexMode:
Chris Dalton3809bab2017-06-13 10:55:06 -0600167 return GrPrimitiveType::kTriangleFan;
Brian Salomon199fb872017-02-06 09:41:10 -0500168 }
Ben Wagnerb4aab9a2017-08-16 10:53:04 -0400169 SK_ABORT("Invalid mode");
Chris Dalton3809bab2017-06-13 10:55:06 -0600170 return GrPrimitiveType::kPoints;
Brian Salomon199fb872017-02-06 09:41:10 -0500171}
172
173//////////////////////////////////////////////////////////////////////////////
174
Mike Reed6b3542a2017-06-06 10:41:18 -0400175GR_STATIC_ASSERT((int)kZero_GrBlendCoeff == (int)SkBlendModeCoeff::kZero);
176GR_STATIC_ASSERT((int)kOne_GrBlendCoeff == (int)SkBlendModeCoeff::kOne);
177GR_STATIC_ASSERT((int)kSC_GrBlendCoeff == (int)SkBlendModeCoeff::kSC);
178GR_STATIC_ASSERT((int)kISC_GrBlendCoeff == (int)SkBlendModeCoeff::kISC);
179GR_STATIC_ASSERT((int)kDC_GrBlendCoeff == (int)SkBlendModeCoeff::kDC);
180GR_STATIC_ASSERT((int)kIDC_GrBlendCoeff == (int)SkBlendModeCoeff::kIDC);
181GR_STATIC_ASSERT((int)kSA_GrBlendCoeff == (int)SkBlendModeCoeff::kSA);
182GR_STATIC_ASSERT((int)kISA_GrBlendCoeff == (int)SkBlendModeCoeff::kISA);
183GR_STATIC_ASSERT((int)kDA_GrBlendCoeff == (int)SkBlendModeCoeff::kDA);
184GR_STATIC_ASSERT((int)kIDA_GrBlendCoeff == (int)SkBlendModeCoeff::kIDA);
185//GR_STATIC_ASSERT(SkXfermode::kCoeffCount == 10);
Brian Salomon587e08f2017-01-27 10:59:27 -0500186
Brian Osman3b655982017-03-07 16:58:08 -0500187#define SkXfermodeCoeffToGrBlendCoeff(X) ((GrBlendCoeff)(X))
Brian Salomon587e08f2017-01-27 10:59:27 -0500188
Brian Osman3b655982017-03-07 16:58:08 -0500189////////////////////////////////////////////////////////////////////////////////
190// Texture management
Brian Salomon587e08f2017-01-27 10:59:27 -0500191
Brian Salomon2bbdcc42017-09-07 12:36:34 -0400192/** Returns a texture representing the bitmap that is compatible with the GrSamplerState. The
Brian Osman3b655982017-03-07 16:58:08 -0500193 * texture is inserted into the cache (unless the bitmap is marked volatile) and can be
194 * retrieved again via this function.
195 * The 'scaleAdjust' in/out parameter will be updated to hold any rescaling that needs to be
196 * performed on the absolute texture coordinates (e.g., if the texture is resized out to
197 * the next power of two). It can be null if the caller is sure the bitmap won't be resized.
bsalomon045802d2015-10-20 07:58:01 -0700198 */
Robert Phillipsbbd7a3b2017-03-21 08:48:40 -0400199sk_sp<GrTextureProxy> GrRefCachedBitmapTextureProxy(GrContext*,
200 const SkBitmap&,
Brian Salomon2bbdcc42017-09-07 12:36:34 -0400201 const GrSamplerState&,
Robert Phillipsbbd7a3b2017-03-21 08:48:40 -0400202 SkScalar scaleAdjust[2]);
203
bsalomon045802d2015-10-20 07:58:01 -0700204/**
205 * Creates a new texture for the bitmap. Does not concern itself with cache keys or texture params.
206 * The bitmap must have CPU-accessible pixels. Attempts to take advantage of faster paths for
Robert Phillips92de6312017-05-23 07:43:48 -0400207 * yuv planes.
bsalomon045802d2015-10-20 07:58:01 -0700208 */
Robert Phillips1afd4cd2018-01-08 13:40:32 -0500209sk_sp<GrTextureProxy> GrUploadBitmapToTextureProxy(GrProxyProvider*, const SkBitmap&,
Matt Sarettdedac852017-05-12 10:56:49 -0400210 SkColorSpace* dstColorSpace);
Robert Phillipsd3749482017-03-14 09:17:43 -0400211
bsalomon0d996862016-03-09 18:44:43 -0800212/**
Greg Daniel55afd6d2017-09-29 09:32:44 -0400213 * Creates a new texture with mipmap levels and copies the baseProxy into the base layer.
214 */
215sk_sp<GrTextureProxy> GrCopyBaseMipMapToTextureProxy(GrContext*,
Greg Daniele1da1d92017-10-06 15:59:27 -0400216 GrTextureProxy* baseProxy);
Greg Daniel55afd6d2017-09-29 09:32:44 -0400217
Greg Daniel7e1912a2018-02-08 09:15:33 -0500218/*
219 * Create a texture proxy from the provided bitmap by wrapping it in an image and calling
220 * GrMakeCachedImageProxy.
221 */
222sk_sp<GrTextureProxy> GrMakeCachedBitmapProxy(GrProxyProvider*, const SkBitmap& bitmap,
223 SkBackingFit fit = SkBackingFit::kExact);
Robert Phillipse14d3052017-02-15 13:18:21 -0500224
Robert Phillips7a926392018-02-01 15:49:54 -0500225/*
226 * Create a texture proxy from the provided 'srcImage' and add it to the texture cache
227 * using the key also extracted from 'srcImage'.
228 */
Greg Daniel490695b2018-02-05 09:34:02 -0500229sk_sp<GrTextureProxy> GrMakeCachedImageProxy(GrProxyProvider*, sk_sp<SkImage> srcImage,
230 SkBackingFit fit = SkBackingFit::kExact);
Brian Osman3b655982017-03-07 16:58:08 -0500231
232/**
233 * Our key includes the offset, width, and height so that bitmaps created by extractSubset()
234 * are unique.
235 *
236 * The imageID is in the shared namespace (see SkNextID::ImageID())
237 * - SkBitmap/SkPixelRef
238 * - SkImage
239 * - SkImageGenerator
240 *
241 * Note: width/height must fit in 16bits for this impl.
242 */
243void GrMakeKeyFromImageID(GrUniqueKey* key, uint32_t imageID, const SkIRect& imageBounds);
244
245/** Call this after installing a GrUniqueKey on texture. It will cause the texture's key to be
246 removed should the bitmap's contents change or be destroyed. */
247void GrInstallBitmapUniqueKeyInvalidator(const GrUniqueKey& key, SkPixelRef* pixelRef);
248
bsalomonf276ac52015-10-09 13:36:42 -0700249//////////////////////////////////////////////////////////////////////////////
250
Brian Osman3b655982017-03-07 16:58:08 -0500251/** When image filter code needs to construct a render target context to do intermediate rendering,
252 we need a renderable pixel config. The source (SkSpecialImage) may not be in a renderable
253 format, but we want to preserve the color space of that source. This picks an appropriate format
254 to use. */
255GrPixelConfig GrRenderableConfigForColorSpace(const SkColorSpace*);
bsalomonf276ac52015-10-09 13:36:42 -0700256
reed8f343722015-08-13 13:32:39 -0700257#endif