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

Side by Side Diff: ui/gfx/path_win.cc

Issue 169223002: Revert of Fix CreateHRGNFromSkPath to support arbitrary SkPaths. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 10 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 | « no previous file | ui/gfx/path_win_unittest.cc » ('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) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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 #include "ui/gfx/path_win.h" 5 #include "ui/gfx/path_win.h"
6 6
7 #include "base/memory/scoped_ptr.h" 7 #include "base/memory/scoped_ptr.h"
8 #include "base/win/scoped_gdi_object.h" 8 #include "base/win/scoped_gdi_object.h"
9 #include "third_party/skia/include/core/SkRegion.h" 9 #include "third_party/skia/include/core/SkRegion.h"
10 #include "ui/gfx/path.h" 10 #include "ui/gfx/path.h"
11 11
12 namespace gfx { 12 namespace gfx {
13 13
14 HRGN CreateHRGNFromSkRegion(const SkRegion& region) { 14 HRGN CreateHRGNFromSkRegion(const SkRegion& region) {
15 base::win::ScopedRegion temp(::CreateRectRgn(0, 0, 0, 0)); 15 base::win::ScopedRegion temp(::CreateRectRgn(0, 0, 0, 0));
16 base::win::ScopedRegion result(::CreateRectRgn(0, 0, 0, 0)); 16 base::win::ScopedRegion result(::CreateRectRgn(0, 0, 0, 0));
17 17
18 for (SkRegion::Iterator i(region); !i.done(); i.next()) { 18 for (SkRegion::Iterator i(region); !i.done(); i.next()) {
19 const SkIRect& rect = i.rect(); 19 const SkIRect& rect = i.rect();
20 ::SetRectRgn(temp, rect.left(), rect.top(), rect.right(), rect.bottom()); 20 ::SetRectRgn(temp, rect.left(), rect.top(), rect.right(), rect.bottom());
21 ::CombineRgn(result, result, temp, RGN_OR); 21 ::CombineRgn(result, result, temp, RGN_OR);
22 } 22 }
23 23
24 return result.release(); 24 return result.release();
25 } 25 }
26 26
27 HRGN CreateHRGNFromSkPath(const SkPath& path) { 27 HRGN CreateHRGNFromSkPath(const SkPath& path) {
28 SkRegion clip(SkIRect::MakeLTRB(INT_MIN, INT_MIN, INT_MAX, INT_MAX)); 28 int point_count = path.getPoints(NULL, 0);
29 SkRegion region; 29 scoped_ptr<SkPoint[]> points(new SkPoint[point_count]);
30 region.setPath(path, clip); 30 path.getPoints(points.get(), point_count);
31 return CreateHRGNFromSkRegion(region); 31 scoped_ptr<POINT[]> windows_points(new POINT[point_count]);
32 for (int i = 0; i < point_count; ++i) {
33 windows_points[i].x = SkScalarRoundToInt(points[i].fX);
34 windows_points[i].y = SkScalarRoundToInt(points[i].fY);
35 }
36
37 return ::CreatePolygonRgn(windows_points.get(), point_count, ALTERNATE);
32 } 38 }
33 39
34 // See path_aura.cc for Aura definition of these methods: 40 // See path_aura.cc for Aura definition of these methods:
35 #if !defined(USE_AURA) 41 #if !defined(USE_AURA)
36 42
37 NativeRegion Path::CreateNativeRegion() const { 43 NativeRegion Path::CreateNativeRegion() const {
38 return CreateHRGNFromSkPath(*this); 44 return CreateHRGNFromSkPath(*this);
39 } 45 }
40 46
41 // static 47 // static
(...skipping 13 matching lines...) Expand all
55 // static 61 // static
56 NativeRegion Path::SubtractRegion(NativeRegion r1, NativeRegion r2) { 62 NativeRegion Path::SubtractRegion(NativeRegion r1, NativeRegion r2) {
57 HRGN dest = CreateRectRgn(0, 0, 1, 1); 63 HRGN dest = CreateRectRgn(0, 0, 1, 1);
58 CombineRgn(dest, r1, r2, RGN_DIFF); 64 CombineRgn(dest, r1, r2, RGN_DIFF);
59 return dest; 65 return dest;
60 } 66 }
61 67
62 #endif 68 #endif
63 69
64 } // namespace gfx 70 } // namespace gfx
OLDNEW
« no previous file with comments | « no previous file | ui/gfx/path_win_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698