diff options
author | raftias <raftias@google.com> | 2016-11-30 11:19:22 -0500 |
---|---|---|
committer | Skia Commit-Bot <skia-commit-bot@chromium.org> | 2016-12-01 16:22:49 +0000 |
commit | 51c3fcd376c5c9972d9476b5532f6164375a38d1 (patch) | |
tree | 550b06db1cb58caf5ec966ecaf80725fa5d74468 /src/opts/SkRasterPipeline_opts.h | |
parent | 14c8f82334b9b3b20316dc4ba4786d526c2a5012 (diff) |
Added CMYK support for ICC profiles.
Changed ICC parsing/SkGammas/SkColorLookUpTable to handle non-3-channel
inputs. Parsed CMYK A2B ICC profiles. Integrated this with SkJpegCodec
(the only file that supports CMYK) and SkColorSpaceXform_A2B to allow
parsing and color xforming of ICC CMYK images.
BUG=skia:
GOLD_TRYBOT_URL= https://gold.skia.org/search?issue=5197
CQ_INCLUDE_TRYBOTS=skia.primary:Test-Ubuntu-GCC-GCE-CPU-AVX2-x86_64-Release-SKNX_NO_SIMD
Change-Id: Id6619f63f04071f79cd2d84321857dfa269ad3aa
Reviewed-on: https://skia-review.googlesource.com/5197
Commit-Queue: Mike Klein <mtklein@chromium.org>
Reviewed-by: Matt Sarett <msarett@google.com>
Reviewed-by: Mike Klein <mtklein@chromium.org>
Reviewed-by: Leon Scroggins <scroggo@google.com>
Diffstat (limited to 'src/opts/SkRasterPipeline_opts.h')
-rw-r--r-- | src/opts/SkRasterPipeline_opts.h | 23 |
1 files changed, 15 insertions, 8 deletions
diff --git a/src/opts/SkRasterPipeline_opts.h b/src/opts/SkRasterPipeline_opts.h index ee8a9bf029..66668bd6d9 100644 --- a/src/opts/SkRasterPipeline_opts.h +++ b/src/opts/SkRasterPipeline_opts.h @@ -632,6 +632,7 @@ SI SkNf parametric(const SkNf& v, const SkColorSpaceTransferFn& p) { STAGE(parametric_r) { r = parametric(r, *(const SkColorSpaceTransferFn*)ctx); } STAGE(parametric_g) { g = parametric(g, *(const SkColorSpaceTransferFn*)ctx); } STAGE(parametric_b) { b = parametric(b, *(const SkColorSpaceTransferFn*)ctx); } +STAGE(parametric_a) { a = parametric(a, *(const SkColorSpaceTransferFn*)ctx); } SI SkNf table(const SkNf& v, const SkTableTransferFn& table) { float result[N]; @@ -643,23 +644,29 @@ SI SkNf table(const SkNf& v, const SkTableTransferFn& table) { STAGE(table_r) { r = table(r, *(const SkTableTransferFn*)ctx); } STAGE(table_g) { g = table(g, *(const SkTableTransferFn*)ctx); } STAGE(table_b) { b = table(b, *(const SkTableTransferFn*)ctx); } +STAGE(table_a) { a = table(a, *(const SkTableTransferFn*)ctx); } STAGE(color_lookup_table) { const SkColorLookUpTable* colorLUT = (const SkColorLookUpTable*)ctx; - float rgb[3]; + SkASSERT(3 == colorLUT->inputChannels() || 4 == colorLUT->inputChannels()); + SkASSERT(3 == colorLUT->outputChannels()); float result[3][N]; for (int i = 0; i < N; ++i) { - rgb[0] = r[i]; - rgb[1] = g[i]; - rgb[2] = b[i]; - colorLUT->interp3D(rgb, rgb); - result[0][i] = rgb[0]; - result[1][i] = rgb[1]; - result[2][i] = rgb[2]; + const float in[4] = { r[i], g[i], b[i], a[i] }; + float out[3]; + colorLUT->interp(out, in); + for (int j = 0; j < colorLUT->outputChannels(); ++j) { + result[j][i] = out[j]; + } } r = SkNf::Load(result[0]); g = SkNf::Load(result[1]); b = SkNf::Load(result[2]); + if (4 == colorLUT->inputChannels()) { + // we must set the pixel to opaque, as the alpha channel was used + // as input before this. + a = 1.f; + } } STAGE(lab_to_xyz) { |