Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(55)

Side by Side Diff: include/gpu/effects/GrPorterDuffXferProcessor.h

Issue 1471053002: Don't create a GXPFactory when blend is SrcOver (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: nit Created 5 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright 2014 Google Inc. 2 * Copyright 2014 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 #ifndef GrPorterDuffXferProcessor_DEFINED 8 #ifndef GrPorterDuffXferProcessor_DEFINED
9 #define GrPorterDuffXferProcessor_DEFINED 9 #define GrPorterDuffXferProcessor_DEFINED
10 10
11 #include "GrTypes.h" 11 #include "GrTypes.h"
12 #include "GrXferProcessor.h" 12 #include "GrXferProcessor.h"
13 #include "SkXfermode.h" 13 #include "SkXfermode.h"
14 14
15 class GrProcOptInfo; 15 class GrProcOptInfo;
16 16
17 class GrPorterDuffXPFactory : public GrXPFactory { 17 class GrPorterDuffXPFactory : public GrXPFactory {
18 public: 18 public:
19 static GrXPFactory* Create(SkXfermode::Mode mode);
20
21 bool supportsRGBCoverage(GrColor /*knownColor*/, uint32_t /*knownColorFlags* /) const override {
22 return true;
23 }
24
25 void getInvariantBlendedColor(const GrProcOptInfo& colorPOI, 19 void getInvariantBlendedColor(const GrProcOptInfo& colorPOI,
26 GrXPFactory::InvariantBlendedColor*) const ove rride; 20 GrXPFactory::InvariantBlendedColor*) const ove rride;
27 21
28 private: 22 private:
29 GrPorterDuffXPFactory(SkXfermode::Mode); 23 GrPorterDuffXPFactory(SkXfermode::Mode);
30 24
25 static GrXPFactory* InternalCreate(SkXfermode::Mode mode);
26
27 public:
28 static inline GrXPFactory* Create(SkXfermode::Mode mode) {
29 if (SkXfermode::kSrc_Mode == mode) {
egdaniel 2015/11/23 20:10:15 Since Src is our second most common blend mode, an
bsalomon 2015/11/23 20:19:51 second most common in real content? My instinct is
egdaniel 2015/11/23 20:49:04 removed
30 static GrPorterDuffXPFactory gSrcPDXPF(SkXfermode::kSrc_Mode);
31 return SkRef(&gSrcPDXPF);
32 }
33 return InternalCreate(mode);
34 }
35
36 private:
31 GrXferProcessor* onCreateXferProcessor(const GrCaps& caps, 37 GrXferProcessor* onCreateXferProcessor(const GrCaps& caps,
32 const GrProcOptInfo& colorPOI, 38 const GrProcOptInfo& colorPOI,
33 const GrProcOptInfo& coveragePOI, 39 const GrProcOptInfo& coveragePOI,
34 bool hasMixedSamples, 40 bool hasMixedSamples,
35 const DstTexture*) const override; 41 const DstTexture*) const override;
36 42
37 bool willReadDstColor(const GrCaps& caps, 43 bool willReadDstColor(const GrCaps& caps,
38 const GrProcOptInfo& colorPOI, 44 const GrProcOptInfo& colorPOI,
39 const GrProcOptInfo& coveragePOI, 45 const GrProcOptInfo& coveragePOI,
40 bool hasMixedSamples) const override; 46 bool hasMixedSamples) const override;
41 47
42 bool onIsEqual(const GrXPFactory& xpfBase) const override { 48 bool onIsEqual(const GrXPFactory& xpfBase) const override {
43 const GrPorterDuffXPFactory& xpf = xpfBase.cast<GrPorterDuffXPFactory>() ; 49 const GrPorterDuffXPFactory& xpf = xpfBase.cast<GrPorterDuffXPFactory>() ;
44 return fXfermode == xpf.fXfermode; 50 return fXfermode == xpf.fXfermode;
45 } 51 }
46 52
47 GR_DECLARE_XP_FACTORY_TEST; 53 GR_DECLARE_XP_FACTORY_TEST;
48 static void TestGetXPOutputTypes(const GrXferProcessor*, int* outPrimary, in t* outSecondary); 54 static void TestGetXPOutputTypes(const GrXferProcessor*, int* outPrimary, in t* outSecondary);
49 55
50 SkXfermode::Mode fXfermode; 56 SkXfermode::Mode fXfermode;
51 57
52 friend class GrPorterDuffTest; // for TestGetXPOutputTypes() 58 friend class GrPorterDuffTest; // for TestGetXPOutputTypes()
53 typedef GrXPFactory INHERITED; 59 typedef GrXPFactory INHERITED;
54 }; 60 };
55 61
62 GrXferProcessor* GrCreateSrcOverXferProcessor(const GrCaps& caps,
bsalomon 2015/11/23 20:19:51 Should this be GrPorterDuffXPFactory::CreateSrcOve
egdaniel 2015/11/23 20:49:04 Done.
63 const GrProcOptInfo& colorPOI,
64 const GrProcOptInfo& coveragePOI,
65 bool hasMixedSamples,
66 const GrXferProcessor::DstTexture* );
67
68 inline void GrSrcOverInvariantBlendedColor(GrColor inputColor,
69 GrColorComponentFlags validColorFlags ,
70 bool isOpaque,
71 GrXPFactory::InvariantBlendedColor* b lendedColor) {
72 if (!isOpaque) {
73 blendedColor->fWillBlendWithDst = true;
74 blendedColor->fKnownColorFlags = kNone_GrColorComponentFlags;
75 return;
76 }
77 blendedColor->fWillBlendWithDst = false;
78
79 blendedColor->fKnownColor = inputColor;
80 blendedColor->fKnownColorFlags = validColorFlags;
81 }
82
83 bool GrSrcOverWillNeedDstTexture(const GrCaps& caps,
84 const GrProcOptInfo& colorPOI,
85 const GrProcOptInfo& coveragePOI,
86 bool hasMixedSamples);
87
56 #endif 88 #endif
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698