diff options
author | mike@reedtribe.org <mike@reedtribe.org@2bbb7eff-a529-9590-31e7-b0007b416f81> | 2012-07-31 03:57:11 +0000 |
---|---|---|
committer | mike@reedtribe.org <mike@reedtribe.org@2bbb7eff-a529-9590-31e7-b0007b416f81> | 2012-07-31 03:57:11 +0000 |
commit | d829b5cbff1a6e149af4961f577368a6fb7c2e39 (patch) | |
tree | 3547d15b033934efc15509b75036c7f450b08db0 /gm/image.cpp | |
parent | d2782edf0736c8c37e1075462d384342af283148 (diff) |
add SkImage from encoded data
git-svn-id: http://skia.googlecode.com/svn/trunk@4845 2bbb7eff-a529-9590-31e7-b0007b416f81
Diffstat (limited to 'gm/image.cpp')
-rw-r--r-- | gm/image.cpp | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/gm/image.cpp b/gm/image.cpp index 22279563e0..3b83c02aa9 100644 --- a/gm/image.cpp +++ b/gm/image.cpp @@ -8,6 +8,31 @@ #include "gm.h" #include "SkSurface.h" #include "SkCanvas.h" +#include "SkStream.h" +#include "SkData.h" + +static SkData* fileToData(const char path[]) { + SkFILEStream stream(path); + if (!stream.isValid()) { + return SkData::NewEmpty(); + } + size_t size = stream.getLength(); + void* mem = sk_malloc_throw(size); + stream.read(mem, size); + return SkData::NewFromMalloc(mem, size); +} + +static void drawJpeg(SkCanvas* canvas, const SkISize& size) { + SkAutoDataUnref data(fileToData("/Users/mike/Downloads/skia.google.jpeg")); + SkImage* image = SkImage::NewEncodedData(data); + if (image) { + SkAutoCanvasRestore acr(canvas, true); + canvas->scale(size.width() * 1.0f / image->width(), + size.height() * 1.0f / image->height()); + image->draw(canvas,0, 0, NULL); + image->unref(); + } +} static void drawContents(SkSurface* surface, SkColor fillC) { SkSize size = SkSize::Make(surface->width(), surface->height()); @@ -80,6 +105,8 @@ protected: } virtual void onDraw(SkCanvas* canvas) { + drawJpeg(canvas, this->getISize()); + canvas->translate(10, 10); canvas->scale(2, 2); |