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

Side by Side Diff: gfx/canvas_skia_mac.mm

Issue 2862025: Canvas refactoring part 2.... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 10 years, 6 months 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « gfx/canvas_skia_linux.cc ('k') | gfx/canvas_skia_paint.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #import <Cocoa/Cocoa.h> 5 #import <Cocoa/Cocoa.h>
6 6
7 #include "gfx/canvas.h" 7 #include "gfx/canvas.h"
8 8
9 #include "base/scoped_cftyperef.h" 9 #include "base/scoped_cftyperef.h"
10 #include "base/sys_string_conversions.h" 10 #include "base/sys_string_conversions.h"
11 #include "gfx/font.h" 11 #include "gfx/font.h"
12 #include "gfx/rect.h" 12 #include "gfx/rect.h"
13 #include "third_party/skia/include/core/SkShader.h" 13 #include "third_party/skia/include/core/SkShader.h"
14 14
15 namespace gfx { 15 namespace gfx {
16 16
17 Canvas::Canvas(int width, int height, bool is_opaque) 17 CanvasSkia::CanvasSkia(int width, int height, bool is_opaque)
18 : skia::PlatformCanvas(width, height, is_opaque) { 18 : skia::PlatformCanvas(width, height, is_opaque) {
19 } 19 }
20 20
21 Canvas::Canvas() : skia::PlatformCanvas() { 21 CanvasSkia::CanvasSkia() : skia::PlatformCanvas() {
22 } 22 }
23 23
24 Canvas::~Canvas() { 24 CanvasSkia::~CanvasSkia() {
25 } 25 }
26 26
27 // static 27 // static
28 void Canvas::SizeStringInt(const std::wstring& text, 28 void CanvasSkia::SizeStringInt(const std::wstring& text,
29 const gfx::Font& font, 29 const gfx::Font& font,
30 int *width, int *height, int flags) { 30 int *width, int *height, int flags) {
31 NSFont* native_font = font.nativeFont(); 31 NSFont* native_font = font.nativeFont();
32 NSString* ns_string = base::SysWideToNSString(text); 32 NSString* ns_string = base::SysWideToNSString(text);
33 NSDictionary* attributes = 33 NSDictionary* attributes =
34 [NSDictionary dictionaryWithObject:native_font 34 [NSDictionary dictionaryWithObject:native_font
35 forKey:NSFontAttributeName]; 35 forKey:NSFontAttributeName];
36 NSSize string_size = [ns_string sizeWithAttributes:attributes]; 36 NSSize string_size = [ns_string sizeWithAttributes:attributes];
37 *width = string_size.width; 37 *width = string_size.width;
38 *height = font.height(); 38 *height = font.height();
39 } 39 }
40 40
41 void Canvas::DrawStringInt(const std::wstring& text, const gfx::Font& font, 41 void CanvasSkia::DrawStringInt(const std::wstring& text, const gfx::Font& font,
42 const SkColor& color, int x, int y, int w, int h, 42 const SkColor& color, int x, int y, int w, int h,
43 int flags) { 43 int flags) {
44 if (!IntersectsClipRectInt(x, y, w, h)) 44 if (!IntersectsClipRectInt(x, y, w, h))
45 return; 45 return;
46 46
47 CGContextRef context = beginPlatformPaint(); 47 CGContextRef context = beginPlatformPaint();
48 CGContextSaveGState(context); 48 CGContextSaveGState(context);
49 49
50 NSColor* ns_color = [NSColor colorWithDeviceRed:SkColorGetR(color) / 255.0 50 NSColor* ns_color = [NSColor colorWithDeviceRed:SkColorGetR(color) / 255.0
51 green:SkColorGetG(color) / 255.0 51 green:SkColorGetG(color) / 255.0
52 blue:SkColorGetB(color) / 255.0 52 blue:SkColorGetB(color) / 255.0
53 alpha:SkColorGetA(color) / 255.0]; 53 alpha:SkColorGetA(color) / 255.0];
(...skipping 21 matching lines...) Expand all
75 CGPathAddRect(path, NULL, text_bounds); 75 CGPathAddRect(path, NULL, text_bounds);
76 76
77 scoped_cftyperef<CTFrameRef> frame( 77 scoped_cftyperef<CTFrameRef> frame(
78 CTFramesetterCreateFrame(framesetter, CFRangeMake(0, 0), path, NULL)); 78 CTFramesetterCreateFrame(framesetter, CFRangeMake(0, 0), path, NULL));
79 CTFrameDraw(frame, context); 79 CTFrameDraw(frame, context);
80 CGContextRestoreGState(context); 80 CGContextRestoreGState(context);
81 endPlatformPaint(); 81 endPlatformPaint();
82 } 82 }
83 83
84 } // namespace gfx 84 } // namespace gfx
OLDNEW
« no previous file with comments | « gfx/canvas_skia_linux.cc ('k') | gfx/canvas_skia_paint.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698