• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright 2013 Google Inc.
3  *
4  * Use of this source code is governed by a BSD-style license that can be
5  * found in the LICENSE file.
6  */
7 
8 #ifndef SkDecodingImageGenerator_DEFINED
9 #define SkDecodingImageGenerator_DEFINED
10 
11 #include "SkBitmap.h"
12 #include "SkImageGenerator.h"
13 
14 class SkData;
15 class SkStreamRewindable;
16 
17 /**
18  *  An implementation of SkImageGenerator that calls into
19  *  SkImageDecoder.
20  */
21 namespace SkDecodingImageGenerator {
22     /**
23      *  These options will be passed on to the image decoder.  The
24      *  defaults are sensible.
25      *
26      *  @param fSampleSize If set to > 1, tells the decoder to return a
27      *         smaller than original bitmap, sampling 1 pixel for
28      *         every size pixels. e.g. if sample size is set to 3,
29      *         then the returned bitmap will be 1/3 as wide and high,
30      *         and will contain 1/9 as many pixels as the original.
31      *         Note: this is a hint, and the codec may choose to
32      *         ignore this, or only approximate the sample size.
33      *
34      *  @param fDitherImage Set to true if the the decoder should try to
35      *         dither the resulting image when decoding to a smaller
36      *         color-space.  The default is true.
37      *
38      *  @param fRequestedColorType If not given, then use whichever
39      *         config the decoder wants.  Else try to use this color
40      *         type.  If the decoder won't support this color type,
41      *         SkDecodingImageGenerator::Create will return
42      *         NULL. kIndex_8_SkColorType is not supported.
43      *
44      *  @param fRequireUnpremul If true, the decoder will attempt to
45      *         decode without premultiplying the alpha. If it cannot,
46      *         the pixels will be set to NULL.
47      */
48     struct Options {
OptionsOptions49         Options()
50             : fSampleSize(1)
51             , fDitherImage(true)
52             , fUseRequestedColorType(false)
53             , fRequestedColorType()
54             , fRequireUnpremul(false) { }
OptionsOptions55         Options(int sampleSize, bool dither)
56             : fSampleSize(sampleSize)
57             , fDitherImage(dither)
58             , fUseRequestedColorType(false)
59             , fRequestedColorType()
60             , fRequireUnpremul(false) { }
OptionsOptions61         Options(int sampleSize, bool dither, SkColorType colorType)
62             : fSampleSize(sampleSize)
63             , fDitherImage(dither)
64             , fUseRequestedColorType(true)
65             , fRequestedColorType(colorType)
66             , fRequireUnpremul(false) { }
OptionsOptions67          Options(int sampleSize, bool dither, SkColorType colorType,
68                  bool requireUnpremul)
69             : fSampleSize(sampleSize)
70             , fDitherImage(dither)
71             , fUseRequestedColorType(true)
72             , fRequestedColorType(colorType)
73             , fRequireUnpremul(requireUnpremul) { }
74         const int         fSampleSize;
75         const bool        fDitherImage;
76         const bool        fUseRequestedColorType;
77         const SkColorType fRequestedColorType;
78         const bool        fRequireUnpremul;
79     };
80 
81     /**
82      *  These two functions return a SkImageGenerator that calls into
83      *  SkImageDecoder.  They return NULL on failure.
84      *
85      *  The SkData version of this function is preferred.  If the stream
86      *  has an underlying SkData (such as a SkMemoryStream) pass that in.
87      *
88      *  This object will unref the stream when done or on failure.  Since
89      *  streams have internal state (position), the caller should not pass
90      *  a shared stream in.  Pass either a new duplicated stream in or
91      *  transfer ownership of the stream.  This factory asserts
92      *  stream->unique().
93      *
94      *  For example:
95      *    SkStreamRewindable* stream;
96      *    ...
97      *    SkImageGenerator* gen
98      *        = SkDecodingImageGenerator::Create(
99      *            stream->duplicate(), SkDecodingImageGenerator::Options());
100      *    ...
101      *    SkDELETE(gen);
102      *
103      *  @param Options (see above)
104      *
105      *  @return NULL on failure, a new SkImageGenerator on success.
106      */
107     SkImageGenerator* Create(SkStreamRewindable* stream,
108                              const Options& opt);
109 
110     /**
111      *  @param data Contains the encoded image data that will be used by
112      *         the SkDecodingImageGenerator.  Will be ref()ed by the
113      *         SkImageGenerator constructor and and unref()ed on deletion.
114      */
115     SkImageGenerator* Create(SkData* data, const Options& opt);
116 };
117 
118 //  // Example of most basic use case:
119 //
120 //  bool install_data(SkData* data, SkBitmap* dst) {
121 //     return SkInstallDiscardablePixelRef(
122 //         SkDecodingImageGenerator::Create(
123 //             data, SkDecodingImageGenerator::Options()), dst, NULL);
124 //  }
125 //  bool install_stream(SkStreamRewindable* stream, SkBitmap* dst) {
126 //     return SkInstallDiscardablePixelRef(
127 //         SkDecodingImageGenerator::Create(
128 //             stream, SkDecodingImageGenerator::Options()), dst, NULL);
129 //  }
130 
131 #endif  // SkDecodingImageGenerator_DEFINED
132