Developer Documentation
PlaneType.cc
1 /*===========================================================================*\
2  * *
3  * OpenFlipper *
4  * Copyright (c) 2001-2015, RWTH-Aachen University *
5  * Department of Computer Graphics and Multimedia *
6  * All rights reserved. *
7  * www.openflipper.org *
8  * *
9  *---------------------------------------------------------------------------*
10  * This file is part of OpenFlipper. *
11  *---------------------------------------------------------------------------*
12  * *
13  * Redistribution and use in source and binary forms, with or without *
14  * modification, are permitted provided that the following conditions *
15  * are met: *
16  * *
17  * 1. Redistributions of source code must retain the above copyright notice, *
18  * this list of conditions and the following disclaimer. *
19  * *
20  * 2. Redistributions in binary form must reproduce the above copyright *
21  * notice, this list of conditions and the following disclaimer in the *
22  * documentation and/or other materials provided with the distribution. *
23  * *
24  * 3. Neither the name of the copyright holder nor the names of its *
25  * contributors may be used to endorse or promote products derived from *
26  * this software without specific prior written permission. *
27  * *
28  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS *
29  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED *
30  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A *
31  * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER *
32  * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, *
33  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, *
34  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR *
35  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF *
36  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING *
37  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS *
38  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *
39  * *
40 \*===========================================================================*/
41 
42 /*===========================================================================*\
43  * *
44  * $Revision$ *
45  * $Author$ *
46  * $Date$ *
47  * *
48 \*===========================================================================*/
49 
50 #include "PlaneType.hh"
51 
52 
53 //== IMPLEMENTATION ==========================================================
54 
55 
56 void Plane::setPlane(const ACG::Vec3d& _position, const ACG::Vec3d& _xDirection, const ACG::Vec3d& _yDirection)
57 {
58  position = _position;
59  xDirection = _xDirection;
60  yDirection = _yDirection;
61  normal = (_xDirection % _yDirection).normalize();
62 }
63 
64 //----------------------------------------------------------------
65 
66 void Plane::setPlane(const ACG::Vec3d& _position, const ACG::Vec3d& _normal)
67 {
68 
69  //find a non zero component
70  int comp = -1;
71  for (int i=0; i < 3; i++)
72  if ( _normal[i] != 0.0 ){
73  comp = i;
74  break;
75  }
76 
77  if (comp == -1){
78  std::cerr << "PlaneNode: normal is invalid!" << std::endl;
79  return;
80  }
81 
82  //compute orthogonal vectors in the plane
83  xDirection[comp] = (-_normal[ (comp + 1) % 3 ] - _normal[(comp + 2) % 3]) / _normal[comp];
84  xDirection[ (comp + 1) % 3 ] = 1;
85  xDirection[ (comp + 2) % 3 ] = 1;
86  xDirection = xDirection.normalize();
87 
88  yDirection = _normal % xDirection;
89  yDirection = yDirection.normalize();
90 
91  position = _position;
92  normal = _normal;
93 }
94 
95 //----------------------------------------------------------------
96 
98 {
99  position = _mat.transform_point(position);
100  xDirection = _mat.transform_vector(xDirection);
101  yDirection = _mat.transform_vector(yDirection);
102 
103  normal = (xDirection % yDirection).normalize();
104 }
105 
106 //----------------------------------------------------------------
107 
108 void Plane::setSize(double _xDirection, double _yDirection)
109 {
110  xDirection = xDirection.normalize() * _xDirection;
111  yDirection = yDirection.normalize() * _yDirection;
112 }
113 
114 
115 //=============================================================================
VectorT< T, 3 > transform_point(const VectorT< T, 3 > &_v) const
transform point (x&#39;,y&#39;,z&#39;,1) = M * (x,y,z,1)
Definition: Matrix4x4T.cc:202
auto normalize() -> decltype(*this/=std::declval< VectorT< S, DIM >>().norm())
Definition: Vector11T.hh:428
void setSize(double _xDirection, double _yDirection)
Set plane size.
Definition: PlaneType.cc:108
void setPlane(const ACG::Vec3d &_position, const ACG::Vec3d &_xDirection, const ACG::Vec3d &)
Set plane.
Definition: PlaneType.cc:56
void transform(const ACG::Matrix4x4d &_mat)
Transform the plane with given matrix.
Definition: PlaneType.cc:97
VectorT< T, 3 > transform_vector(const VectorT< T, 3 > &_v) const
transform vector (x&#39;,y&#39;,z&#39;,0) = A * (x,y,z,0)
Definition: Matrix4x4T.cc:225