blob: eb98b010d7e4c9e9bcf5bc29a15c995609da93a9 [file] [log] [blame]
msarettc0444612016-09-16 11:45:58 -07001/*
Matt Sarett4c550272017-03-20 19:06:18 -04002 * Copyright 2016 Google Inc.
msarettc0444612016-09-16 11:45:58 -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
8#include "gm.h"
9#include "SkColor.h"
Matt Sarett4c550272017-03-20 19:06:18 -040010#include "SkColorSpace_Base.h"
msarettc0444612016-09-16 11:45:58 -070011#include "SkColorSpaceXform.h"
12#include "SkRect.h"
Florin Malitaab244f02017-05-03 19:16:58 +000013#include "SkShader.h"
msarettc0444612016-09-16 11:45:58 -070014
15class ColorSpaceXformGM : public skiagm::GM {
16public:
17 ColorSpaceXformGM() {}
18
19protected:
20 void onOnceBeforeDraw() override {
21 SkColor colors[] = {
22 SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorMAGENTA, SK_ColorCYAN, SK_ColorYELLOW,
23 SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorMAGENTA,
24 };
25 static_assert(kNumColors == SK_ARRAY_COUNT(colors), "Fix number of colors.");
26
27 for (int i = 0; i < kNumColors; i++) {
28 fSRGBColors[i] = SkColor4f::FromColor(colors[i]);
msarettc0444612016-09-16 11:45:58 -070029 }
30
31 static constexpr float kWideGamutRGB_toXYZD50[]{
32 0.7161046f, 0.1009296f, 0.1471858f,
33 0.2581874f, 0.7249378f, 0.0168748f,
34 0.0000000f, 0.0517813f, 0.7734287f,
35 };
36
37 SkMatrix44 wideGamut(SkMatrix44::kUninitialized_Constructor);
38 wideGamut.set3x3RowMajorf(kWideGamutRGB_toXYZD50);
msarett4be0e7c2016-09-22 07:02:24 -070039
Matt Sarett4c550272017-03-20 19:06:18 -040040 // Test BGRA input.
Matt Sarett77a7a1b2017-02-07 13:56:11 -050041 sk_sp<SkColorSpace> srcSpace = SkColorSpace::MakeSRGB();
msarett4be0e7c2016-09-22 07:02:24 -070042 sk_sp<SkColorSpace> dstSpace =
Brian Osman526972e2016-10-24 09:24:02 -040043 SkColorSpace::MakeRGB(SkColorSpace::kLinear_RenderTargetGamma, wideGamut);
msarett4be0e7c2016-09-22 07:02:24 -070044 std::unique_ptr<SkColorSpaceXform> xform = SkColorSpaceXform::New(srcSpace.get(),
45 dstSpace.get());
Matt Sarett4c550272017-03-20 19:06:18 -040046 xform->apply(SkColorSpaceXform::kRGBA_F32_ColorFormat, fWideGamutColors0,
msarett31d097e82016-10-11 12:15:03 -070047 SkColorSpaceXform::kBGRA_8888_ColorFormat, colors, kNumColors,
48 kOpaque_SkAlphaType);
Matt Sarett4c550272017-03-20 19:06:18 -040049
50 // Test F32 input.
51 srcSpace = as_CSB(srcSpace)->makeLinearGamma();
52 xform = SkColorSpaceXform::New(srcSpace.get(), dstSpace.get());
53 xform->apply(SkColorSpaceXform::kRGBA_F32_ColorFormat, fWideGamutColors1,
54 SkColorSpaceXform::kRGBA_F32_ColorFormat, fSRGBColors, kNumColors,
55 kOpaque_SkAlphaType);
msarettc0444612016-09-16 11:45:58 -070056 }
57
58 SkString onShortName() override {
59 return SkString("colorspacexform");
60 }
61
62 SkISize onISize() override {
Matt Sarett4c550272017-03-20 19:06:18 -040063 return SkISize::Make(500, 300);
msarettc0444612016-09-16 11:45:58 -070064 }
65
66 void onDraw(SkCanvas* canvas) override {
67 auto drawColors = [canvas](SkColor4f* colors) {
68 SkRect r = SkRect::MakeXYWH(0.0f, 0.0f, 50.0f, 100.0f);
69
70 canvas->save();
71 for (int i = 0; i < kNumColors; i++) {
Matt Sarett77a7a1b2017-02-07 13:56:11 -050072 auto space = SkColorSpace::MakeSRGBLinear();
msarettc0444612016-09-16 11:45:58 -070073 sk_sp<SkShader> s = SkShader::MakeColorShader(colors[i], space);
74 SkPaint paint;
75 paint.setShader(s);
76 canvas->drawRect(r, paint);
77 canvas->translate(50.0f, 0.0f);
78 }
79 canvas->restore();
80 };
81
82 // Wide gamut colors should appear darker - we are simulating a more intense display.
83 drawColors(fSRGBColors);
84 canvas->translate(0.0f, 100.0f);
Matt Sarett4c550272017-03-20 19:06:18 -040085 drawColors(fWideGamutColors0);
86 canvas->translate(0.0f, 100.0f);
87 drawColors(fWideGamutColors1);
msarettc0444612016-09-16 11:45:58 -070088 }
89
90private:
91 static constexpr int kNumColors = 10;
92
93 SkColor4f fSRGBColors[kNumColors];
Matt Sarett4c550272017-03-20 19:06:18 -040094 SkColor4f fWideGamutColors0[kNumColors];
95 SkColor4f fWideGamutColors1[kNumColors];
msarettc0444612016-09-16 11:45:58 -070096
97 typedef skiagm::GM INHERITED;
98};
99
100DEF_GM(return new ColorSpaceXformGM;)