blob: f6f6a91cc2735c9134e0870df74726f840b4988e [file] [log] [blame]
 // Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file // for details. All rights reserved. Use of this source code is governed by a // BSD-style license that can be found in the LICENSE file. import 'dart:math' hide Rectangle; import 'dart:math' as math show Point, Rectangle, MutableRectangle; import 'package:expect/expect.dart' show Expect; void main() { verifyRectable(new Rectangle(1, 2, 3, 4)); } void verifyRectable(math.Rectangle rect) { Expect.equals(1.0, rect.left.toDouble()); Expect.equals(2.0, rect.top.toDouble()); Expect.equals(4.0, rect.right.toDouble()); Expect.equals(6.0, rect.bottom.toDouble()); } class Rectangle implements math.MutableRectangle { T left; T top; T width; T height; Rectangle(this.left, this.top, this.width, this.height); T get right => (left + width) as T; T get bottom => (top + height) as T; Point get topLeft => new Point(left, top); Point get topRight => new Point(right, top); Point get bottomLeft => new Point(left, bottom); Point get bottomRight => new Point(right, bottom); //--------------------------------------------------------------------------- bool contains(num px, num py) { return left <= px && top <= py && right > px && bottom > py; } bool containsPoint(math.Point p) { return contains(p.x, p.y); } bool intersects(math.Rectangle r) { return left < r.right && right > r.left && top < r.bottom && bottom > r.top; } /// Returns a new rectangle which completely contains `this` and [other]. Rectangle boundingBox(math.Rectangle other) { T rLeft = min(left, other.left); T rTop = min(top, other.top); T rRight = max(right, other.right); T rBottom = max(bottom, other.bottom); return new Rectangle( rLeft, rTop, (rRight - rLeft) as T, (rBottom - rTop) as T); } /// Tests whether `this` entirely contains [another]. bool containsRectangle(math.Rectangle r) { return left <= r.left && top <= r.top && right >= r.right && bottom >= r.bottom; } Rectangle intersection(math.Rectangle rect) { T rLeft = max(left, rect.left); T rTop = max(top, rect.top); T rRight = min(right, rect.right); T rBottom = min(bottom, rect.bottom); return new Rectangle( rLeft, rTop, (rRight - rLeft) as T, (rBottom - rTop) as T); } }