1 /*
2  * Copyright 2017 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 #include "gm.h"
9 #include "sk_tool_utils.h"
10 #include "SkCanvas.h"
11 #include "SkImage.h"
12 #include "Resources.h"
13 #include "SkColorFilter.h"
14 
15 DEF_SIMPLE_GM(srgb_colorfilter, canvas, 512, 256*3) {
16     auto img = GetResourceAsImage("images/mandrill_256.png");
17 
18     const float array[] = {
19         1, 0, 0, 0, 0,
20         0, 1, 0, 0, 0,
21         0, 0, 1, 0, 0,
22         -1, 0, 0, 1, 0,
23     };
24     auto cf0 = SkColorFilter::MakeMatrixFilterRowMajor255(array);
25     auto cf1 = SkColorFilter::MakeLinearToSRGBGamma();
26     auto cf2 = SkColorFilter::MakeSRGBToLinearGamma();
27 
28     SkPaint p;
29     p.setColorFilter(cf0);
30     canvas->drawImage(img, 0, 0, nullptr);
31     canvas->drawImage(img, 256, 0, &p);
32 
33     p.setColorFilter(cf1);
34     canvas->drawImage(img, 0, 256, &p);
35     p.setColorFilter(SkColorFilter::MakeComposeFilter(cf1, cf0));
36     canvas->drawImage(img, 256, 256, &p);
37 
38     p.setColorFilter(cf2);
39     canvas->drawImage(img, 0, 512, &p);
40     p.setColorFilter(SkColorFilter::MakeComposeFilter(cf2, cf0));
41     canvas->drawImage(img, 256, 512, &p);
42 }
43