1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
<?php
/**
* File containing the ezcGraphRotation class
*
* @package Graph
* @version //autogentag//
* @copyright Copyright (C) 2005-2010 eZ Systems AS. All rights reserved.
* @license http://ez.no/licenses/new_bsd New BSD License
* @access private
*/
/**
* Class to create rotation matrices from given rotation and center point
*
* Three dimensional matrices (3x3) may be used to specify transformation of
* points, vectors and complexer structures in a two dimensional cartesian
* coordinate system. For more details have a look here:
* http://en.wikipedia.org/wiki/Transformation_matrix
*
* This class implements a convenient interface to create matrixes to rotate
* elements. This matrix may be combined with other transformation matrices, as
* usual.
*
* @version //autogentag//
* @package Graph
* @access private
*/
class ezcGraphRotation extends ezcGraphTransformation
{
/**
* Rotation in degrees
*
* @var float
*/
protected $rotation;
/**
* Center point
*
* @var ezcGraphCoordinate
*/
protected $center;
/**
* Construct rotation matrix from rotation (in degrees) and optional
* center point.
*
* @param int $rotation
* @param ezcGraphCoordinate $center
* @return ezcGraphTransformation
*/
public function __construct( $rotation = 0, ezcGraphCoordinate $center = null )
{
$this->rotation = (float) $rotation;
if ( $center === null )
{
$this->center = new ezcGraphCoordinate( 0, 0 );
$clockwiseRotation = deg2rad( $rotation );
$rotationMatrixArray = array(
array( cos( $clockwiseRotation ), -sin( $clockwiseRotation ), 0 ),
array( sin( $clockwiseRotation ), cos( $clockwiseRotation ), 0 ),
array( 0, 0, 1 ),
);
return parent::__construct( $rotationMatrixArray );
}
parent::__construct();
$this->center = $center;
$this->multiply( new ezcGraphTranslation( $center->x, $center->y ) );
$this->multiply( new ezcGraphRotation( $rotation ) );
$this->multiply( new ezcGraphTranslation( -$center->x, -$center->y ) );
}
/**
* Return rotaion angle in degrees
*
* @return float
*/
public function getRotation()
{
return $this->rotation;
}
/**
* Return the center point of the current rotation
*
* @return ezcGraphCoordinate
*/
public function getCenter()
{
return $this->center;
}
}
?>
|