epoger@google.com | ec3ed6a | 2011-07-28 14:26:00 +0000 | [diff] [blame] | 1 | |
| 2 | /* |
| 3 | * Copyright 2011 Google Inc. |
| 4 | * |
| 5 | * Use of this source code is governed by a BSD-style license that can be |
| 6 | * found in the LICENSE file. |
| 7 | */ |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 8 | #include "SampleCode.h" |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 9 | #include "SkCanvas.h" |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 10 | #include "SkNinePatch.h" |
| 11 | #include "SkPaint.h" |
reed@google.com | 40a3772 | 2011-09-06 18:54:54 +0000 | [diff] [blame] | 12 | #include "SkGpuDevice.h" |
| 13 | |
| 14 | static void make_bitmap(SkBitmap* bitmap, GrContext* ctx, SkIRect* center) { |
| 15 | SkDevice* dev; |
| 16 | SkCanvas canvas; |
| 17 | |
| 18 | const int kFixed = 28; |
| 19 | const int kStretchy = 8; |
| 20 | const int kSize = 2*kFixed + kStretchy; |
| 21 | |
| 22 | if (ctx) { |
| 23 | dev = new SkGpuDevice(ctx, SkBitmap::kARGB_8888_Config, kSize, kSize); |
| 24 | *bitmap = dev->accessBitmap(false); |
| 25 | } else { |
| 26 | bitmap->setConfig(SkBitmap::kARGB_8888_Config, kSize, kSize); |
| 27 | bitmap->allocPixels(); |
| 28 | dev = new SkDevice(*bitmap); |
| 29 | } |
| 30 | |
| 31 | canvas.setDevice(dev)->unref(); |
| 32 | canvas.clear(0); |
| 33 | |
| 34 | SkRect r = SkRect::MakeWH(SkIntToScalar(kSize), SkIntToScalar(kSize)); |
| 35 | const SkScalar strokeWidth = SkIntToScalar(6); |
| 36 | const SkScalar radius = SkIntToScalar(kFixed) - strokeWidth/2; |
| 37 | |
| 38 | center->setXYWH(kFixed, kFixed, kStretchy, kStretchy); |
| 39 | |
| 40 | SkPaint paint; |
| 41 | paint.setAntiAlias(true); |
| 42 | |
reed@google.com | 40a3772 | 2011-09-06 18:54:54 +0000 | [diff] [blame] | 43 | paint.setColor(0xFFFF0000); |
| 44 | canvas.drawRoundRect(r, radius, radius, paint); |
| 45 | r.setXYWH(SkIntToScalar(kFixed), 0, SkIntToScalar(kStretchy), SkIntToScalar(kSize)); |
| 46 | paint.setColor(0x8800FF00); |
| 47 | canvas.drawRect(r, paint); |
| 48 | r.setXYWH(0, SkIntToScalar(kFixed), SkIntToScalar(kSize), SkIntToScalar(kStretchy)); |
| 49 | paint.setColor(0x880000FF); |
| 50 | canvas.drawRect(r, paint); |
reed@google.com | 40a3772 | 2011-09-06 18:54:54 +0000 | [diff] [blame] | 51 | } |
| 52 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 53 | |
reed@google.com | 81e3d7f | 2011-06-01 12:42:36 +0000 | [diff] [blame] | 54 | class NinePatchView : public SampleView { |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 55 | public: |
reed@google.com | 40a3772 | 2011-09-06 18:54:54 +0000 | [diff] [blame] | 56 | NinePatchView() {} |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 57 | |
| 58 | protected: |
| 59 | // overrides from SkEventSink |
| 60 | virtual bool onQuery(SkEvent* evt) { |
| 61 | if (SampleCode::TitleQ(*evt)) { |
| 62 | SampleCode::TitleR(evt, "NinePatch"); |
| 63 | return true; |
| 64 | } |
| 65 | return this->INHERITED::onQuery(evt); |
| 66 | } |
reed@android.com | 7d970c7 | 2010-04-22 16:07:49 +0000 | [diff] [blame] | 67 | |
reed@google.com | 40a3772 | 2011-09-06 18:54:54 +0000 | [diff] [blame] | 68 | static void drawNine(SkCanvas* canvas, const SkRect& dst, const SkBitmap& bm, |
| 69 | const SkIRect& center, const SkPaint* paint) { |
| 70 | SkIRect margin; |
| 71 | margin.set(center.fLeft, center.fTop, bm.width() - center.fRight, |
| 72 | bm.height() - center.fBottom); |
| 73 | SkNinePatch::DrawNine(canvas, dst, bm, margin, paint); |
reed@android.com | 7d970c7 | 2010-04-22 16:07:49 +0000 | [diff] [blame] | 74 | } |
| 75 | |
reed@google.com | 81e3d7f | 2011-06-01 12:42:36 +0000 | [diff] [blame] | 76 | virtual void onDrawContent(SkCanvas* canvas) { |
reed@google.com | 40a3772 | 2011-09-06 18:54:54 +0000 | [diff] [blame] | 77 | SkBitmap bm; |
| 78 | SkIRect center; |
| 79 | make_bitmap(&bm, SampleCode::GetGr(), ¢er); |
reed@android.com | 7d970c7 | 2010-04-22 16:07:49 +0000 | [diff] [blame] | 80 | |
reed@google.com | 40a3772 | 2011-09-06 18:54:54 +0000 | [diff] [blame] | 81 | // amount of bm that should not be stretched (unless we have to) |
| 82 | const SkScalar fixed = SkIntToScalar(bm.width() - center.width()); |
reed@android.com | 7d970c7 | 2010-04-22 16:07:49 +0000 | [diff] [blame] | 83 | |
reed@google.com | 40a3772 | 2011-09-06 18:54:54 +0000 | [diff] [blame] | 84 | const SkTSize<SkScalar> size[] = { |
| 85 | { fixed * 4 / 5, fixed * 4 / 5 }, // shrink in both axes |
| 86 | { fixed * 4 / 5, fixed * 4 }, // shrink in X |
| 87 | { fixed * 4, fixed * 4 / 5 }, // shrink in Y |
| 88 | { fixed * 4, fixed * 4 } |
| 89 | }; |
| 90 | |
| 91 | canvas->drawBitmap(bm, SkIntToScalar(10), SkIntToScalar(10), NULL); |
| 92 | |
| 93 | SkScalar x = SkIntToScalar(100); |
| 94 | SkScalar y = SkIntToScalar(100); |
| 95 | |
reed@android.com | 7d970c7 | 2010-04-22 16:07:49 +0000 | [diff] [blame] | 96 | SkPaint paint; |
reed@google.com | 40a3772 | 2011-09-06 18:54:54 +0000 | [diff] [blame] | 97 | paint.setFilterBitmap(true); |
| 98 | |
| 99 | for (int iy = 0; iy < 2; ++iy) { |
| 100 | for (int ix = 0; ix < 2; ++ix) { |
| 101 | int i = ix * 2 + iy; |
| 102 | SkRect r = SkRect::MakeXYWH(x + ix * fixed, y + iy * fixed, |
| 103 | size[i].width(), size[i].height()); |
| 104 | drawNine(canvas, r, bm, center, &paint); |
| 105 | } |
| 106 | } |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 107 | } |
| 108 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 109 | private: |
reed@android.com | c4cae85 | 2009-09-23 15:06:10 +0000 | [diff] [blame] | 110 | SkScalar fX, fY; |
reed@google.com | 81e3d7f | 2011-06-01 12:42:36 +0000 | [diff] [blame] | 111 | typedef SampleView INHERITED; |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 112 | }; |
| 113 | |
| 114 | ////////////////////////////////////////////////////////////////////////////// |
| 115 | |
| 116 | static SkView* MyFactory() { return new NinePatchView; } |
| 117 | static SkViewRegister reg(MyFactory); |
| 118 | |