Chromium Code Reviews| Index: src/pdf/SkPDFBitmap.h | 
| diff --git a/src/pdf/SkPDFBitmap.h b/src/pdf/SkPDFBitmap.h | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..a522112f8ce0ae224891e559dc1b607e7a582a30 | 
| --- /dev/null | 
| +++ b/src/pdf/SkPDFBitmap.h | 
| @@ -0,0 +1,45 @@ | 
| +/* | 
| + * Copyright 2015 Google Inc. | 
| + * | 
| + * Use of this source code is governed by a BSD-style license that can be | 
| + * found in the LICENSE file. | 
| + */ | 
| +#ifndef SkPDFBitmap_DEFINED | 
| +#define SkPDFBitmap_DEFINED | 
| + | 
| +#include "SkPDFTypes.h" | 
| +#include "SkBitmap.h" | 
| + | 
| +/** | 
| + * This is a replacement for SkPDFImage. As of now, it only supports | 
| 
 
mtklein
2015/02/12 00:21:46
Let's write this comment first as if SkPDFImage di
 
hal.canary
2015/02/12 21:28:03
Done.
 
 | 
| + * 8888 bitmaps (the most common case). This onbect takes very little | 
| 
 
mtklein
2015/02/12 00:21:46
object
 
 | 
| + * extra memory (aside from refing the bitmap's pixels), and its | 
| + * emitObject() does not cache any data. | 
| + * | 
| + * The SkPDFBitmap::Create function will check the canon for duplicates. | 
| + */ | 
| +class SkPDFBitmap : public SkPDFObject { | 
| +public: | 
| + // Returns NULL on unsupported bitmap; | 
| + // TODO(halcanary): support other bitmap colortypes and replace | 
| + // SkPDFImage. | 
| + static SkPDFBitmap* Create(const SkBitmap&, | 
| + const SkIRect& subset); | 
| 
 
mtklein
2015/02/12 00:21:46
Does passing a subset here have any different effe
 
hal.canary
2015/02/12 21:28:03
It's  only here to match the calling site.
 
 | 
| + ~SkPDFBitmap(); | 
| + void emitObject(SkWStream*, SkPDFCatalog*) SK_OVERRIDE; | 
| + void addResources(SkTSet<SkPDFObject*>* resourceSet, | 
| + SkPDFCatalog* catalog) const SK_OVERRIDE; | 
| + bool equals(const SkBitmap& other) const { | 
| + return fBitmap.getGenerationID() == other.getGenerationID() && | 
| + fBitmap.pixelRefOrigin() == other.pixelRefOrigin() && | 
| + fBitmap.dimensions() == other.dimensions() && !fIsAlpha; | 
| 
 
mtklein
2015/02/12 00:21:46
What's the deal with && !fIsAlpha?  That deserves
 
hal.canary
2015/02/12 21:28:03
When IsAlpha is true, the SkPDFBitmap represents t
 
 | 
| + } | 
| + | 
| +private: | 
| + SkBitmap fBitmap; | 
| + SkAutoTUnref<SkPDFBitmap> fSMask; | 
| + bool fIsAlpha; | 
| + SkPDFBitmap(const SkBitmap&, bool isAlpha, SkPDFBitmap* smask); | 
| +}; | 
| + | 
| +#endif // SkPDFBitmap_DEFINED |