diff options
author | Brian Osman <brianosman@google.com> | 2018-07-12 14:44:27 -0400 |
---|---|---|
committer | Skia Commit-Bot <skia-commit-bot@chromium.org> | 2018-07-12 20:54:14 +0000 |
commit | b62f50cf763279fa0d0aa2f80624de02c7a1c2fb (patch) | |
tree | a4aba5466ff7e3136bd97c35718a678354b430ea /src/images/SkJpegEncoder.cpp | |
parent | 5bc4fc8f3f26e9e14cccee4d200309e4b500b8d3 (diff) |
Replace nearly all kRespect with kIgnore
- Encoders and decoders always assume kIgnore.
- They are less opinionated about F16 and color space,
we just trust the color space that's passed in, and
put that directly in the image (no sRGB encoding).
- SkBitmap and SkPixmap read/write pixels functions were
defaulting to kResepct, those are now always kIgnore.
- Many other bits of plumbing are simplified, and I
added a default of kIgnore to SkImage::makeColorSpace,
so we can phase out that argument entirely.
- Still need to add defaults to other public APIs that
take SkTransferFunctionBehavior.
- This makes gold think that we've dramatically changed
the contents of all F16 images, but that's because
it doesn't understand the (now linear) color space
that's embedded. Once we triage them all once, they
will work fine (and they'll look perfect in the browser).
Bug: skia:
Change-Id: I62fa090f96cae1b67d181ce14bd91f34ff2ed747
Reviewed-on: https://skia-review.googlesource.com/140570
Commit-Queue: Brian Osman <brianosman@google.com>
Reviewed-by: Mike Klein <mtklein@google.com>
Diffstat (limited to 'src/images/SkJpegEncoder.cpp')
-rw-r--r-- | src/images/SkJpegEncoder.cpp | 13 |
1 files changed, 2 insertions, 11 deletions
diff --git a/src/images/SkJpegEncoder.cpp b/src/images/SkJpegEncoder.cpp index 9c139f707b..1c1fb15e2e 100644 --- a/src/images/SkJpegEncoder.cpp +++ b/src/images/SkJpegEncoder.cpp @@ -74,15 +74,7 @@ bool SkJpegEncoderMgr::setParams(const SkImageInfo& srcInfo, const SkJpegEncoder return (transform_scanline_proc) nullptr; } - // Note that kRespect mode is only supported with sRGB or linear transfer functions. - // The legacy code path is incidentally correct when the transfer function is linear. - const bool isSRGBTransferFn = srcInfo.gammaCloseToSRGB() && - (SkTransferFunctionBehavior::kRespect == options.fBlendBehavior); - if (isSRGBTransferFn) { - return transform_scanline_to_premul_linear; - } else { - return transform_scanline_to_premul_legacy; - } + return transform_scanline_to_premul_legacy; }; J_COLOR_SPACE jpegColorType = JCS_EXT_RGBA; @@ -118,8 +110,7 @@ bool SkJpegEncoderMgr::setParams(const SkImageInfo& srcInfo, const SkJpegEncoder numComponents = 1; break; case kRGBA_F16_SkColorType: - if (!srcInfo.colorSpace() || - SkTransferFunctionBehavior::kRespect != options.fBlendBehavior) { + if (!srcInfo.colorSpace()) { return false; } |