aboutsummaryrefslogtreecommitdiffhomepage
path: root/gm/image.cpp
diff options
context:
space:
mode:
authorGravatar mike@reedtribe.org <mike@reedtribe.org@2bbb7eff-a529-9590-31e7-b0007b416f81>2012-07-31 03:57:11 +0000
committerGravatar mike@reedtribe.org <mike@reedtribe.org@2bbb7eff-a529-9590-31e7-b0007b416f81>2012-07-31 03:57:11 +0000
commitd829b5cbff1a6e149af4961f577368a6fb7c2e39 (patch)
tree3547d15b033934efc15509b75036c7f450b08db0 /gm/image.cpp
parentd2782edf0736c8c37e1075462d384342af283148 (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.cpp27
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);