xref: /aosp_15_r20/external/skia/src/gpu/ganesh/GrColorSpaceXform.h (revision c8dee2aa9b3f27cf6c858bd81872bdeb2c07ed17)
1 /*
2  * Copyright 2016 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 GrColorSpaceXform_DEFINED
9 #define GrColorSpaceXform_DEFINED
10 
11 #include "include/core/SkColor.h"
12 #include "include/core/SkRefCnt.h"
13 #include "include/private/SkColorData.h"
14 #include "src/core/SkColorSpaceXformSteps.h"
15 #include "src/gpu/ganesh/GrFragmentProcessor.h"
16 
17 #include <cstdint>
18 #include <memory>
19 
20 class GrColorInfo;
21 class SkColorSpace;
22 enum SkAlphaType : int;
23 struct GrShaderCaps;
24 
25 namespace skgpu { class KeyBuilder; }
26 
27  /**
28   * Represents a color space transformation
29   */
30 class GrColorSpaceXform : public SkRefCnt {
31 public:
GrColorSpaceXform(const SkColorSpaceXformSteps & steps)32     GrColorSpaceXform(const SkColorSpaceXformSteps& steps) : fSteps(steps) {}
33 
34     static sk_sp<GrColorSpaceXform> Make(SkColorSpace* src, SkAlphaType srcAT,
35                                          SkColorSpace* dst, SkAlphaType dstAT);
36 
37     static sk_sp<GrColorSpaceXform> Make(const GrColorInfo& srcInfo, const GrColorInfo& dstInfo);
38 
steps()39     const SkColorSpaceXformSteps& steps() const { return fSteps; }
40 
41     /**
42      * GrFragmentProcessor::addToKey() must call this and include the returned value in its
43      * computed key.
44      */
45     static uint32_t XformKey(const GrColorSpaceXform* xform);
46 
47     static bool Equals(const GrColorSpaceXform* a, const GrColorSpaceXform* b);
48 
49     SkColor4f apply(const SkColor4f& srcColor);
50 
51 private:
52     friend class GrGLSLColorSpaceXformHelper;
53 
54     SkColorSpaceXformSteps fSteps;
55 };
56 
57 class GrColorSpaceXformEffect : public GrFragmentProcessor {
58 public:
59     /**
60      *  Returns a fragment processor that calls the passed in fragment processor, and then converts
61      *  the color space of the output from src to dst. If the child is null, fInputColor is used.
62      */
63     static std::unique_ptr<GrFragmentProcessor> Make(std::unique_ptr<GrFragmentProcessor> child,
64                                                      SkColorSpace* src, SkAlphaType srcAT,
65                                                      SkColorSpace* dst, SkAlphaType dstAT);
66     static std::unique_ptr<GrFragmentProcessor> Make(std::unique_ptr<GrFragmentProcessor> child,
67                                                      const GrColorInfo& srcInfo,
68                                                      const GrColorInfo& dstInfo);
69 
70     /**
71      * Returns a fragment processor that calls the passed in FP and then converts it with the given
72      * color xform. If the child is null, fInputColor is used. Returns child as-is if the xform is
73      * null (i.e. a no-op).
74      */
75     static std::unique_ptr<GrFragmentProcessor> Make(std::unique_ptr<GrFragmentProcessor> child,
76                                                      sk_sp<GrColorSpaceXform> colorXform);
77 
name()78     const char* name() const override { return "ColorSpaceXform"; }
79     std::unique_ptr<GrFragmentProcessor> clone() const override;
80 
colorXform()81     const GrColorSpaceXform* colorXform() const { return fColorXform.get(); }
82 
83 private:
84     GrColorSpaceXformEffect(std::unique_ptr<GrFragmentProcessor> child,
85                             sk_sp<GrColorSpaceXform> colorXform);
86 
87     GrColorSpaceXformEffect(const GrColorSpaceXformEffect& that);
88 
89     static OptimizationFlags OptFlags(const GrFragmentProcessor* child);
90     SkPMColor4f constantOutputForConstantInput(const SkPMColor4f& input) const override;
91 
92     std::unique_ptr<ProgramImpl> onMakeProgramImpl() const override;
93     void onAddToKey(const GrShaderCaps&, skgpu::KeyBuilder*) const override;
94     bool onIsEqual(const GrFragmentProcessor&) const override;
95 
96     sk_sp<GrColorSpaceXform> fColorXform;
97 
98     using INHERITED = GrFragmentProcessor;
99 };
100 
101 #endif
102