OpenStructure
Loading...
Searching...
No Matches
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
37namespace ost { namespace img { namespace alg {
38
40
55public:
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
72protected:
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
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