1 /* 2 * Copyright 2011 Google Inc. 3 * 4 * Use of this source code is governed by a BSD-style license that can be 5 * found in the LICENSE file. 6 */ 7 8 #include "gm.h" 9 #include "SkCanvas.h" 10 #include "SkPath.h" 11 12 /** Draw a 2px border around the target, then red behind the target; 13 set the clip to match the target, then draw >> the target in blue. 14 */ 15 16 static void draw(SkCanvas* canvas, SkRect& target, int x, int y) { 17 SkPaint borderPaint; 18 borderPaint.setColor(SkColorSetRGB(0x0, 0xDD, 0x0)); 19 borderPaint.setAntiAlias(true); 20 SkPaint backgroundPaint; 21 backgroundPaint.setColor(SkColorSetRGB(0xDD, 0x0, 0x0)); 22 backgroundPaint.setAntiAlias(true); 23 SkPaint foregroundPaint; 24 foregroundPaint.setColor(SkColorSetRGB(0x0, 0x0, 0xDD)); 25 foregroundPaint.setAntiAlias(true); 26 27 canvas->save(); 28 canvas->translate(SkIntToScalar(x), SkIntToScalar(y)); 29 target.inset(SkIntToScalar(-2), SkIntToScalar(-2)); 30 canvas->drawRect(target, borderPaint); 31 target.inset(SkIntToScalar(2), SkIntToScalar(2)); 32 canvas->drawRect(target, backgroundPaint); 33 canvas->clipRect(target, SkRegion::kIntersect_Op, true); 34 target.inset(SkIntToScalar(-4), SkIntToScalar(-4)); 35 canvas->drawRect(target, foregroundPaint); 36 canvas->restore(); 37 } 38 39 static void draw_square(SkCanvas* canvas, int x, int y) { 40 SkRect target (SkRect::MakeWH(10 * SK_Scalar1, 10 * SK_Scalar1)); 41 draw(canvas, target, x, y); 42 } 43 44 static void draw_column(SkCanvas* canvas, int x, int y) { 45 SkRect target (SkRect::MakeWH(1 * SK_Scalar1, 10 * SK_Scalar1)); 46 draw(canvas, target, x, y); 47 } 48 49 static void draw_bar(SkCanvas* canvas, int x, int y) { 50 SkRect target (SkRect::MakeWH(10 * SK_Scalar1, 1 * SK_Scalar1)); 51 draw(canvas, target, x, y); 52 } 53 54 static void draw_rect_tests(SkCanvas* canvas) { 55 draw_square(canvas, 10, 10); 56 draw_column(canvas, 30, 10); 57 draw_bar(canvas, 10, 30); 58 } 59 60 /** 61 Test a set of clipping problems discovered while writing blitAntiRect, 62 and test all the code paths through the clipping blitters. 63 Each region should show as a blue center surrounded by a 2px green 64 border, with no red. 65 */ 66 67 class AAClipGM : public skiagm::GM { 68 public: 69 AAClipGM() { 70 71 } 72 73 protected: 74 virtual SkString onShortName() SK_OVERRIDE { 75 return SkString("aaclip"); 76 } 77 78 virtual SkISize onISize() SK_OVERRIDE { 79 return SkISize::Make(240, 120); 80 } 81 82 virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE { 83 // Initial pixel-boundary-aligned draw 84 draw_rect_tests(canvas); 85 86 // Repeat 4x with .2, .4, .6, .8 px offsets 87 canvas->translate(SK_Scalar1 / 5, SK_Scalar1 / 5); 88 canvas->translate(SkIntToScalar(50), 0); 89 draw_rect_tests(canvas); 90 91 canvas->translate(SK_Scalar1 / 5, SK_Scalar1 / 5); 92 canvas->translate(SkIntToScalar(50), 0); 93 draw_rect_tests(canvas); 94 95 canvas->translate(SK_Scalar1 / 5, SK_Scalar1 / 5); 96 canvas->translate(SkIntToScalar(50), 0); 97 draw_rect_tests(canvas); 98 99 canvas->translate(SK_Scalar1 / 5, SK_Scalar1 / 5); 100 canvas->translate(SkIntToScalar(50), 0); 101 draw_rect_tests(canvas); 102 } 103 104 virtual uint32_t onGetFlags() const { return kSkipPipe_Flag; } 105 106 private: 107 typedef skiagm::GM INHERITED; 108 }; 109 110 DEF_GM( return SkNEW(AAClipGM); ) 111 112 ///////////////////////////////////////////////////////////////////////// 113 114 #ifdef SK_BUILD_FOR_MAC 115 116 static SkCanvas* make_canvas(const SkBitmap& bm) { 117 const SkImageInfo& info = bm.info(); 118 if (info.bytesPerPixel() == 4) { 119 return SkCanvas::NewRasterDirectN32(info.width(), info.height(), 120 (SkPMColor*)bm.getPixels(), 121 bm.rowBytes()); 122 } else { 123 return SkNEW_ARGS(SkCanvas, (bm)); 124 } 125 } 126 127 #include "SkCGUtils.h" 128 static void test_image(SkCanvas* canvas, const SkImageInfo& info) { 129 SkBitmap bm; 130 bm.allocPixels(info); 131 132 SkAutoTUnref<SkCanvas> newc(make_canvas(bm)); 133 if (info.isOpaque()) { 134 bm.eraseColor(SK_ColorGREEN); 135 } else { 136 bm.eraseColor(0); 137 } 138 139 SkPaint paint; 140 paint.setAntiAlias(true); 141 paint.setColor(SK_ColorBLUE); 142 newc->drawCircle(50, 50, 49, paint); 143 canvas->drawBitmap(bm, 10, 10); 144 145 CGImageRef image = SkCreateCGImageRefWithColorspace(bm, NULL); 146 147 SkBitmap bm2; 148 SkCreateBitmapFromCGImage(&bm2, image); 149 CGImageRelease(image); 150 151 canvas->drawBitmap(bm2, 10, 120); 152 } 153 154 class CGImageGM : public skiagm::GM { 155 public: 156 CGImageGM() {} 157 158 protected: 159 virtual SkString onShortName() SK_OVERRIDE { 160 return SkString("cgimage"); 161 } 162 163 virtual SkISize onISize() SK_OVERRIDE { 164 return SkISize::Make(800, 250); 165 } 166 167 virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE { 168 const struct { 169 SkColorType fCT; 170 SkAlphaType fAT; 171 } rec[] = { 172 { kRGB_565_SkColorType, kOpaque_SkAlphaType }, 173 174 { kRGBA_8888_SkColorType, kPremul_SkAlphaType }, 175 { kRGBA_8888_SkColorType, kUnpremul_SkAlphaType }, 176 { kRGBA_8888_SkColorType, kOpaque_SkAlphaType }, 177 178 { kBGRA_8888_SkColorType, kPremul_SkAlphaType }, 179 { kBGRA_8888_SkColorType, kUnpremul_SkAlphaType }, 180 { kBGRA_8888_SkColorType, kOpaque_SkAlphaType }, 181 }; 182 183 for (size_t i = 0; i < SK_ARRAY_COUNT(rec); ++i) { 184 SkImageInfo info = SkImageInfo::Make(100, 100, rec[i].fCT, rec[i].fAT); 185 test_image(canvas, info); 186 canvas->translate(info.width() + 10, 0); 187 } 188 } 189 190 virtual uint32_t onGetFlags() const SK_OVERRIDE { return kSkipPipe_Flag; } 191 192 private: 193 typedef skiagm::GM INHERITED; 194 }; 195 196 #if 0 // Disabled pending fix from reed@ 197 DEF_GM( return SkNEW(CGImageGM); ) 198 #endif 199 #endif 200