| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2016 Google Inc. | 2 * Copyright 2016 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 #include "Resources.h" | 8 #include "Resources.h" |
| 9 #include "SkCodec.h" | 9 #include "SkCodec.h" |
| 10 #include "SkColorPriv.h" | 10 #include "SkColorPriv.h" |
| (...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 106 } | 106 } |
| 107 | 107 |
| 108 DEF_TEST(ColorSpaceXform_ExponentialGamma, r) { | 108 DEF_TEST(ColorSpaceXform_ExponentialGamma, r) { |
| 109 // Exponential gamma curves | 109 // Exponential gamma curves |
| 110 sk_sp<SkGammas> gammas = sk_sp<SkGammas>(new SkGammas()); | 110 sk_sp<SkGammas> gammas = sk_sp<SkGammas>(new SkGammas()); |
| 111 gammas->fRedType = gammas->fGreenType = gammas->fBlueType = SkGammas::Type::
kValue_Type; | 111 gammas->fRedType = gammas->fGreenType = gammas->fBlueType = SkGammas::Type::
kValue_Type; |
| 112 gammas->fRedData.fValue = gammas->fGreenData.fValue = gammas->fBlueData.fVal
ue = 1.4f; | 112 gammas->fRedData.fValue = gammas->fGreenData.fValue = gammas->fBlueData.fVal
ue = 1.4f; |
| 113 test_identity_xform(r, gammas); | 113 test_identity_xform(r, gammas); |
| 114 } | 114 } |
| 115 | 115 |
| 116 DEF_TEST(ColorSpaceXform_NamedGamma, r) { |
| 117 sk_sp<SkGammas> gammas = sk_sp<SkGammas>(new SkGammas()); |
| 118 gammas->fRedType = gammas->fGreenType = gammas->fBlueType = SkGammas::Type::
kNamed_Type; |
| 119 gammas->fRedData.fNamed = kSRGB_SkGammaNamed; |
| 120 gammas->fGreenData.fNamed = k2Dot2Curve_SkGammaNamed; |
| 121 gammas->fBlueData.fNamed = kLinear_SkGammaNamed; |
| 122 test_identity_xform(r, gammas); |
| 123 } |
| 124 |
| 116 DEF_TEST(ColorSpaceXform_NonMatchingGamma, r) { | 125 DEF_TEST(ColorSpaceXform_NonMatchingGamma, r) { |
| 117 constexpr size_t tableSize = 10; | 126 constexpr size_t tableSize = 10; |
| 118 void* memory = sk_malloc_throw(sizeof(SkGammas) + sizeof(float) * tableSize
+ | 127 void* memory = sk_malloc_throw(sizeof(SkGammas) + sizeof(float) * tableSize
+ |
| 119 sizeof(SkGammas::Params)); | 128 sizeof(SkGammas::Params)); |
| 120 sk_sp<SkGammas> gammas = sk_sp<SkGammas>(new (memory) SkGammas()); | 129 sk_sp<SkGammas> gammas = sk_sp<SkGammas>(new (memory) SkGammas()); |
| 121 | 130 |
| 122 float* table = SkTAddOffset<float>(memory, sizeof(SkGammas)); | 131 float* table = SkTAddOffset<float>(memory, sizeof(SkGammas)); |
| 123 table[0] = 0.00f; | 132 table[0] = 0.00f; |
| 124 table[1] = 0.15f; | 133 table[1] = 0.15f; |
| 125 table[2] = 0.20f; | 134 table[2] = 0.20f; |
| (...skipping 20 matching lines...) Expand all Loading... |
| 146 | 155 |
| 147 gammas->fGreenType = SkGammas::Type::kTable_Type; | 156 gammas->fGreenType = SkGammas::Type::kTable_Type; |
| 148 gammas->fGreenData.fTable.fSize = tableSize; | 157 gammas->fGreenData.fTable.fSize = tableSize; |
| 149 gammas->fGreenData.fTable.fOffset = 0; | 158 gammas->fGreenData.fTable.fOffset = 0; |
| 150 | 159 |
| 151 gammas->fBlueType = SkGammas::Type::kParam_Type; | 160 gammas->fBlueType = SkGammas::Type::kParam_Type; |
| 152 gammas->fBlueData.fParamOffset = sizeof(float) * tableSize; | 161 gammas->fBlueData.fParamOffset = sizeof(float) * tableSize; |
| 153 | 162 |
| 154 test_identity_xform(r, gammas); | 163 test_identity_xform(r, gammas); |
| 155 } | 164 } |
| OLD | NEW |