Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Class List | Directories | File List | Namespace Members | Class Members | File Members | Related Pages

_QGAR_translation.H

Go to the documentation of this file.
00001 /*---------------------------------------------------------------------+
00002  | Library QgarLib, graphics analysis and recognition                  |
00003  | Copyright (C) 2002  Qgar Project, LORIA                             |
00004  |                                                                     |
00005  | This library is free software; you can redistribute it and/or       |
00006  | modify it under the terms of the GNU Lesser General Public          |
00007  | License version 2.1, as published by the Free Software Foundation.  |
00008  |                                                                     |
00009  | This library is distributed in the hope that it will be useful,     |
00010  | but WITHOUT ANY WARRANTY; without even the implied warranty of      |
00011  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.                |
00012  | See the GNU Lesser General Public License for more details.         |
00013  |                                                                     |
00014  | The GNU Lesser General Public License is included in the file       |
00015  | LICENSE.LGPL, in the root directory of the Qgar packaging. See      |
00016  | http://www.gnu.org/licenses/lgpl.html for the terms of the licence. |
00017  | To receive a paper copy, write to the Free Software Foundation,     |
00018  | Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.       |
00019  |                                                                     |
00020  | Contact Project Qgar for any information:                           |
00021  |   LORIA - équipe Qgar                                               |
00022  |   B.P. 239, 54506 Vandoeuvre-lès-Nancy Cedex, France                |
00023  |   email: qgar-contact@loria.fr                                      |
00024  |   http://www.qgar.org/                                              |
00025  *---------------------------------------------------------------------*/
00026 
00027 
00028 #ifndef ___QGAR_TRANSLATION_H_INCLUDED__
00029 #define ___QGAR_TRANSLATION_H_INCLUDED__
00030 
00031 
00032 /**
00033  * @file   _QGAR_translation.H
00034  * @brief  Global functions to perform translations.
00035  *
00036  * @warning <b>Not to be used as include file!</b>
00037  * <br>When working with primitives, use header file primitives.H.
00038  *
00039  * @author <a href="mailto:qgar-develop@loria.fr?subject=Qgar fwd Gérald Masini">Gérald Masini</a>
00040  * @date   February 10 2005,  19:44
00041  * @since  Qgar 2.2
00042  */
00043 
00044 
00045 // For RCS/CVS use: Do not delete
00046 /* $Id: _QGAR_translation.H,v 1.2 2005/09/14 10:53:19 masini Exp $ */
00047 
00048 
00049 
00050 namespace qgar
00051 {
00052 
00053 
00054 /**
00055  * @name Global functions to translate points and primitives
00056  */
00057 //@{
00058 
00059 
00060 // -------------------------------------------------------------------
00061 // T R A N S L A T I O N   O F   A   P O I N T
00062 // -------------------------------------------------------------------
00063 
00064 
00065 /**
00066  * @ingroup GLOB_PRIM_TRANS
00067  *
00068  * @brief Return the given point translated along X and Y axis.
00069  *
00070  * @param aPt      point to be translated
00071  * @param aTransX  X translation factor
00072  * @param aTransY  Y translation factor
00073  */
00074 template <class T>
00075 inline GenPoint<T>
00076 qgTranslatedPoint(const GenPoint<T>& aPt, T aTransX, T aTransY);
00077 
00078 
00079 // -------------------------------------------------------------------
00080 // T R A N S L A T I O N   O F   A   S E G M E N T
00081 // -------------------------------------------------------------------
00082 
00083 
00084 /**
00085  * @ingroup GLOB_PRIM_TRANS
00086  *
00087  * @brief Return the given segment translated along X and Y axis.
00088  *
00089  * @param aSeg     segment to be translated
00090  * @param aTransX  X translation factor
00091  * @param aTransY  Y translation factor
00092  */
00093 template <class T>
00094 inline GenSegment<T>
00095 qgTranslatedSegment(const GenSegment<T>& aSeg, T aTransX, T aTransY);
00096 
00097 
00098 // -------------------------------------------------------------------
00099 // T R A N S L A T I O N   O F   A N   A R C
00100 // -------------------------------------------------------------------
00101 
00102 
00103 /**
00104  * @ingroup GLOB_PRIM_TRANS
00105  *
00106  * @brief Return the given arc translated along X and Y axis.
00107  *
00108  * @param anArc    arc to be translated
00109  * @param aTransX  X translation factor
00110  * @param aTransY  Y translation factor
00111  */
00112 template <class T>
00113 inline GenArc<T>
00114 qgTranslatedArc(const GenArc<T>& anArc, T aTransX, T aTransY);
00115 
00116 
00117 // -------------------------------------------------------------------
00118 // T R A N S L A T I O N   O F   A   P O L Y G O N
00119 // -------------------------------------------------------------------
00120 
00121 
00122 /**
00123  * @ingroup GLOB_PRIM_TRANS
00124  *
00125  * @brief Return the given polygon translated along X and Y axis.
00126  *
00127  * @param aPolygon  polygon to be translated
00128  * @param aTransX   X translation factor
00129  * @param aTransY   Y translation factor
00130  */
00131 template <class T>
00132 inline GenPolygon<T>
00133 qgTranslatedPolygon(const GenPolygon<T>& aPolygon, T aTransX, T aTransY);
00134 
00135 
00136 // -------------------------------------------------------------------
00137 // T R A N S L A T I O N   O F   A   P O L Y L I N E
00138 // -------------------------------------------------------------------
00139 
00140 
00141 /**
00142  * @ingroup GLOB_PRIM_TRANS
00143  *
00144  * @brief Return the given polyline translated along X and Y axis.
00145  *
00146  * @param aPolyline  polyline to be translated
00147  * @param aTransX    X translation factor
00148  * @param aTransY    Y translation factor
00149  */
00150   template <class T>
00151   GenPolyline<T>
00152   qgTranslatedPolyline(const GenPolyline<T>& aPolyline, T aTransX, T aTransY);
00153 
00154 
00155 // -------------------------------------------------------------------
00156 
00157 
00158 //@}
00159 
00160 
00161 } // namespace qgar
00162 
00163 
00164 #endif /* ___QGAR_TRANSLATION_H_INCLUDED__ */