OLD | NEW |
1 | 1 |
2 /* | 2 /* |
3 * Copyright 2006 The Android Open Source Project | 3 * Copyright 2006 The Android Open Source Project |
4 * | 4 * |
5 * Use of this source code is governed by a BSD-style license that can be | 5 * Use of this source code is governed by a BSD-style license that can be |
6 * found in the LICENSE file. | 6 * found in the LICENSE file. |
7 */ | 7 */ |
8 | 8 |
9 | 9 |
10 #include "SkXfermode.h" | 10 #include "SkXfermode.h" |
(...skipping 450 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
461 setSaturationComponents(g, b, r, s); | 461 setSaturationComponents(g, b, r, s); |
462 } else { | 462 } else { |
463 setSaturationComponents(b, g, r, s); | 463 setSaturationComponents(b, g, r, s); |
464 } | 464 } |
465 } | 465 } |
466 | 466 |
467 static inline void clipColor(int* r, int* g, int* b, int a) { | 467 static inline void clipColor(int* r, int* g, int* b, int a) { |
468 int L = Lum(*r, *g, *b); | 468 int L = Lum(*r, *g, *b); |
469 int n = minimum(*r, *g, *b); | 469 int n = minimum(*r, *g, *b); |
470 int x = maximum(*r, *g, *b); | 470 int x = maximum(*r, *g, *b); |
471 if(n < 0) { | 471 int denom; |
472 *r = L + SkMulDiv(*r - L, L, L - n); | 472 if ((n < 0) && (denom = L - n)) { // Compute denom and make sure it's non ze
ro |
473 *g = L + SkMulDiv(*g - L, L, L - n); | 473 *r = L + SkMulDiv(*r - L, L, denom); |
474 *b = L + SkMulDiv(*b - L, L, L - n); | 474 *g = L + SkMulDiv(*g - L, L, denom); |
| 475 *b = L + SkMulDiv(*b - L, L, denom); |
475 } | 476 } |
476 | 477 |
477 if (x > a) { | 478 if ((x > a) && (denom = x - L)) { // Compute denom and make sure it's non ze
ro |
478 *r = L + SkMulDiv(*r - L, a - L, x - L); | 479 int numer = a - L; |
479 *g = L + SkMulDiv(*g - L, a - L, x - L); | 480 *r = L + SkMulDiv(*r - L, numer, denom); |
480 *b = L + SkMulDiv(*b - L, a - L, x - L); | 481 *g = L + SkMulDiv(*g - L, numer, denom); |
| 482 *b = L + SkMulDiv(*b - L, numer, denom); |
481 } | 483 } |
482 } | 484 } |
483 | 485 |
484 static inline void SetLum(int* r, int* g, int* b, int a, int l) { | 486 static inline void SetLum(int* r, int* g, int* b, int a, int l) { |
485 int d = l - Lum(*r, *g, *b); | 487 int d = l - Lum(*r, *g, *b); |
486 *r += d; | 488 *r += d; |
487 *g += d; | 489 *g += d; |
488 *b += d; | 490 *b += d; |
489 | 491 |
490 clipColor(r, g, b, a); | 492 clipColor(r, g, b, a); |
(...skipping 1477 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1968 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_START(SkXfermode) | 1970 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_START(SkXfermode) |
1969 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkProcCoeffXfermode) | 1971 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkProcCoeffXfermode) |
1970 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkClearXfermode) | 1972 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkClearXfermode) |
1971 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkSrcXfermode) | 1973 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkSrcXfermode) |
1972 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkDstInXfermode) | 1974 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkDstInXfermode) |
1973 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkDstOutXfermode) | 1975 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkDstOutXfermode) |
1974 #if !SK_ARM_NEON_IS_NONE | 1976 #if !SK_ARM_NEON_IS_NONE |
1975 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkNEONProcCoeffXfermode) | 1977 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkNEONProcCoeffXfermode) |
1976 #endif | 1978 #endif |
1977 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_END | 1979 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_END |
OLD | NEW |