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 "SkAtomics.h" | 8 #include "SkAtomics.h" |
9 #include "SkColorSpace.h" | 9 #include "SkColorSpace.h" |
10 #include "SkColorSpacePriv.h" | 10 #include "SkColorSpacePriv.h" |
(...skipping 585 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
596 bool load_matrix(SkMatrix44* toXYZ, const uint8_t* src, size_t len) { | 596 bool load_matrix(SkMatrix44* toXYZ, const uint8_t* src, size_t len) { |
597 if (len < 48) { | 597 if (len < 48) { |
598 SkColorSpacePrintf("Matrix tag is too small (%d bytes).", len); | 598 SkColorSpacePrintf("Matrix tag is too small (%d bytes).", len); |
599 return false; | 599 return false; |
600 } | 600 } |
601 | 601 |
602 float array[16]; | 602 float array[16]; |
603 array[ 0] = SkFixedToFloat(read_big_endian_int(src)); | 603 array[ 0] = SkFixedToFloat(read_big_endian_int(src)); |
604 array[ 1] = SkFixedToFloat(read_big_endian_int(src + 4)); | 604 array[ 1] = SkFixedToFloat(read_big_endian_int(src + 4)); |
605 array[ 2] = SkFixedToFloat(read_big_endian_int(src + 8)); | 605 array[ 2] = SkFixedToFloat(read_big_endian_int(src + 8)); |
606 array[ 3] = 0; | 606 array[ 3] = SkFixedToFloat(read_big_endian_int(src + 36)); // translate R |
607 array[ 4] = SkFixedToFloat(read_big_endian_int(src + 12)); | 607 array[ 4] = SkFixedToFloat(read_big_endian_int(src + 12)); |
608 array[ 5] = SkFixedToFloat(read_big_endian_int(src + 16)); | 608 array[ 5] = SkFixedToFloat(read_big_endian_int(src + 16)); |
609 array[ 6] = SkFixedToFloat(read_big_endian_int(src + 20)); | 609 array[ 6] = SkFixedToFloat(read_big_endian_int(src + 20)); |
610 array[ 7] = 0; | 610 array[ 7] = SkFixedToFloat(read_big_endian_int(src + 40)); // translate G |
611 array[ 8] = SkFixedToFloat(read_big_endian_int(src + 24)); | 611 array[ 8] = SkFixedToFloat(read_big_endian_int(src + 24)); |
612 array[ 9] = SkFixedToFloat(read_big_endian_int(src + 28)); | 612 array[ 9] = SkFixedToFloat(read_big_endian_int(src + 28)); |
613 array[10] = SkFixedToFloat(read_big_endian_int(src + 32)); | 613 array[10] = SkFixedToFloat(read_big_endian_int(src + 32)); |
614 array[11] = 0; | 614 array[11] = SkFixedToFloat(read_big_endian_int(src + 44)); // translate B |
615 array[12] = SkFixedToFloat(read_big_endian_int(src + 36)); // translate R | 615 array[12] = 0.0f; |
616 array[13] = SkFixedToFloat(read_big_endian_int(src + 40)); // translate G | 616 array[13] = 0.0f; |
617 array[14] = SkFixedToFloat(read_big_endian_int(src + 44)); | 617 array[14] = 0.0f; |
618 array[15] = 1; | 618 array[15] = 1.0f; |
619 toXYZ->setColMajorf(array); | 619 toXYZ->setColMajorf(array); |
620 return true; | 620 return true; |
621 } | 621 } |
622 | 622 |
623 bool SkColorSpace::LoadA2B0(SkColorLookUpTable* colorLUT, SkGammaCurve* gammas,
SkMatrix44* toXYZ, | 623 bool SkColorSpace::LoadA2B0(SkColorLookUpTable* colorLUT, SkGammaCurve* gammas,
SkMatrix44* toXYZ, |
624 const uint8_t* src, size_t len) { | 624 const uint8_t* src, size_t len) { |
625 if (len < 32) { | 625 if (len < 32) { |
626 SkColorSpacePrintf("A to B tag is too small (%d bytes).", len); | 626 SkColorSpacePrintf("A to B tag is too small (%d bytes).", len); |
627 return false; | 627 return false; |
628 } | 628 } |
(...skipping 179 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
808 } | 808 } |
809 } | 809 } |
810 | 810 |
811 } | 811 } |
812 default: | 812 default: |
813 break; | 813 break; |
814 } | 814 } |
815 | 815 |
816 return_null("ICC profile contains unsupported colorspace"); | 816 return_null("ICC profile contains unsupported colorspace"); |
817 } | 817 } |
OLD | NEW |