OpenStructure
transformation_base.hh
Go to the documentation of this file.
1 //------------------------------------------------------------------------------
2 // This file is part of the OpenStructure project <www.openstructure.org>
3 //
4 // Copyright (C) 2008-2020 by the OpenStructure authors
5 // Copyright (C) 2003-2010 by the IPLT authors
6 //
7 // This library is free software; you can redistribute it and/or modify it under
8 // the terms of the GNU Lesser General Public License as published by the Free
9 // Software Foundation; either version 3.0 of the License, or (at your option)
10 // any later version.
11 // This library is distributed in the hope that it will be useful, but WITHOUT
12 // ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
13 // FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
14 // details.
15 //
16 // You should have received a copy of the GNU Lesser General Public License
17 // along with this library; if not, write to the Free Software Foundation, Inc.,
18 // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 //------------------------------------------------------------------------------
20 
21 /*
22  transformation interface
23 
24  Author: Ansgar Philippsen
25 */
26 
27 #ifndef _IMG_TRANSFORMATION_H
28 #define _IMG_TRANSFORMATION_H
29 
30 #include <cmath>
31 
32 #include <ost/img/vecmat.hh>
33 #include <ost/img/extent.hh>
34 #include <ost/img/point.hh>
35 
37 namespace ost { namespace img { namespace alg {
38 
40 
55 public:
56  enum SizeRule {ORIGINAL, FIT};
57 
59  Transformation(const Mat4& tmat);
60  Transformation(const Mat4& tmat,const Mat4& imat);
61 
62  Mat4& Matrix() {return tmat_;}
63  const Mat4& Matrix() const {return tmat_;}
64 
65  Mat4& InverseMatrix() {return imat_;}
66  const Mat4& InverseMatrix() const {return imat_;}
67 
68  Point Apply(const Point& p);
69  Extent Apply(const Extent& e);
70 
71 
72 protected:
73  Mat4 tmat_;
74  Mat4 imat_;
75 };
76 
77 }}} // ns
78 
79 #endif
80 
Defines lower and upper valid indices.
Definition: extent.hh:60
class encapsulating 1D to 3D point
Definition: point.hh:47
transformation base class
const Mat4 & InverseMatrix() const
Extent Apply(const Extent &e)
Transformation(const Mat4 &tmat, const Mat4 &imat)
Point Apply(const Point &p)
Transformation(const Mat4 &tmat)
#define DLLEXPORT_IMG_ALG
Definition: base.dox:1