Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1867)

Unified Diff: gm/bitmapsource.cpp

Issue 106933002: Implement srcRect and dstRect functionality in SkBitmapSource. This is required for the "preserveAs… (Closed) Base URL: https://skia.googlecode.com/svn/trunk
Patch Set: Fix SkTileImageFilter to respect CTM, and not to request an invalid subset Created 7 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | gm/tileimagefilter.cpp » ('j') | gm/xfermodeimagefilter.cpp » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: gm/bitmapsource.cpp
diff --git a/gm/bitmapsource.cpp b/gm/bitmapsource.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..f3507eb18d18f23e3d1350d933f32679e47f2b02
--- /dev/null
+++ b/gm/bitmapsource.cpp
@@ -0,0 +1,95 @@
+/*
+ * Copyright 2013 Google Inc.
+ *
+ * Use of this source code is governed by a BSD-style license that can be
+ * found in the LICENSE file.
+ */
+
+#include "gm.h"
+
+#include "SkBitmapSource.h"
+
robertphillips 2013/12/09 16:23:01 // This GM ...?
Stephen White 2013/12/09 17:04:25 Done.
+class BitmapSourceGM : public skiagm::GM {
+public:
+ BitmapSourceGM() : fInitialized(false) {
+ }
+
+protected:
robertphillips 2013/12/09 16:23:01 override
Stephen White 2013/12/09 17:04:25 Done.
+ virtual SkString onShortName() {
+ return SkString("bitmapsource");
+ }
+
robertphillips 2013/12/09 16:23:01 makeBitmap?
Stephen White 2013/12/09 17:04:25 Done.
+ void make_bitmap() {
+ fBitmap.setConfig(SkBitmap::kARGB_8888_Config, 100, 100);
+ fBitmap.allocPixels();
+ SkBitmapDevice device(fBitmap);
+ SkCanvas canvas(&device);
+ canvas.clear(0x00000000);
+ SkPaint paint;
+ paint.setAntiAlias(true);
+ paint.setColor(0xFFFFFFFF);
+ paint.setTextSize(SkIntToScalar(96));
+ const char* str = "e";
+ canvas.drawText(str, strlen(str), SkIntToScalar(20), SkIntToScalar(70), paint);
+ }
+
robertphillips 2013/12/09 16:23:01 override
Stephen White 2013/12/09 17:04:25 Done.
+ virtual SkISize onISize() { return SkISize::Make(500, 150); }
+
robertphillips 2013/12/09 16:23:01 override
Stephen White 2013/12/09 17:04:25 Done.
+ virtual void onDraw(SkCanvas* canvas) {
robertphillips 2013/12/09 16:23:01 maybe just do this in onOnceBeforeDraw?
Stephen White 2013/12/09 17:04:25 Done.
+ if (!fInitialized) {
+ this->make_bitmap();
+ fInitialized = true;
+ }
+ canvas->clear(0x00000000);
+ {
+ SkRect srcRect = SkRect::MakeXYWH(20, 20, 30, 30);
+ SkRect dstRect = SkRect::MakeXYWH(0, 10, 60, 60);
+ SkRect clipRect = SkRect::MakeXYWH(0, 0, 100, 100);
+ SkRect bounds;
+ fBitmap.getBounds(&bounds);
+ SkAutoTUnref<SkImageFilter> bitmapSource(new SkBitmapSource(fBitmap));
+ SkAutoTUnref<SkImageFilter> bitmapSourceSrcRect(new SkBitmapSource(fBitmap, srcRect, srcRect));
+ SkAutoTUnref<SkImageFilter> bitmapSourceSrcRectDstRect(new SkBitmapSource(fBitmap, srcRect, dstRect));
+ SkAutoTUnref<SkImageFilter> bitmapSourceDstRectOnly(new SkBitmapSource(fBitmap, bounds, dstRect));
+
robertphillips 2013/12/09 16:23:01 subroutine/loop?
Stephen White 2013/12/09 17:04:25 Done.
+ SkPaint paint;
+ paint.setImageFilter(bitmapSource);
+ canvas->save();
+ canvas->clipRect(clipRect);
+ canvas->drawPaint(paint);
+ canvas->restore();
+ canvas->translate(SkIntToScalar(100), 0);
+
+ paint.setImageFilter(bitmapSourceSrcRect);
+ canvas->save();
+ canvas->clipRect(clipRect);
+ canvas->drawPaint(paint);
+ canvas->restore();
+ canvas->translate(SkIntToScalar(100), 0);
+
+ paint.setImageFilter(bitmapSourceSrcRectDstRect);
+ canvas->save();
+ canvas->clipRect(clipRect);
+ canvas->drawPaint(paint);
+ canvas->restore();
+ canvas->translate(SkIntToScalar(100), 0);
+
+ paint.setImageFilter(bitmapSourceDstRectOnly);
+ canvas->save();
+ canvas->clipRect(clipRect);
+ canvas->drawPaint(paint);
+ canvas->restore();
+ canvas->translate(SkIntToScalar(100), 0);
+ }
+ }
+
+private:
robertphillips 2013/12/09 16:23:01 micro-nit: this is supposed to go last
Stephen White 2013/12/09 17:04:25 Done.
+ typedef GM INHERITED;
+ SkBitmap fBitmap;
+ bool fInitialized;
+};
+
+///////////////////////////////////////////////////////////////////////////////
+
robertphillips 2013/12/09 16:23:01 DEF_GM
Stephen White 2013/12/09 17:04:25 Done.
+static skiagm::GM* MyFactory(void*) { return new BitmapSourceGM; }
+static skiagm::GMRegistry reg(MyFactory);
« no previous file with comments | « no previous file | gm/tileimagefilter.cpp » ('j') | gm/xfermodeimagefilter.cpp » ('J')

Powered by Google App Engine
This is Rietveld 408576698