blob: 6e5ee37926e6ad6ea25e1779bcbecd276dcd5607 [file] [log] [blame]
vandebo@chromium.org9b49dc02010-10-20 22:23:29 +00001/*
2 * Copyright (C) 2010 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef SkPDFImage_DEFINED
18#define SkPDFImage_DEFINED
19
20#include "SkPDFStream.h"
21#include "SkPDFTypes.h"
22#include "SkRefCnt.h"
23
24class SkBitmap;
25class SkPaint;
26class SkPDFCatalog;
27
28/** \class SkPDFImage
29
30 An image XObject.
31*/
32
33// We could play the same trick here as is done in SkPDFGraphicState, storing
34// a copy of the Bitmap object (not the pixels), the pixel generation number,
35// and settings used from the paint to canonicalize image objects.
36class SkPDFImage : public SkPDFObject {
37public:
38 /** Create a PDF image XObject. Entries for the image properties are
39 * automatically added to the stream dictionary.
40 * @param bitmap The image to use.
41 * @param paint Used to calculate alpha, masks, etc.
42 */
43 SkPDFImage(const SkBitmap& bitmap, const SkPaint& paint);
44 virtual ~SkPDFImage();
45
46 // The SkPDFObject interface.
47 virtual void emitObject(SkWStream* stream, SkPDFCatalog* catalog,
48 bool indirect);
49 virtual size_t getOutputSize(SkPDFCatalog* catalog, bool indirect);
50
51 /** Add the value to the stream dictionary with the given key.
52 * @param key The key for this dictionary entry.
53 * @param value The value for this dictionary entry.
54 */
55 void insert(SkPDFName* key, SkPDFObject* value);
56
57 /** Add the value to the stream dictionary with the given key.
58 * @param key The text of the key for this dictionary entry.
59 * @param value The value for this dictionary entry.
60 */
61 void insert(const char key[], SkPDFObject* value);
62
63private:
64 SkRefPtr<SkPDFStream> fStream;
65};
66
67#endif