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 |