reed | 8f34372 | 2015-08-13 13:32:39 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2015 Google Inc. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license that can be |
| 5 | * found in the LICENSE file. |
| 6 | */ |
| 7 | |
| 8 | #ifndef SkGrPriv_DEFINED |
| 9 | #define SkGrPriv_DEFINED |
| 10 | |
| 11 | #include "GrTypes.h" |
bsalomon | f276ac5 | 2015-10-09 13:36:42 -0700 | [diff] [blame] | 12 | #include "GrBlend.h" |
bsalomon | f1b7a1d | 2015-09-28 06:26:28 -0700 | [diff] [blame] | 13 | #include "SkImageInfo.h" |
bsalomon | afa95e2 | 2015-10-12 10:39:46 -0700 | [diff] [blame] | 14 | #include "SkMatrix.h" |
bsalomon | f1b7a1d | 2015-09-28 06:26:28 -0700 | [diff] [blame] | 15 | #include "SkXfermode.h" |
reed | 8f34372 | 2015-08-13 13:32:39 -0700 | [diff] [blame] | 16 | |
| 17 | class GrCaps; |
bsalomon | f1b7a1d | 2015-09-28 06:26:28 -0700 | [diff] [blame] | 18 | class GrContext; |
| 19 | class GrFragmentProcessor; |
| 20 | class GrPaint; |
bsalomon | f276ac5 | 2015-10-09 13:36:42 -0700 | [diff] [blame] | 21 | class GrTexture; |
bsalomon | afa95e2 | 2015-10-12 10:39:46 -0700 | [diff] [blame] | 22 | class GrTextureParams; |
reed | 8f34372 | 2015-08-13 13:32:39 -0700 | [diff] [blame] | 23 | class GrUniqueKey; |
bsalomon | afa95e2 | 2015-10-12 10:39:46 -0700 | [diff] [blame] | 24 | class SkData; |
bsalomon | f1b7a1d | 2015-09-28 06:26:28 -0700 | [diff] [blame] | 25 | class SkPaint; |
bsalomon | afa95e2 | 2015-10-12 10:39:46 -0700 | [diff] [blame] | 26 | class SkPixelRef; |
bsalomon | f1b7a1d | 2015-09-28 06:26:28 -0700 | [diff] [blame] | 27 | struct SkIRect; |
reed | 8f34372 | 2015-08-13 13:32:39 -0700 | [diff] [blame] | 28 | |
| 29 | /** |
| 30 | * Our key includes the offset, width, and height so that bitmaps created by extractSubset() |
| 31 | * are unique. |
| 32 | * |
bsalomon | 045802d | 2015-10-20 07:58:01 -0700 | [diff] [blame] | 33 | * The imageID is in the shared namespace (see SkNextID::ImageID()) |
reed | 8f34372 | 2015-08-13 13:32:39 -0700 | [diff] [blame] | 34 | * - SkBitmap/SkPixelRef |
| 35 | * - SkImage |
| 36 | * - SkImageGenerator |
| 37 | * |
| 38 | * Note: width/height must fit in 16bits for this impl. |
| 39 | */ |
bsalomon | 045802d | 2015-10-20 07:58:01 -0700 | [diff] [blame] | 40 | void GrMakeKeyFromImageID(GrUniqueKey* key, uint32_t imageID, const SkIRect& imageBounds); |
reed | 856e9d9 | 2015-09-30 12:21:45 -0700 | [diff] [blame] | 41 | |
bsalomon | c55271f | 2015-11-09 11:55:57 -0800 | [diff] [blame] | 42 | /** Call this after installing a GrUniqueKey on texture. It will cause the texture's key to be |
| 43 | removed should the bitmap's contents change or be destroyed. */ |
| 44 | void GrInstallBitmapUniqueKeyInvalidator(const GrUniqueKey& key, SkPixelRef* pixelRef); |
| 45 | |
bsalomon | f1b7a1d | 2015-09-28 06:26:28 -0700 | [diff] [blame] | 46 | /** Converts an SkPaint to a GrPaint for a given GrContext. The matrix is required in order |
bsalomon | aa48d36 | 2015-10-01 08:34:17 -0700 | [diff] [blame] | 47 | to convert the SkShader (if any) on the SkPaint. The primitive itself has no color. */ |
bsalomon | f1b7a1d | 2015-09-28 06:26:28 -0700 | [diff] [blame] | 48 | bool SkPaintToGrPaint(GrContext*, |
| 49 | const SkPaint& skPaint, |
| 50 | const SkMatrix& viewM, |
| 51 | GrPaint* grPaint); |
| 52 | |
bsalomon | aa48d36 | 2015-10-01 08:34:17 -0700 | [diff] [blame] | 53 | /** Same as above but ignores the SkShader (if any) on skPaint. */ |
bsalomon | f1b7a1d | 2015-09-28 06:26:28 -0700 | [diff] [blame] | 54 | bool SkPaintToGrPaintNoShader(GrContext* context, |
| 55 | const SkPaint& skPaint, |
| 56 | GrPaint* grPaint); |
| 57 | |
| 58 | /** Replaces the SkShader (if any) on skPaint with the passed in GrFragmentProcessor. The processor |
bsalomon | aa48d36 | 2015-10-01 08:34:17 -0700 | [diff] [blame] | 59 | should expect an unpremul input color and produce a premultiplied output color. There is |
| 60 | no primitive color. */ |
bsalomon | f1b7a1d | 2015-09-28 06:26:28 -0700 | [diff] [blame] | 61 | bool SkPaintToGrPaintReplaceShader(GrContext*, |
| 62 | const SkPaint& skPaint, |
| 63 | const GrFragmentProcessor* shaderFP, |
| 64 | GrPaint* grPaint); |
| 65 | |
| 66 | /** Blends the SkPaint's shader (or color if no shader) with the color which specified via a |
| 67 | GrBatch's GrPrimitiveProcesssor. Currently there is a bool param to indicate whether the |
| 68 | primitive color is the dst or src color to the blend in order to work around differences between |
bsalomon | aa48d36 | 2015-10-01 08:34:17 -0700 | [diff] [blame] | 69 | drawVertices and drawAtlas. */ |
bsalomon | f1b7a1d | 2015-09-28 06:26:28 -0700 | [diff] [blame] | 70 | bool SkPaintToGrPaintWithXfermode(GrContext* context, |
| 71 | const SkPaint& skPaint, |
| 72 | const SkMatrix& viewM, |
| 73 | SkXfermode::Mode primColorMode, |
| 74 | bool primitiveIsSrc, |
| 75 | GrPaint* grPaint); |
| 76 | |
bsalomon | aa48d36 | 2015-10-01 08:34:17 -0700 | [diff] [blame] | 77 | /** This is used when there is a primitive color, but the shader should be ignored. Currently, |
| 78 | the expectation is that the primitive color will be premultiplied, though it really should be |
| 79 | unpremultiplied so that interpolation is done in unpremul space. The paint's alpha will be |
| 80 | applied to the primitive color after interpolation. */ |
| 81 | inline bool SkPaintToGrPaintWithPrimitiveColor(GrContext* context, const SkPaint& skPaint, |
| 82 | GrPaint* grPaint) { |
| 83 | return SkPaintToGrPaintWithXfermode(context, skPaint, SkMatrix::I(), SkXfermode::kDst_Mode, |
| 84 | false, grPaint); |
| 85 | } |
| 86 | |
joshualitt | 33a5fce | 2015-11-18 13:28:51 -0800 | [diff] [blame] | 87 | /** This is used when there may or may not be a shader, and the caller wants to plugin a texture |
| 88 | lookup. If there is a shader, then its output will only be used if the texture is alpha8. */ |
| 89 | bool SkPaintToGrPaintWithTexture(GrContext* context, |
| 90 | const SkPaint& paint, |
| 91 | const SkMatrix& viewM, |
| 92 | const GrFragmentProcessor* fp, |
| 93 | bool textureIsAlphaOnly, |
| 94 | GrPaint* grPaint); |
| 95 | |
bsalomon | f276ac5 | 2015-10-09 13:36:42 -0700 | [diff] [blame] | 96 | ////////////////////////////////////////////////////////////////////////////// |
| 97 | |
bsalomon | f276ac5 | 2015-10-09 13:36:42 -0700 | [diff] [blame] | 98 | GrSurfaceDesc GrImageInfoToSurfaceDesc(const SkImageInfo&); |
| 99 | |
| 100 | bool GrPixelConfig2ColorAndProfileType(GrPixelConfig, SkColorType*, SkColorProfileType*); |
| 101 | |
| 102 | /** |
bsalomon | 045802d | 2015-10-20 07:58:01 -0700 | [diff] [blame] | 103 | * If the compressed data in the SkData is supported (as a texture format, this returns |
| 104 | * the pixel-config that should be used, and sets outStartOfDataToUpload to the ptr into |
| 105 | * the data where the actual raw data starts (skipping any header bytes). |
| 106 | * |
| 107 | * If the compressed data is not supported, this returns kUnknown_GrPixelConfig, and |
| 108 | * ignores outStartOfDataToUpload. |
| 109 | */ |
bsalomon | f276ac5 | 2015-10-09 13:36:42 -0700 | [diff] [blame] | 110 | GrPixelConfig GrIsCompressedTextureDataSupported(GrContext* ctx, SkData* data, |
| 111 | int expectedW, int expectedH, |
| 112 | const void** outStartOfDataToUpload); |
| 113 | |
bsalomon | f276ac5 | 2015-10-09 13:36:42 -0700 | [diff] [blame] | 114 | |
bsalomon | 045802d | 2015-10-20 07:58:01 -0700 | [diff] [blame] | 115 | /** |
| 116 | * Creates a new texture for the bitmap. Does not concern itself with cache keys or texture params. |
| 117 | * The bitmap must have CPU-accessible pixels. Attempts to take advantage of faster paths for |
| 118 | * compressed textures and yuv planes. |
| 119 | */ |
| 120 | GrTexture* GrUploadBitmapToTexture(GrContext*, const SkBitmap&); |
bsalomon | f276ac5 | 2015-10-09 13:36:42 -0700 | [diff] [blame] | 121 | |
cblume | 55f2d2d | 2016-02-26 13:20:48 -0800 | [diff] [blame^] | 122 | GrTexture* GrGenerateMipMapsAndUploadToTexture(GrContext*, const SkBitmap&); |
| 123 | |
bsalomon | f276ac5 | 2015-10-09 13:36:42 -0700 | [diff] [blame] | 124 | ////////////////////////////////////////////////////////////////////////////// |
| 125 | |
| 126 | GR_STATIC_ASSERT((int)kZero_GrBlendCoeff == (int)SkXfermode::kZero_Coeff); |
| 127 | GR_STATIC_ASSERT((int)kOne_GrBlendCoeff == (int)SkXfermode::kOne_Coeff); |
| 128 | GR_STATIC_ASSERT((int)kSC_GrBlendCoeff == (int)SkXfermode::kSC_Coeff); |
| 129 | GR_STATIC_ASSERT((int)kISC_GrBlendCoeff == (int)SkXfermode::kISC_Coeff); |
| 130 | GR_STATIC_ASSERT((int)kDC_GrBlendCoeff == (int)SkXfermode::kDC_Coeff); |
| 131 | GR_STATIC_ASSERT((int)kIDC_GrBlendCoeff == (int)SkXfermode::kIDC_Coeff); |
| 132 | GR_STATIC_ASSERT((int)kSA_GrBlendCoeff == (int)SkXfermode::kSA_Coeff); |
| 133 | GR_STATIC_ASSERT((int)kISA_GrBlendCoeff == (int)SkXfermode::kISA_Coeff); |
| 134 | GR_STATIC_ASSERT((int)kDA_GrBlendCoeff == (int)SkXfermode::kDA_Coeff); |
| 135 | GR_STATIC_ASSERT((int)kIDA_GrBlendCoeff == (int)SkXfermode::kIDA_Coeff); |
| 136 | GR_STATIC_ASSERT(SkXfermode::kCoeffCount == 10); |
| 137 | |
| 138 | #define SkXfermodeCoeffToGrBlendCoeff(X) ((GrBlendCoeff)(X)) |
| 139 | |
reed | 8f34372 | 2015-08-13 13:32:39 -0700 | [diff] [blame] | 140 | #endif |