blob: 6fed7e1761017b4ef5f8e492b3bf731025dfff09 [file] [log] [blame]
joshualitt4eaf9ce2015-04-28 13:31:18 -07001/*
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 GrTestUtils_DEFINED
9#define GrTestUtils_DEFINED
10
joshualitt3f655f32015-04-29 10:01:22 -070011#include "SkTypes.h"
12
13#ifdef GR_TEST_UTILS
14
joshualitt4eaf9ce2015-04-28 13:31:18 -070015#include "GrColor.h"
16#include "SkRandom.h"
joshualitt21279c72015-05-11 07:21:37 -070017#include "SkStrokeRec.h"
joshualitt4eaf9ce2015-04-28 13:31:18 -070018
19class SkMatrix;
joshualitt40ded322015-05-02 07:07:17 -070020class SkPath;
joshualitt3e708c52015-04-30 13:49:27 -070021class SkRRect;
joshualitt3f655f32015-04-29 10:01:22 -070022struct SkRect;
joshualitt4eaf9ce2015-04-28 13:31:18 -070023
24namespace GrTest {
25/**
26 * A helper for use in Test functions.
27 */
28const SkMatrix& TestMatrix(SkRandom*);
joshualittfa2008f2015-04-29 11:32:05 -070029const SkMatrix& TestMatrixPreservesRightAngles(SkRandom*);
joshualitt3e708c52015-04-30 13:49:27 -070030const SkMatrix& TestMatrixRectStaysRect(SkRandom*);
joshualitt2fbd4062015-05-07 13:06:41 -070031const SkMatrix& TestMatrixInvertible(SkRandom*);
joshualitt3f655f32015-04-29 10:01:22 -070032const SkRect& TestRect(SkRandom*);
joshualitt6c891102015-05-13 08:51:49 -070033const SkRect& TestSquare(SkRandom*);
joshualitt3e708c52015-04-30 13:49:27 -070034const SkRRect& TestRRectSimple(SkRandom*);
joshualitt40ded322015-05-02 07:07:17 -070035const SkPath& TestPath(SkRandom*);
joshualitt8e5c1772015-05-11 08:58:52 -070036const SkPath& TestPathConvex(SkRandom*);
joshualitt21279c72015-05-11 07:21:37 -070037SkStrokeRec TestStrokeRec(SkRandom*);
joshualitt4eaf9ce2015-04-28 13:31:18 -070038
39}
40
41static inline GrColor GrRandomColor(SkRandom* random) {
42 // There are only a few cases of random colors which interest us
43 enum ColorMode {
44 kAllOnes_ColorMode,
45 kAllZeros_ColorMode,
46 kAlphaOne_ColorMode,
47 kRandom_ColorMode,
48 kLast_ColorMode = kRandom_ColorMode
49 };
50
51 ColorMode colorMode = ColorMode(random->nextULessThan(kLast_ColorMode + 1));
52 GrColor color;
53 switch (colorMode) {
54 case kAllOnes_ColorMode:
55 color = GrColorPackRGBA(0xFF, 0xFF, 0xFF, 0xFF);
56 break;
57 case kAllZeros_ColorMode:
58 color = GrColorPackRGBA(0, 0, 0, 0);
59 break;
60 case kAlphaOne_ColorMode:
61 color = GrColorPackRGBA(random->nextULessThan(256),
62 random->nextULessThan(256),
63 random->nextULessThan(256),
64 0xFF);
65 break;
joshualitt3f655f32015-04-29 10:01:22 -070066 case kRandom_ColorMode: {
67 uint8_t alpha = random->nextULessThan(256);
68 color = GrColorPackRGBA(random->nextRangeU(0, alpha),
69 random->nextRangeU(0, alpha),
70 random->nextRangeU(0, alpha),
71 alpha);
joshualitt4eaf9ce2015-04-28 13:31:18 -070072 break;
joshualitt3f655f32015-04-29 10:01:22 -070073 }
joshualitt4eaf9ce2015-04-28 13:31:18 -070074 }
75 GrColorIsPMAssert(color);
76 return color;
77}
78
79static inline uint8_t GrRandomCoverage(SkRandom* random) {
80 enum CoverageMode {
81 kZero_CoverageMode,
82 kAllOnes_CoverageMode,
83 kRandom_CoverageMode,
84 kLast_CoverageMode = kRandom_CoverageMode
85 };
86
87 CoverageMode colorMode = CoverageMode(random->nextULessThan(kLast_CoverageMode + 1));
88 uint8_t coverage;
89 switch (colorMode) {
90 case kZero_CoverageMode:
91 coverage = 0;
92 case kAllOnes_CoverageMode:
93 coverage = 0xff;
94 break;
95 case kRandom_CoverageMode:
96 coverage = random->nextULessThan(256);
97 break;
98 }
99 return coverage;
100}
101
102#endif
joshualitt3f655f32015-04-29 10:01:22 -0700103#endif