Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright 2015 Google Inc. | 2 * Copyright 2015 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 "SkColorPriv.h" | 8 #include "SkColorPriv.h" |
| 9 #include "SkData.h" | 9 #include "SkData.h" |
| 10 #include "SkDeflate.h" | 10 #include "SkDeflate.h" |
| (...skipping 364 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 375 stream->writeStream(asset.get(), asset->getLength()); | 375 stream->writeStream(asset.get(), asset->getLength()); |
| 376 pdf_stream_end(stream); | 376 pdf_stream_end(stream); |
| 377 } | 377 } |
| 378 | 378 |
| 379 //////////////////////////////////////////////////////////////////////////////// | 379 //////////////////////////////////////////////////////////////////////////////// |
| 380 | 380 |
| 381 namespace { | 381 namespace { |
| 382 // This SkPDFObject only outputs the alpha layer of the given bitmap. | 382 // This SkPDFObject only outputs the alpha layer of the given bitmap. |
| 383 class PDFAlphaBitmap final : public SkPDFObject { | 383 class PDFAlphaBitmap final : public SkPDFObject { |
| 384 public: | 384 public: |
| 385 PDFAlphaBitmap(const SkImage* image) : fImage(SkRef(image)) {} | 385 PDFAlphaBitmap(const SkImage* image) : fImage(SkRef(image)) { SkASSERT(image ); } |
|
tomhudson
2016/03/18 13:59:38
You don't want to do the force-to-be-nonnull-by-pa
hal.canary
2016/03/18 21:18:07
We rarely ever refer to SkImage types by reference
| |
| 386 ~PDFAlphaBitmap() {} | 386 ~PDFAlphaBitmap() {} |
|
tomhudson
2016/03/18 13:59:38
Since the base class has virtual functions, do we
hal.canary
2016/03/18 21:18:07
it's a final class
tomhudson
2016/03/21 13:54:30
This assertion is not sufficient for me to evaluat
mtklein
2016/03/21 14:11:15
Marking a class final prevents subclassing and als
| |
| 387 void emitObject(SkWStream* stream, | 387 void emitObject(SkWStream* stream, |
| 388 const SkPDFObjNumMap& objNumMap, | 388 const SkPDFObjNumMap& objNumMap, |
| 389 const SkPDFSubstituteMap& subs) const override { | 389 const SkPDFSubstituteMap& subs) const override { |
| 390 SkASSERT(fImage); | |
| 390 emit_image_xobject(stream, fImage.get(), true, nullptr, objNumMap, subs) ; | 391 emit_image_xobject(stream, fImage.get(), true, nullptr, objNumMap, subs) ; |
| 391 } | 392 } |
| 393 void dump() override { fImage = nullptr; } | |
| 392 | 394 |
| 393 private: | 395 private: |
| 394 sk_sp<const SkImage> fImage; | 396 sk_sp<const SkImage> fImage; |
| 395 }; | 397 }; |
| 396 | 398 |
| 397 } // namespace | 399 } // namespace |
| 398 | 400 |
| 399 //////////////////////////////////////////////////////////////////////////////// | 401 //////////////////////////////////////////////////////////////////////////////// |
| 400 | 402 |
| 401 namespace { | 403 namespace { |
| 402 class PDFDefaultBitmap final : public SkPDFObject { | 404 class PDFDefaultBitmap final : public SkPDFObject { |
| 403 public: | 405 public: |
| 404 void emitObject(SkWStream* stream, | 406 void emitObject(SkWStream* stream, |
| 405 const SkPDFObjNumMap& objNumMap, | 407 const SkPDFObjNumMap& objNumMap, |
| 406 const SkPDFSubstituteMap& subs) const override { | 408 const SkPDFSubstituteMap& subs) const override { |
| 409 SkASSERT(fImage); | |
| 407 emit_image_xobject(stream, fImage.get(), false, fSMask, objNumMap, subs) ; | 410 emit_image_xobject(stream, fImage.get(), false, fSMask, objNumMap, subs) ; |
| 408 } | 411 } |
| 409 void addResources(SkPDFObjNumMap* catalog, | 412 void addResources(SkPDFObjNumMap* catalog, |
| 410 const SkPDFSubstituteMap& subs) const override { | 413 const SkPDFSubstituteMap& subs) const override { |
| 414 SkASSERT(fImage); | |
| 411 if (fSMask.get()) { | 415 if (fSMask.get()) { |
| 412 SkPDFObject* obj = subs.getSubstitute(fSMask.get()); | 416 SkPDFObject* obj = subs.getSubstitute(fSMask.get()); |
| 413 SkASSERT(obj); | 417 SkASSERT(obj); |
| 414 catalog->addObjectRecursively(obj, subs); | 418 catalog->addObjectRecursively(obj, subs); |
| 415 } | 419 } |
| 416 } | 420 } |
| 421 void dump() override { fImage = nullptr; fSMask = nullptr; } | |
| 417 PDFDefaultBitmap(const SkImage* image, SkPDFObject* smask) | 422 PDFDefaultBitmap(const SkImage* image, SkPDFObject* smask) |
| 418 : fImage(SkRef(image)), fSMask(smask) {} | 423 : fImage(SkRef(image)), fSMask(smask) { SkASSERT(fImage); } |
|
tomhudson
2016/03/18 13:59:38
No destructor; do we need one since we've got virt
hal.canary
2016/03/18 21:18:07
it's a final class.
mtklein
2016/03/21 14:11:14
(No _explicit_ destructor. There is an implicitly
| |
| 419 | 424 |
| 420 private: | 425 private: |
| 421 sk_sp<const SkImage> fImage; | 426 sk_sp<const SkImage> fImage; |
| 422 const sk_sp<SkPDFObject> fSMask; | 427 sk_sp<SkPDFObject> fSMask; |
| 423 }; | 428 }; |
| 424 } // namespace | 429 } // namespace |
| 425 | 430 |
| 426 //////////////////////////////////////////////////////////////////////////////// | 431 //////////////////////////////////////////////////////////////////////////////// |
| 427 | 432 |
| 428 namespace { | 433 namespace { |
| 429 /** | 434 /** |
| 430 * This PDFObject assumes that its constructor was handed YUV or | 435 * This PDFObject assumes that its constructor was handed YUV or |
| 431 * Grayscale JFIF Jpeg-encoded data that can be directly embedded | 436 * Grayscale JFIF Jpeg-encoded data that can be directly embedded |
| 432 * into a PDF. | 437 * into a PDF. |
| 433 */ | 438 */ |
| 434 class PDFJpegBitmap final : public SkPDFObject { | 439 class PDFJpegBitmap final : public SkPDFObject { |
| 435 public: | 440 public: |
| 436 SkISize fSize; | 441 SkISize fSize; |
| 437 sk_sp<SkData> fData; | 442 sk_sp<SkData> fData; |
| 438 bool fIsYUV; | 443 bool fIsYUV; |
| 439 PDFJpegBitmap(SkISize size, SkData* data, bool isYUV) | 444 PDFJpegBitmap(SkISize size, SkData* data, bool isYUV) |
| 440 : fSize(size), fData(SkRef(data)), fIsYUV(isYUV) {} | 445 : fSize(size), fData(SkRef(data)), fIsYUV(isYUV) { SkASSERT(data); } |
| 441 void emitObject(SkWStream*, | 446 void emitObject(SkWStream*, |
| 442 const SkPDFObjNumMap&, | 447 const SkPDFObjNumMap&, |
| 443 const SkPDFSubstituteMap&) const override; | 448 const SkPDFSubstituteMap&) const override; |
| 449 void dump() override { fData = nullptr; } | |
| 444 }; | 450 }; |
| 445 | 451 |
| 446 void PDFJpegBitmap::emitObject(SkWStream* stream, | 452 void PDFJpegBitmap::emitObject(SkWStream* stream, |
| 447 const SkPDFObjNumMap& objNumMap, | 453 const SkPDFObjNumMap& objNumMap, |
| 448 const SkPDFSubstituteMap& substituteMap) const { | 454 const SkPDFSubstituteMap& substituteMap) const { |
| 455 SkASSERT(fData); | |
| 449 SkPDFDict pdfDict("XObject"); | 456 SkPDFDict pdfDict("XObject"); |
| 450 pdfDict.insertName("Subtype", "Image"); | 457 pdfDict.insertName("Subtype", "Image"); |
| 451 pdfDict.insertInt("Width", fSize.width()); | 458 pdfDict.insertInt("Width", fSize.width()); |
| 452 pdfDict.insertInt("Height", fSize.height()); | 459 pdfDict.insertInt("Height", fSize.height()); |
| 453 if (fIsYUV) { | 460 if (fIsYUV) { |
| 454 pdfDict.insertName("ColorSpace", "DeviceRGB"); | 461 pdfDict.insertName("ColorSpace", "DeviceRGB"); |
| 455 } else { | 462 } else { |
| 456 pdfDict.insertName("ColorSpace", "DeviceGray"); | 463 pdfDict.insertName("ColorSpace", "DeviceGray"); |
| 457 } | 464 } |
| 458 pdfDict.insertInt("BitsPerComponent", 8); | 465 pdfDict.insertInt("BitsPerComponent", 8); |
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 502 } | 509 } |
| 503 } | 510 } |
| 504 | 511 |
| 505 SkPDFObject* smask = | 512 SkPDFObject* smask = |
| 506 image_compute_is_opaque(image) ? nullptr : new PDFAlphaBitmap(image) ; | 513 image_compute_is_opaque(image) ? nullptr : new PDFAlphaBitmap(image) ; |
| 507 #ifdef SK_PDF_IMAGE_STATS | 514 #ifdef SK_PDF_IMAGE_STATS |
| 508 gRegularImageObjects.fetch_add(1); | 515 gRegularImageObjects.fetch_add(1); |
| 509 #endif | 516 #endif |
| 510 return new PDFDefaultBitmap(image, smask); | 517 return new PDFDefaultBitmap(image, smask); |
| 511 } | 518 } |
| OLD | NEW |