diff options
author | halcanary <halcanary@google.com> | 2016-02-25 17:21:40 -0800 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2016-02-25 17:21:40 -0800 |
commit | 7363e13a07f8b6a9d4ba82ff7b13526f0a89eaee (patch) | |
tree | 1e09c3c491eb900638254bb296a3b6e7f3c3c688 | |
parent | a705641cf6bbf66a8feeb3ceddb2b45a417cebf4 (diff) |
SkPDF: Let client re-encode JPGs if they want to
GOLD_TRYBOT_URL= https://gold.skia.org/search2?unt=true&query=source_type%3Dgm&master=false&issue=1734223003
Review URL: https://codereview.chromium.org/1734223003
-rw-r--r-- | src/pdf/SkPDFBitmap.cpp | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/src/pdf/SkPDFBitmap.cpp b/src/pdf/SkPDFBitmap.cpp index 4e49db518d..e067ed1c0b 100644 --- a/src/pdf/SkPDFBitmap.cpp +++ b/src/pdf/SkPDFBitmap.cpp @@ -472,7 +472,12 @@ SkPDFObject* SkPDFCreateBitmapObject(const SkImage* image, SkPixelSerializer* pixelSerializer) { SkAutoTUnref<SkData> data(image->refEncoded()); SkJFIFInfo info; - if (data && SkIsJFIF(data, &info)) { + if (data && SkIsJFIF(data, &info) && + (!pixelSerializer || + pixelSerializer->useEncodedData(data->data(), data->size()))) { + // If there is a SkPixelSerializer, give it a chance to + // re-encode the JPEG with more compression by returning false + // from useEncodedData. bool yuv = info.fType == SkJFIFInfo::kYCbCr; if (info.fSize == image->dimensions()) { // Sanity check. // hold on to data, not image. |