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

ThresBinaryImage.H

Go to the documentation of this file.
00001 /*---------------------------------------------------------------------*
00002  | Library QgarLib, graphics analysis and recognition                  |
00003  | Copyright (C) 2005  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 license. |
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 __THRESBINARYIMAGE_H_INCLUDED__
00029 #define __THRESBINARYIMAGE_H_INCLUDED__
00030 
00031 
00032 /**
00033  * @file   ThresBinaryImage.H
00034  * @brief  Header file of class qgar::ThresBinaryImage.
00035  *
00036  * @author <a href="mailto:qgar-develop@loria.fr?subject=Qgar fwd Jan Rendek">Jan Rendek</a>
00037  * @date   July 4, 2005  09:23
00038  * @since  Qgar 2.2
00039  */
00040 
00041 
00042 // For RCS/CVS use: Do not delete
00043 /* $Id: ThresBinaryImage.H,v 1.1 2005/10/14 17:05:48 masini Exp $ */
00044 
00045 
00046 
00047 // QGAR
00048 #include <qgarlib/GenImage.H>
00049 
00050 
00051 
00052 namespace qgar
00053 {
00054 
00055 /**
00056  * @ingroup IMGPROC_BIN
00057  *
00058  * @class ThresBinaryImage ThresBinaryImage.H "qgarlib/ThresBinaryImage.H"
00059  *
00060  * @brief Elementary binarization, using a constant threshold.
00061  *
00062  * All pixels above the given threshold are set to <b>white</b>,
00063  * pixels below the threshold are set to <b>black</b>.
00064  *
00065  * @author <a href="mailto:qgar-develop@loria.fr?subject=Qgar fwd Jan Rendek">Jan Rendek</a>
00066  * @date   July 4, 2005  09:23
00067  * @since  Qgar 2.2
00068  */
00069 class ThresBinaryImage
00070 
00071   : public BinaryImage
00072 
00073 {
00074 // -------------------------------------------------------------------
00075 // T Y P E   D E F I N I T I O N S
00076 // -------------------------------------------------------------------
00077 public:
00078 
00079 
00080   /** @name Types */
00081   //        =====
00082   //@{
00083 
00084   /**
00085    * @brief Type of the elements stored in the pixmap.
00086    */
00087   typedef BinaryImage::value_type value_type;
00088 
00089   /**
00090    * @brief Reference to qgar::ThresBinaryImage::value_type.
00091    */
00092   typedef value_type& reference;
00093 
00094   /**
00095    * @brief Constant reference to qgar::ThresBinaryImage::value_type.
00096    */
00097   typedef const value_type& const_reference;
00098 
00099   /**
00100    * @brief Pointer to qgar::ThresBinaryImage::value_type.
00101    */
00102   typedef value_type* pointer;
00103 
00104   /**
00105    * @brief Constant pointer to qgar::ThresBinaryImage::value_type.
00106    */
00107   typedef const value_type* const_pointer;
00108 
00109   //@}
00110 
00111 
00112 // -------------------------------------------------------------------
00113 // P U B L I C    M E M B E R S
00114 // -------------------------------------------------------------------
00115 public:
00116 
00117 
00118 /** @name Constructors */
00119 //        ============
00120 //@{
00121 
00122 /**
00123  * @brief Default constructor.
00124  *
00125  * @param anImg    the greylevel input image
00126  * @param aThres   the threshold value
00127  */
00128   ThresBinaryImage(const GreyLevelImage& anImg, int aThres);
00129 
00130 //@}
00131 
00132 
00133 /** @name Destructor */
00134 //        ==========
00135 //@{
00136 
00137 /**
00138  * @brief Virtual destructor.
00139  */
00140   virtual ~ThresBinaryImage();
00141 
00142 //@}
00143 
00144 // -------------------------------------------------------------------
00145 }; // class ThresBinaryImage
00146 
00147 
00148 } // namespace qgar
00149 
00150 
00151 
00152 
00153 
00154 // HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH
00155 // HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH
00156 // H  E  L  P  E  R  S
00157 // HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH
00158 // HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH
00159 
00160 
00161 namespace qgar
00162 {
00163 
00164 
00165 /** @name Binarization helper functions */
00166 //        =============================
00167 //@{
00168 
00169 /**
00170  * @ingroup GLOB_HELPER
00171  *
00172  * @brief Returns a binary image, result of the binarization
00173  *   of the given grey-level image, using a constant threshold.
00174  *
00175  * @param anImg   grey-level image
00176  * @param aThres  constant binarization threshold
00177  */
00178 ThresBinaryImage
00179 qgThresBinarization(const GreyLevelImage& anImg, int aThres);
00180 
00181 //@}
00182 
00183 
00184 } // namespace qgar 
00185 
00186 
00187 // HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH
00188 // HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH
00189 
00190 
00191 #endif /* __THRESBINARYIMAGE_H_INCLUDED__ */