Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright 2014 Google Inc. | 2 * Copyright 2014 Google Inc. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
| 5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
| 6 */ | 6 */ |
| 7 | 7 |
| 8 #include "sk_surface.h" | 8 #include "sk_surface.h" |
| 9 | 9 |
| 10 #include "SkCanvas.h" | 10 #include "SkCanvas.h" |
| 11 #include "SkImage.h" | 11 #include "SkImage.h" |
| 12 #include "SkMatrix.h" | 12 #include "SkMatrix.h" |
| 13 #include "SkPaint.h" | 13 #include "SkPaint.h" |
| 14 #include "SkPath.h" | 14 #include "SkPath.h" |
| 15 #include "SkSurface.h" | 15 #include "SkSurface.h" |
| 16 | 16 |
| 17 static SkImageInfo make(const sk_imageinfo_t& cinfo) { | 17 static SkImageInfo make(const sk_imageinfo_t& cinfo) { |
| 18 return SkImageInfo::Make(cinfo.width, cinfo.height, | 18 return SkImageInfo::Make(cinfo.width, cinfo.height, |
| 19 (SkColorType)cinfo.colorType, (SkAlphaType)cinfo.al phaType); | 19 (SkColorType)cinfo.colorType, (SkAlphaType)cinfo.al phaType); |
| 20 } | 20 } |
| 21 | 21 |
| 22 static const SkRect& AsRect(const sk_rect_t& crect) { | 22 static const SkRect& AsRect(const sk_rect_t& crect) { |
| 23 return reinterpret_cast<const SkRect&>(crect); | 23 return reinterpret_cast<const SkRect&>(crect); |
| 24 } | 24 } |
| 25 | 25 |
| 26 static const SkPath& AsPath(const sk_path_t& cpath) { | 26 static const SkPath& AsPath(const sk_path_t& cpath) { |
| 27 return reinterpret_cast<const SkPath&>(cpath); | 27 return reinterpret_cast<const SkPath&>(cpath); |
| 28 } | 28 } |
| 29 | 29 |
| 30 static SkPath* as_path(sk_path_t* cpath) { | |
| 31 return reinterpret_cast<SkPath*>(cpath); | |
| 32 } | |
| 33 | |
| 34 static const SkPath* as_path(const sk_path_t* cpath) { | |
|
reed1
2014/10/08 12:12:46
do we need this one? if so, can it take/return a r
robertphillips
2014/10/08 12:56:18
Apparently it is not needed, I've removed it.
| |
| 35 return reinterpret_cast<const SkPath*>(cpath); | |
| 36 } | |
| 37 | |
| 30 static const SkImage* AsImage(const sk_image_t* cimage) { | 38 static const SkImage* AsImage(const sk_image_t* cimage) { |
| 31 return reinterpret_cast<const SkImage*>(cimage); | 39 return reinterpret_cast<const SkImage*>(cimage); |
| 32 } | 40 } |
| 33 | 41 |
| 34 static const SkPaint& AsPaint(const sk_paint_t& cpaint) { | 42 static const SkPaint& AsPaint(const sk_paint_t& cpaint) { |
| 35 return reinterpret_cast<const SkPaint&>(cpaint); | 43 return reinterpret_cast<const SkPaint&>(cpaint); |
| 36 } | 44 } |
| 37 | 45 |
| 38 static const SkPaint* AsPaint(const sk_paint_t* cpaint) { | 46 static const SkPaint* AsPaint(const sk_paint_t* cpaint) { |
| 39 return reinterpret_cast<const SkPaint*>(cpaint); | 47 return reinterpret_cast<const SkPaint*>(cpaint); |
| (...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 95 sk_color_t sk_paint_get_color(const sk_paint_t* cpaint) { | 103 sk_color_t sk_paint_get_color(const sk_paint_t* cpaint) { |
| 96 return AsPaint(*cpaint).getColor(); | 104 return AsPaint(*cpaint).getColor(); |
| 97 } | 105 } |
| 98 | 106 |
| 99 void sk_paint_set_color(sk_paint_t* cpaint, sk_color_t c) { | 107 void sk_paint_set_color(sk_paint_t* cpaint, sk_color_t c) { |
| 100 AsPaint(cpaint)->setColor(c); | 108 AsPaint(cpaint)->setColor(c); |
| 101 } | 109 } |
| 102 | 110 |
| 103 //////////////////////////////////////////////////////////////////////////////// /////////// | 111 //////////////////////////////////////////////////////////////////////////////// /////////// |
| 104 | 112 |
| 113 sk_path_t* sk_path_new() { | |
| 114 return (sk_path_t*)SkNEW(SkPath); | |
| 115 } | |
| 116 | |
| 117 void sk_path_delete(sk_path_t* cpath) { | |
| 118 SkDELETE(as_path(cpath)); | |
| 119 } | |
| 120 | |
| 121 void sk_path_move_to(sk_path_t* cpath, float x, float y) { | |
| 122 as_path(cpath)->moveTo(x, y); | |
| 123 } | |
| 124 | |
| 125 void sk_path_line_to(sk_path_t* cpath, float x, float y) { | |
| 126 as_path(cpath)->lineTo(x, y); | |
| 127 } | |
| 128 | |
| 129 void sk_path_quad_to(sk_path_t* cpath, float x0, float y0, float x1, float y1) { | |
| 130 as_path(cpath)->quadTo(x0, y0, x1, y1); | |
| 131 } | |
| 132 | |
| 133 void sk_path_close(sk_path_t* cpath) { | |
| 134 as_path(cpath)->close(); | |
| 135 } | |
| 136 | |
| 137 //////////////////////////////////////////////////////////////////////////////// /////////// | |
| 138 | |
| 105 void sk_canvas_save(sk_canvas_t* ccanvas) { | 139 void sk_canvas_save(sk_canvas_t* ccanvas) { |
| 106 AsCanvas(ccanvas)->save(); | 140 AsCanvas(ccanvas)->save(); |
| 107 } | 141 } |
| 108 | 142 |
| 109 void sk_canvas_save_layer(sk_canvas_t* ccanvas, const sk_rect_t* crect, const sk _paint_t* cpaint) { | 143 void sk_canvas_save_layer(sk_canvas_t* ccanvas, const sk_rect_t* crect, const sk _paint_t* cpaint) { |
| 110 AsCanvas(ccanvas)->drawRect(AsRect(*crect), AsPaint(*cpaint)); | 144 AsCanvas(ccanvas)->drawRect(AsRect(*crect), AsPaint(*cpaint)); |
| 111 } | 145 } |
| 112 | 146 |
| 113 void sk_canvas_restore(sk_canvas_t* ccanvas) { | 147 void sk_canvas_restore(sk_canvas_t* ccanvas) { |
| 114 AsCanvas(ccanvas)->restore(); | 148 AsCanvas(ccanvas)->restore(); |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 146 //////////////////////////////////////////////////////////////////////////////// /////////// | 180 //////////////////////////////////////////////////////////////////////////////// /////////// |
| 147 | 181 |
| 148 sk_surface_t* sk_surface_new_raster(const sk_imageinfo_t* cinfo) { | 182 sk_surface_t* sk_surface_new_raster(const sk_imageinfo_t* cinfo) { |
| 149 return (sk_surface_t*)SkSurface::NewRaster(make(*cinfo)); | 183 return (sk_surface_t*)SkSurface::NewRaster(make(*cinfo)); |
| 150 } | 184 } |
| 151 | 185 |
| 152 sk_surface_t* sk_surface_new_raster_direct(const sk_imageinfo_t* cinfo, void* pi xels, | 186 sk_surface_t* sk_surface_new_raster_direct(const sk_imageinfo_t* cinfo, void* pi xels, |
| 153 size_t rowBytes) { | 187 size_t rowBytes) { |
| 154 return (sk_surface_t*)SkSurface::NewRasterDirect(make(*cinfo), pixels, rowBy tes); | 188 return (sk_surface_t*)SkSurface::NewRasterDirect(make(*cinfo), pixels, rowBy tes); |
| 155 } | 189 } |
| 156 | 190 |
|
robertphillips
2014/10/07 18:20:09
It seems a bit funky to call this delete but unref
reed1
2014/10/08 12:12:46
Yea, trying to be conservative in exposing when so
| |
| 157 void sk_surface_delete(sk_surface_t* csurf) { | 191 void sk_surface_delete(sk_surface_t* csurf) { |
| 158 SkSurface* surf = (SkSurface*)csurf; | 192 SkSurface* surf = (SkSurface*)csurf; |
| 159 SkSafeUnref(surf); | 193 SkSafeUnref(surf); |
| 160 } | 194 } |
| 161 | 195 |
| 162 sk_canvas_t* sk_surface_get_canvas(sk_surface_t* csurf) { | 196 sk_canvas_t* sk_surface_get_canvas(sk_surface_t* csurf) { |
| 163 SkSurface* surf = (SkSurface*)csurf; | 197 SkSurface* surf = (SkSurface*)csurf; |
| 164 return (sk_canvas_t*)surf->getCanvas(); | 198 return (sk_canvas_t*)surf->getCanvas(); |
| 165 } | 199 } |
| 166 | 200 |
| (...skipping 22 matching lines...) Expand all Loading... | |
| 189 sk_rect_t cr = { 5, 5, 95, 95 }; | 223 sk_rect_t cr = { 5, 5, 95, 95 }; |
| 190 sk_canvas_draw_oval(ccanvas, &cr, cpaint); | 224 sk_canvas_draw_oval(ccanvas, &cr, cpaint); |
| 191 | 225 |
| 192 cr.left += 25; | 226 cr.left += 25; |
| 193 cr.top += 25; | 227 cr.top += 25; |
| 194 cr.right -= 25; | 228 cr.right -= 25; |
| 195 cr.bottom -= 25; | 229 cr.bottom -= 25; |
| 196 sk_paint_set_color(cpaint, 0xFF00FF00); | 230 sk_paint_set_color(cpaint, 0xFF00FF00); |
| 197 sk_canvas_draw_rect(ccanvas, &cr, cpaint); | 231 sk_canvas_draw_rect(ccanvas, &cr, cpaint); |
| 198 | 232 |
| 233 sk_path_t* cpath = sk_path_new(); | |
| 234 sk_path_move_to(cpath, 50, 50); | |
| 235 sk_path_line_to(cpath, 100, 100); | |
| 236 sk_path_line_to(cpath, 50, 100); | |
| 237 sk_path_close(cpath); | |
| 238 | |
| 239 sk_canvas_draw_path(ccanvas, cpath, cpaint); | |
| 240 | |
| 199 sk_image_t* cimage = sk_surface_new_image_snapshot(csurface); | 241 sk_image_t* cimage = sk_surface_new_image_snapshot(csurface); |
| 200 | 242 |
| 201 // HERE WE CROSS THE C..C++ boundary | 243 // HERE WE CROSS THE C..C++ boundary |
| 202 canvas->drawImage((const SkImage*)cimage, 20, 20, NULL); | 244 canvas->drawImage((const SkImage*)cimage, 20, 20, NULL); |
| 203 | 245 |
| 246 sk_path_delete(cpath); | |
| 204 sk_paint_delete(cpaint); | 247 sk_paint_delete(cpaint); |
| 205 sk_image_unref(cimage); | 248 sk_image_unref(cimage); |
| 206 sk_surface_delete(csurface); | 249 sk_surface_delete(csurface); |
| 207 } | 250 } |
| OLD | NEW |