reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 1 | #include "SampleCode.h" |
| 2 | #include "SkView.h" |
| 3 | #include "SkCanvas.h" |
| 4 | #include "SkGradientShader.h" |
| 5 | #include "SkGraphics.h" |
| 6 | #include "SkImageDecoder.h" |
| 7 | #include "SkPath.h" |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 8 | #include "SkRegion.h" |
| 9 | #include "SkShader.h" |
| 10 | #include "SkUtils.h" |
| 11 | #include "SkXfermode.h" |
reed@android.com | da342a8 | 2008-12-23 18:37:08 +0000 | [diff] [blame] | 12 | #include "SkComposeShader.h" |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 13 | #include "SkColorPriv.h" |
| 14 | #include "SkColorFilter.h" |
| 15 | #include "SkTime.h" |
| 16 | #include "SkTransparentShader.h" |
| 17 | #include "SkTypeface.h" |
| 18 | |
| 19 | static SkShader* make_bitmapfade(const SkBitmap& bm) |
| 20 | { |
| 21 | SkPoint pts[2]; |
| 22 | SkColor colors[2]; |
| 23 | |
| 24 | pts[0].set(0, 0); |
| 25 | pts[1].set(0, SkIntToScalar(bm.height())); |
| 26 | colors[0] = SK_ColorBLACK; |
| 27 | colors[1] = SkColorSetARGB(0, 0, 0, 0); |
| 28 | SkShader* shaderA = SkGradientShader::CreateLinear(pts, colors, NULL, 2, SkShader::kClamp_TileMode); |
| 29 | |
| 30 | SkShader* shaderB = SkShader::CreateBitmapShader(bm, |
| 31 | SkShader::kClamp_TileMode, SkShader::kClamp_TileMode); |
| 32 | |
reed@android.com | 048522d | 2009-06-23 12:19:41 +0000 | [diff] [blame] | 33 | SkXfermode* mode = SkXfermode::Create(SkXfermode::kDstIn_Mode); |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 34 | |
| 35 | SkShader* shader = new SkComposeShader(shaderB, shaderA, mode); |
| 36 | shaderA->unref(); |
| 37 | shaderB->unref(); |
| 38 | mode->unref(); |
reed@google.com | 82065d6 | 2011-02-07 15:30:46 +0000 | [diff] [blame] | 39 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 40 | return shader; |
| 41 | } |
| 42 | |
mike@reedtribe.org | 5fd9243 | 2011-05-05 01:59:48 +0000 | [diff] [blame^] | 43 | class ShaderView : public SampleView { |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 44 | public: |
| 45 | SkShader* fShader; |
| 46 | SkBitmap fBitmap; |
| 47 | |
mike@reedtribe.org | 5fd9243 | 2011-05-05 01:59:48 +0000 | [diff] [blame^] | 48 | ShaderView() { |
reed@android.com | 44a6312 | 2009-05-30 02:40:28 +0000 | [diff] [blame] | 49 | SkImageDecoder::DecodeFile("/skimages/logo.gif", &fBitmap); |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 50 | |
| 51 | SkPoint pts[2]; |
| 52 | SkColor colors[2]; |
reed@google.com | 82065d6 | 2011-02-07 15:30:46 +0000 | [diff] [blame] | 53 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 54 | pts[0].set(0, 0); |
| 55 | pts[1].set(SkIntToScalar(100), 0); |
| 56 | colors[0] = SK_ColorRED; |
| 57 | colors[1] = SK_ColorBLUE; |
| 58 | SkShader* shaderA = SkGradientShader::CreateLinear(pts, colors, NULL, 2, SkShader::kClamp_TileMode); |
reed@google.com | 82065d6 | 2011-02-07 15:30:46 +0000 | [diff] [blame] | 59 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 60 | pts[0].set(0, 0); |
| 61 | pts[1].set(0, SkIntToScalar(100)); |
| 62 | colors[0] = SK_ColorBLACK; |
| 63 | colors[1] = SkColorSetARGB(0x80, 0, 0, 0); |
| 64 | SkShader* shaderB = SkGradientShader::CreateLinear(pts, colors, NULL, 2, SkShader::kClamp_TileMode); |
reed@google.com | 82065d6 | 2011-02-07 15:30:46 +0000 | [diff] [blame] | 65 | |
reed@android.com | 048522d | 2009-06-23 12:19:41 +0000 | [diff] [blame] | 66 | SkXfermode* mode = SkXfermode::Create(SkXfermode::kDstIn_Mode); |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 67 | |
| 68 | fShader = new SkComposeShader(shaderA, shaderB, mode); |
| 69 | shaderA->unref(); |
| 70 | shaderB->unref(); |
| 71 | mode->unref(); |
| 72 | } |
mike@reedtribe.org | 5fd9243 | 2011-05-05 01:59:48 +0000 | [diff] [blame^] | 73 | virtual ~ShaderView() { |
reed@google.com | 82065d6 | 2011-02-07 15:30:46 +0000 | [diff] [blame] | 74 | SkSafeUnref(fShader); |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 75 | } |
reed@google.com | 82065d6 | 2011-02-07 15:30:46 +0000 | [diff] [blame] | 76 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 77 | protected: |
| 78 | // overrides from SkEventSink |
reed@android.com | 44a6312 | 2009-05-30 02:40:28 +0000 | [diff] [blame] | 79 | virtual bool onQuery(SkEvent* evt) { |
| 80 | if (SampleCode::TitleQ(*evt)) { |
| 81 | SampleCode::TitleR(evt, "Shaders"); |
| 82 | return true; |
| 83 | } |
| 84 | return this->INHERITED::onQuery(evt); |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 85 | } |
reed@google.com | 82065d6 | 2011-02-07 15:30:46 +0000 | [diff] [blame] | 86 | |
mike@reedtribe.org | 5fd9243 | 2011-05-05 01:59:48 +0000 | [diff] [blame^] | 87 | virtual void onDrawContent(SkCanvas* canvas) { |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 88 | canvas->drawBitmap(fBitmap, 0, 0); |
reed@google.com | 82065d6 | 2011-02-07 15:30:46 +0000 | [diff] [blame] | 89 | |
reed@android.com | 44a6312 | 2009-05-30 02:40:28 +0000 | [diff] [blame] | 90 | canvas->translate(SkIntToScalar(20), SkIntToScalar(120)); |
reed@google.com | 82065d6 | 2011-02-07 15:30:46 +0000 | [diff] [blame] | 91 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 92 | SkPaint paint; |
| 93 | SkRect r; |
| 94 | |
| 95 | paint.setColor(SK_ColorGREEN); |
| 96 | canvas->drawRectCoords(0, 0, SkIntToScalar(100), SkIntToScalar(100), paint); |
| 97 | paint.setShader(fShader); |
| 98 | canvas->drawRectCoords(0, 0, SkIntToScalar(100), SkIntToScalar(100), paint); |
| 99 | |
| 100 | canvas->translate(SkIntToScalar(110), 0); |
| 101 | |
reed@android.com | 44a6312 | 2009-05-30 02:40:28 +0000 | [diff] [blame] | 102 | int w = fBitmap.width(); |
| 103 | int h = fBitmap.height(); |
| 104 | w = 120; |
| 105 | h = 80; |
| 106 | r.set(0, 0, SkIntToScalar(w), SkIntToScalar(h)); |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 107 | |
| 108 | paint.setShader(NULL); |
| 109 | canvas->drawRect(r, paint); |
| 110 | paint.setShader(make_bitmapfade(fBitmap))->unref(); |
| 111 | canvas->drawRect(r, paint); |
reed@google.com | 82065d6 | 2011-02-07 15:30:46 +0000 | [diff] [blame] | 112 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 113 | paint.setShader(new SkTransparentShader)->unref(); |
| 114 | canvas->drawRect(r, paint); |
| 115 | } |
reed@google.com | 82065d6 | 2011-02-07 15:30:46 +0000 | [diff] [blame] | 116 | |
mike@reedtribe.org | 5fd9243 | 2011-05-05 01:59:48 +0000 | [diff] [blame^] | 117 | virtual SkView::Click* onFindClickHandler(SkScalar x, SkScalar y) { |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 118 | this->inval(NULL); |
| 119 | return this->INHERITED::onFindClickHandler(x, y); |
| 120 | } |
reed@google.com | 82065d6 | 2011-02-07 15:30:46 +0000 | [diff] [blame] | 121 | |
mike@reedtribe.org | 5fd9243 | 2011-05-05 01:59:48 +0000 | [diff] [blame^] | 122 | virtual bool onClick(Click* click) { |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 123 | return this->INHERITED::onClick(click); |
| 124 | } |
reed@google.com | 82065d6 | 2011-02-07 15:30:46 +0000 | [diff] [blame] | 125 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 126 | private: |
mike@reedtribe.org | 5fd9243 | 2011-05-05 01:59:48 +0000 | [diff] [blame^] | 127 | typedef SampleView INHERITED; |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 128 | }; |
| 129 | |
| 130 | ////////////////////////////////////////////////////////////////////////////// |
| 131 | |
| 132 | static SkView* MyFactory() { return new ShaderView; } |
| 133 | static SkViewRegister reg(MyFactory); |
| 134 | |