summaryrefslogtreecommitdiffstats
path: root/src/math/rotation.php
blob: cb0cc86e304cb00c49558f788764842b364b7b04 (plain)
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;
    }
}

?>
OpenPOWER on IntegriCloud