123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346 |
- // Copyright 2008 The Closure Library Authors. All Rights Reserved.
- // Use of this source code is governed by the Apache License, Version 2.0.
- goog.provide('goog.graphics.AffineTransformTest');
- goog.setTestOnly('goog.graphics.AffineTransformTest');
- goog.require('goog.graphics');
- goog.require('goog.graphics.AffineTransform');
- goog.require('goog.testing.jsunit');
- function testGetTranslateInstance() {
- var tx = goog.graphics.AffineTransform.getTranslateInstance(2, 4);
- assertEquals(1, tx.getScaleX());
- assertEquals(0, tx.getShearY());
- assertEquals(0, tx.getShearX());
- assertEquals(1, tx.getScaleY());
- assertEquals(2, tx.getTranslateX());
- assertEquals(4, tx.getTranslateY());
- }
- function testGetScaleInstance() {
- var tx = goog.graphics.AffineTransform.getScaleInstance(2, 4);
- assertEquals(2, tx.getScaleX());
- assertEquals(0, tx.getShearY());
- assertEquals(0, tx.getShearX());
- assertEquals(4, tx.getScaleY());
- assertEquals(0, tx.getTranslateX());
- assertEquals(0, tx.getTranslateY());
- }
- function testGetRotateInstance() {
- var tx = goog.graphics.AffineTransform.getRotateInstance(Math.PI / 2, 1, 2);
- assertRoughlyEquals(0, tx.getScaleX(), 1e-9);
- assertRoughlyEquals(1, tx.getShearY(), 1e-9);
- assertRoughlyEquals(-1, tx.getShearX(), 1e-9);
- assertRoughlyEquals(0, tx.getScaleY(), 1e-9);
- assertRoughlyEquals(3, tx.getTranslateX(), 1e-9);
- assertRoughlyEquals(1, tx.getTranslateY(), 1e-9);
- }
- function testGetShearInstance() {
- var tx = goog.graphics.AffineTransform.getShearInstance(2, 4);
- assertEquals(1, tx.getScaleX());
- assertEquals(4, tx.getShearY());
- assertEquals(2, tx.getShearX());
- assertEquals(1, tx.getScaleY());
- assertEquals(0, tx.getTranslateX());
- assertEquals(0, tx.getTranslateY());
- }
- function testConstructor() {
- assertThrows(function() {
- new goog.graphics.AffineTransform([0, 0]);
- });
- assertThrows(function() {
- new goog.graphics.AffineTransform({});
- });
- assertThrows(function() {
- new goog.graphics.AffineTransform(0, 0, 0, 'a', 0, 0);
- });
- var tx = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- assertEquals(1, tx.getScaleX());
- assertEquals(2, tx.getShearY());
- assertEquals(3, tx.getShearX());
- assertEquals(4, tx.getScaleY());
- assertEquals(5, tx.getTranslateX());
- assertEquals(6, tx.getTranslateY());
- tx = new goog.graphics.AffineTransform();
- assert(tx.isIdentity());
- }
- function testIsIdentity() {
- var tx = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- assertFalse(tx.isIdentity());
- tx.setTransform(1, 0, 0, 1, 0, 0);
- assert(tx.isIdentity());
- }
- function testClone() {
- var tx = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- var copy = tx.clone();
- assertEquals(copy.getScaleX(), tx.getScaleX());
- assertEquals(copy.getShearY(), tx.getShearY());
- assertEquals(copy.getShearX(), tx.getShearX());
- assertEquals(copy.getScaleY(), tx.getScaleY());
- assertEquals(copy.getTranslateX(), tx.getTranslateX());
- assertEquals(copy.getTranslateY(), tx.getTranslateY());
- }
- function testSetTransform() {
- var tx = new goog.graphics.AffineTransform();
- assertThrows(function() {
- tx.setTransform(1, 2, 3, 4, 6);
- });
- assertThrows(function() {
- tx.setTransform('a', 2, 3, 4, 5, 6);
- });
- tx.setTransform(1, 2, 3, 4, 5, 6);
- assertEquals(1, tx.getScaleX());
- assertEquals(2, tx.getShearY());
- assertEquals(3, tx.getShearX());
- assertEquals(4, tx.getScaleY());
- assertEquals(5, tx.getTranslateX());
- assertEquals(6, tx.getTranslateY());
- }
- function testScale() {
- var tx = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- tx.scale(2, 3);
- assertEquals(2, tx.getScaleX());
- assertEquals(4, tx.getShearY());
- assertEquals(9, tx.getShearX());
- assertEquals(12, tx.getScaleY());
- assertEquals(5, tx.getTranslateX());
- assertEquals(6, tx.getTranslateY());
- }
- function testPreScale() {
- var tx = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- tx.preScale(2, 3);
- assertEquals(2, tx.getScaleX());
- assertEquals(6, tx.getShearY());
- assertEquals(6, tx.getShearX());
- assertEquals(12, tx.getScaleY());
- assertEquals(10, tx.getTranslateX());
- assertEquals(18, tx.getTranslateY());
- }
- function testTranslate() {
- var tx = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- tx.translate(2, 3);
- assertEquals(1, tx.getScaleX());
- assertEquals(2, tx.getShearY());
- assertEquals(3, tx.getShearX());
- assertEquals(4, tx.getScaleY());
- assertEquals(16, tx.getTranslateX());
- assertEquals(22, tx.getTranslateY());
- }
- function testPreTranslate() {
- var tx = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- tx.preTranslate(2, 3);
- assertEquals(1, tx.getScaleX());
- assertEquals(2, tx.getShearY());
- assertEquals(3, tx.getShearX());
- assertEquals(4, tx.getScaleY());
- assertEquals(7, tx.getTranslateX());
- assertEquals(9, tx.getTranslateY());
- }
- function testRotate() {
- var tx = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- tx.rotate(Math.PI / 2, 1, 1);
- assertRoughlyEquals(3, tx.getScaleX(), 1e-9);
- assertRoughlyEquals(4, tx.getShearY(), 1e-9);
- assertRoughlyEquals(-1, tx.getShearX(), 1e-9);
- assertRoughlyEquals(-2, tx.getScaleY(), 1e-9);
- assertRoughlyEquals(7, tx.getTranslateX(), 1e-9);
- assertRoughlyEquals(10, tx.getTranslateY(), 1e-9);
- }
- function testPreRotate() {
- var tx = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- tx.preRotate(Math.PI / 2, 1, 1);
- assertRoughlyEquals(-2, tx.getScaleX(), 1e-9);
- assertRoughlyEquals(1, tx.getShearY(), 1e-9);
- assertRoughlyEquals(-4, tx.getShearX(), 1e-9);
- assertRoughlyEquals(3, tx.getScaleY(), 1e-9);
- assertRoughlyEquals(-4, tx.getTranslateX(), 1e-9);
- assertRoughlyEquals(5, tx.getTranslateY(), 1e-9);
- }
- function testShear() {
- var tx = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- tx.shear(2, 3);
- assertEquals(10, tx.getScaleX());
- assertEquals(14, tx.getShearY());
- assertEquals(5, tx.getShearX());
- assertEquals(8, tx.getScaleY());
- assertEquals(5, tx.getTranslateX());
- assertEquals(6, tx.getTranslateY());
- }
- function testPreShear() {
- var tx = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- tx.preShear(2, 3);
- assertEquals(5, tx.getScaleX());
- assertEquals(5, tx.getShearY());
- assertEquals(11, tx.getShearX());
- assertEquals(13, tx.getScaleY());
- assertEquals(17, tx.getTranslateX());
- assertEquals(21, tx.getTranslateY());
- }
- function testConcatentate() {
- var tx = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- tx.concatenate(new goog.graphics.AffineTransform(2, 1, 6, 5, 4, 3));
- assertEquals(5, tx.getScaleX());
- assertEquals(8, tx.getShearY());
- assertEquals(21, tx.getShearX());
- assertEquals(32, tx.getScaleY());
- assertEquals(18, tx.getTranslateX());
- assertEquals(26, tx.getTranslateY());
- }
- function testPreConcatentate() {
- var tx = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- tx.preConcatenate(new goog.graphics.AffineTransform(2, 1, 6, 5, 4, 3));
- assertEquals(14, tx.getScaleX());
- assertEquals(11, tx.getShearY());
- assertEquals(30, tx.getShearX());
- assertEquals(23, tx.getScaleY());
- assertEquals(50, tx.getTranslateX());
- assertEquals(38, tx.getTranslateY());
- }
- function testAssociativeConcatenate() {
- var x = new goog.graphics.AffineTransform(2, 3, 5, 7, 11, 13).concatenate(
- new goog.graphics.AffineTransform(17, 19, 23, 29, 31, 37));
- var y = new goog.graphics.AffineTransform(17, 19, 23, 29, 31, 37)
- .preConcatenate(new goog.graphics.AffineTransform(2, 3, 5, 7, 11, 13));
- assertEquals(x.getScaleX(), y.getScaleX());
- assertEquals(x.getShearY(), y.getShearY());
- assertEquals(x.getShearX(), y.getShearX());
- assertEquals(x.getScaleY(), y.getScaleY());
- assertEquals(x.getTranslateX(), y.getTranslateX());
- assertEquals(x.getTranslateY(), y.getTranslateY());
- };
- function testTransform() {
- var srcPts = [0, 0, 1, 0, 1, 1, 0, 1];
- var dstPts = [];
- var tx = goog.graphics.AffineTransform.getScaleInstance(2, 3);
- tx.translate(5, 10);
- tx.rotate(Math.PI / 4, 5, 10);
- tx.transform(srcPts, 0, dstPts, 0, 4);
- assert(goog.array.equals(
- [27.071068, 28.180195, 28.485281, 30.301516,
- 27.071068, 32.422836, 25.656855, 30.301516],
- dstPts,
- goog.math.nearlyEquals));
- }
- function testGetDeterminant() {
- var tx = goog.graphics.AffineTransform.getScaleInstance(2, 3);
- tx.translate(5, 10);
- tx.rotate(Math.PI / 4, 5, 10);
- assertRoughlyEquals(6, tx.getDeterminant(), 0.001);
- }
- function testIsInvertible() {
- assertTrue(new goog.graphics.AffineTransform(2, 3, 4, 5, 6, 7).
- isInvertible());
- assertTrue(new goog.graphics.AffineTransform(1, 0, 0, 1, 0, 0).
- isInvertible());
- assertFalse(new goog.graphics.AffineTransform(NaN, 0, 0, 1, 0, 0).
- isInvertible());
- assertFalse(new goog.graphics.AffineTransform(1, NaN, 0, 1, 0, 0).
- isInvertible());
- assertFalse(new goog.graphics.AffineTransform(1, 0, NaN, 1, 0, 0).
- isInvertible());
- assertFalse(new goog.graphics.AffineTransform(1, 0, 0, NaN, 0, 0).
- isInvertible());
- assertFalse(new goog.graphics.AffineTransform(1, 0, 0, 1, NaN, 0).
- isInvertible());
- assertFalse(new goog.graphics.AffineTransform(1, 0, 0, 1, 0, NaN).
- isInvertible());
- assertFalse(new goog.graphics.AffineTransform(Infinity, 0, 0, 1, 0, 0).
- isInvertible());
- assertFalse(new goog.graphics.AffineTransform(1, Infinity, 0, 1, 0, 0).
- isInvertible());
- assertFalse(new goog.graphics.AffineTransform(1, 0, Infinity, 1, 0, 0).
- isInvertible());
- assertFalse(new goog.graphics.AffineTransform(1, 0, 0, Infinity, 0, 0).
- isInvertible());
- assertFalse(new goog.graphics.AffineTransform(1, 0, 0, 1, Infinity, 0).
- isInvertible());
- assertFalse(new goog.graphics.AffineTransform(1, 0, 0, 1, 0, Infinity).
- isInvertible());
- assertFalse(new goog.graphics.AffineTransform(0, 0, 0, 0, 1, 0).
- isInvertible());
- }
- function testCreateInverse() {
- var tx = goog.graphics.AffineTransform.getScaleInstance(2, 3);
- tx.translate(5, 10);
- tx.rotate(Math.PI / 4, 5, 10);
- var inverse = tx.createInverse();
- assert(goog.math.nearlyEquals(0.353553, inverse.getScaleX()));
- assert(goog.math.nearlyEquals(-0.353553, inverse.getShearY()));
- assert(goog.math.nearlyEquals(0.235702, inverse.getShearX()));
- assert(goog.math.nearlyEquals(0.235702, inverse.getScaleY()));
- assert(goog.math.nearlyEquals(-16.213203, inverse.getTranslateX()));
- assert(goog.math.nearlyEquals(2.928932, inverse.getTranslateY()));
- }
- function testCopyFrom() {
- var from = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- var to = new goog.graphics.AffineTransform();
- to.copyFrom(from);
- assertEquals(from.getScaleX(), to.getScaleX());
- assertEquals(from.getShearY(), to.getShearY());
- assertEquals(from.getShearX(), to.getShearX());
- assertEquals(from.getScaleY(), to.getScaleY());
- assertEquals(from.getTranslateX(), to.getTranslateX());
- assertEquals(from.getTranslateY(), to.getTranslateY());
- }
- function testToString() {
- var tx = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- assertEquals("matrix(1,2,3,4,5,6)", tx.toString());
- }
- function testEquals() {
- var tx1 = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- var tx2 = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, 6);
- assertEqualsMethod(tx1, tx2, true);
- tx2 = new goog.graphics.AffineTransform(-1, 2, 3, 4, 5, 6);
- assertEqualsMethod(tx1, tx2, false);
- tx2 = new goog.graphics.AffineTransform(1, -1, 3, 4, 5, 6);
- assertEqualsMethod(tx1, tx2, false);
- tx2 = new goog.graphics.AffineTransform(1, 2, -3, 4, 5, 6);
- assertEqualsMethod(tx1, tx2, false);
- tx2 = new goog.graphics.AffineTransform(1, 2, 3, -4, 5, 6);
- assertEqualsMethod(tx1, tx2, false);
- tx2 = new goog.graphics.AffineTransform(1, 2, 3, 4, -5, 6);
- assertEqualsMethod(tx1, tx2, false);
- tx2 = new goog.graphics.AffineTransform(1, 2, 3, 4, 5, -6);
- assertEqualsMethod(tx1, tx2, false);
- }
- function assertEqualsMethod(tx1, tx2, expected) {
- assertEquals(expected, tx1.equals(tx2));
- assertEquals(expected, tx2.equals(tx1));
- assertEquals(true, tx1.equals(tx1));
- assertEquals(true, tx2.equals(tx2));
- }
|