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

OpenBinaryImage.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 __OPENBINARYIMAGE_H_INCLUDED__
00029 #define __OPENBINARYIMAGE_H_INCLUDED__
00030 
00031 
00032 /**
00033  * @file   OpenBinaryImage.H
00034  * @brief  Header file of class qgar::OpenBinaryImage.
00035  *
00036  * @author <a href="mailto:qgar-develop@loria.fr?subject=Qgar fwd Mathieu Baeumler">Mathieu Baeumler</a>
00037  * @date   July 18, 2002  15:48
00038  * @since  Qgar 2.0
00039  */
00040 
00041 
00042 
00043 // For RCS/CVS use: Do not delete
00044 /* $Id: OpenBinaryImage.H,v 1.13 2005/10/14 17:05:47 masini Exp $ */
00045 
00046 
00047 
00048 // QGAR
00049 #include <qgarlib/GenImage.H>
00050 namespace qgar
00051 {
00052   // Avoid #include's when not necessary
00053   class QgarErrorDomain;
00054 }
00055 
00056 
00057 
00058 namespace qgar
00059 {
00060 
00061 /**
00062  * @ingroup IMGPROC_MORPH
00063  *
00064  * @class OpenBinaryImage OpenBinaryImage.H "qgarlib/OpenBinaryImage.H"
00065  *
00066  * @brief Open a binary image using morphological operators.
00067  * 
00068  * The structural element is a square of size
00069  * <b>(2 * anOpenSize) + 1</b>.
00070  * 
00071  * @todo Allow the use of other structural elements, like disks, crosses...
00072  *
00073  * @author <a href="mailto:qgar-develop@loria.fr?subject=Qgar fwd Mathieu Baeumler">Mathieu Baeumler</a>
00074  * @date   July 18, 2002  15:48
00075  * @since  Qgar 2.0
00076  */
00077 class OpenBinaryImage
00078 
00079   : public BinaryImage
00080 
00081 {
00082 // -------------------------------------------------------------------
00083 // T Y P E   D E F I N I T I O N S
00084 // -------------------------------------------------------------------
00085 public:
00086 
00087   /** @name Types */
00088   //        =====
00089   //@{
00090 
00091   /**
00092    * @brief Type of the elements stored in the pixel map.
00093    */
00094   typedef BinaryImage::value_type value_type;
00095 
00096   /**
00097    * @brief Reference to qgar::OpenBinaryImage::value_type.
00098    */
00099   typedef value_type& reference;
00100 
00101   /**
00102    * @brief Constant reference to qgar::OpenBinaryImage::value_type.
00103    */
00104   typedef const value_type& const_reference;
00105 
00106   /**
00107    * @brief Pointer to qgar::OpenBinaryImage::value_type.
00108    */
00109   typedef value_type* pointer;
00110 
00111   /**
00112    * @brief Constant pointer to qgar::OpenBinaryImage::value_type.
00113    */
00114   typedef const value_type* const_pointer;
00115 
00116   //@}
00117 
00118 // -------------------------------------------------------------------
00119 // P U B L I C    M E M B E R S
00120 // -------------------------------------------------------------------
00121 public:
00122 
00123   /** @name Constructors */
00124   //        ============
00125   //@{
00126 
00127   /**
00128    * @brief Construct from given binary image.
00129    *
00130    * @param anImg       image to be opened
00131    * @param anOpenSize  opening size
00132    * 
00133    * @exception qgar::QgarErrorDomain
00134    * (opening size too large for image)
00135    */
00136   OpenBinaryImage(const BinaryImage& anImg, unsigned int anOpenSize = 1)
00137     throw(QgarErrorDomain);
00138 
00139   //@}
00140 
00141 
00142   /** @name Opening */
00143   //        =======
00144   //@{
00145 
00146   /**
00147    * @brief Perform an opening on a given binary image.
00148    *
00149    * <b>To be used to perform an opening without preserving
00150    * the initial image.</b>
00151    *
00152    * @param anImg       pointer to the image to be opened
00153    * @param anOpenSize  opening size
00154    */
00155   static void perform(BinaryImage* anImg, unsigned int anOpenSize = 1);
00156 
00157   //@}
00158 
00159 // -------------------------------------------------------------------
00160 }; // class OpenBinaryImage
00161 
00162 
00163 } // namespace qgar
00164 
00165 
00166 #endif /* __OPENBINARYIMAGE_H_INCLUDED__ */