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

Side by Side Diff: sky/engine/core/painting/Offset.dart

Issue 1209413004: Instead of applying a transform for every RenderObject, pass down an Offset for where to paint. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Created 5 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
« no previous file with comments | « no previous file | sky/engine/core/painting/Rect.dart » ('j') | sky/sdk/lib/rendering/box.dart » ('J')
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 part of dart.sky; 5 part of dart.sky;
6 6
7 /// Holds a 2D floating-point offset. 7 /// Holds a 2D floating-point offset.
8 /// Think of this as a vector from an unspecified point 8 /// Think of this as a vector from an unspecified point
9 class Offset extends OffsetBase { 9 class Offset extends OffsetBase {
10 const Offset(dx, dy) : super(dx, dy); 10 const Offset(dx, dy) : super(dx, dy);
11 Offset.copy(Offset source) : super(source.dx, source.dy); 11 Offset.copy(Offset source) : super(source.dx, source.dy);
12 12
13 double get dx => _dx; 13 double get dx => _dx;
14 double get dy => _dy; 14 double get dy => _dy;
15 15
16 static const Offset zero = const Offset(0.0, 0.0); 16 static const Offset zero = const Offset(0.0, 0.0);
17 static const Offset infinite = const Offset(double.INFINITY, double.INFINITY); 17 static const Offset infinite = const Offset(double.INFINITY, double.INFINITY);
18 18
19 Offset scale(double scaleX, double scaleY) => new Offset(dx * scaleX, dy * sca leY); 19 Offset scale(double scaleX, double scaleY) => new Offset(dx * scaleX, dy * sca leY);
20 20
21 Offset operator -() => new Offset(-dx, -dy); 21 Offset operator -() => new Offset(-dx, -dy);
22 Offset operator -(Offset other) => new Offset(dx - other.dx, dy - other.dy); 22 Offset operator -(Offset other) => new Offset(dx - other.dx, dy - other.dy);
23 Offset operator +(Offset other) => new Offset(dx + other.dx, dy + other.dy); 23 dynamic operator +(dynamic other) {
24 if (other is Offset)
25 return new Offset(dx + other.dx, dy + other.dy);
26 if (other is Size)
27 return new Rect.fromLTWH(dx, dy, other.width, other.height);
abarth-chromium 2015/06/27 00:39:37 Wow, an offset + a size is a rect? Crazy.
28 throw new ArgumentError(other);
29 }
24 30
25 // does the equivalent of "return new Point(0,0) + this" 31 // does the equivalent of "return new Point(0,0) + this"
26 Point toPoint() => new Point(this.dx, this.dy); 32 Point toPoint() => new Point(this.dx, this.dy);
27 33
28 String toString() => "Offset($dx, $dy)"; 34 String toString() => "Offset($dx, $dy)";
29 } 35 }
OLDNEW
« no previous file with comments | « no previous file | sky/engine/core/painting/Rect.dart » ('j') | sky/sdk/lib/rendering/box.dart » ('J')

Powered by Google App Engine
This is Rietveld 408576698