| Index: src/image/SkImage_Codec.cpp | 
| diff --git a/src/image/SkImage_Codec.cpp b/src/image/SkImage_Codec.cpp | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..21c844d01dd331b0f4235f215fc11ad494fb84bf | 
| --- /dev/null | 
| +++ b/src/image/SkImage_Codec.cpp | 
| @@ -0,0 +1,80 @@ | 
| +/* | 
| + * Copyright 2012 Google Inc. | 
| + * | 
| + * Use of this source code is governed by a BSD-style license that can be | 
| + * found in the LICENSE file. | 
| + */ | 
| + | 
| +#include "SkImageDecoder.h" | 
| +#include "SkImage_Base.h" | 
| +#include "SkBitmap.h" | 
| +#include "SkCanvas.h" | 
| +#include "SkData.h" | 
| + | 
| +class SkImage_Codec : public SkImage_Base { | 
| +public: | 
| +    static SkImage* NewEmpty(); | 
| + | 
| +    SkImage_Codec(SkData* encodedData, int width, int height); | 
| +    virtual ~SkImage_Codec(); | 
| + | 
| +    virtual void onDraw(SkCanvas*, SkScalar, SkScalar, const SkPaint*) const SK_OVERRIDE; | 
| +    virtual void onDrawRectToRect(SkCanvas*, const SkRect*, const SkRect&, | 
| +                                  const SkPaint*) const SK_OVERRIDE; | 
| + | 
| +private: | 
| +    SkData*     fEncodedData; | 
| +    SkBitmap    fBitmap; | 
| + | 
| +    typedef SkImage_Base INHERITED; | 
| +}; | 
| + | 
| +/////////////////////////////////////////////////////////////////////////////// | 
| + | 
| +SkImage_Codec::SkImage_Codec(SkData* data, int width, int height) : INHERITED(width, height) { | 
| +    fEncodedData = data; | 
| +    fEncodedData->ref(); | 
| +} | 
| + | 
| +SkImage_Codec::~SkImage_Codec() { | 
| +    fEncodedData->unref(); | 
| +} | 
| + | 
| +void SkImage_Codec::onDraw(SkCanvas* canvas, SkScalar x, SkScalar y, const SkPaint* paint) const { | 
| +    if (!fBitmap.pixelRef()) { | 
| +        // todo: this needs to be thread-safe | 
| +        SkBitmap* bitmap = const_cast<SkBitmap*>(&fBitmap); | 
| +        if (!SkImageDecoder::DecodeMemory(fEncodedData->bytes(), fEncodedData->size(), bitmap)) { | 
| +            return; | 
| +        } | 
| +    } | 
| +    canvas->drawBitmap(fBitmap, x, y, paint); | 
| +} | 
| + | 
| +void SkImage_Codec::onDrawRectToRect(SkCanvas* canvas, const SkRect* src, const SkRect& dst, | 
| +                                     const SkPaint* paint) const { | 
| +    if (!fBitmap.pixelRef()) { | 
| +        // todo: this needs to be thread-safe | 
| +        SkBitmap* bitmap = const_cast<SkBitmap*>(&fBitmap); | 
| +        if (!SkImageDecoder::DecodeMemory(fEncodedData->bytes(), fEncodedData->size(), bitmap)) { | 
| +            return; | 
| +        } | 
| +    } | 
| +    canvas->drawBitmapRectToRect(fBitmap, src, dst, paint); | 
| +} | 
| + | 
| +/////////////////////////////////////////////////////////////////////////////// | 
| + | 
| +SkImage* SkImage::NewEncodedData(SkData* data) { | 
| +    if (NULL == data) { | 
| +        return NULL; | 
| +    } | 
| + | 
| +    SkBitmap bitmap; | 
| +    if (!SkImageDecoder::DecodeMemory(data->bytes(), data->size(), &bitmap, kUnknown_SkColorType, | 
| +                                      SkImageDecoder::kDecodeBounds_Mode)) { | 
| +        return NULL; | 
| +    } | 
| + | 
| +    return SkNEW_ARGS(SkImage_Codec, (data, bitmap.width(), bitmap.height())); | 
| +} | 
|  |