00001 /****************************************************************************** 00002 * __ _ _ _ _ _ _____ * 00003 * | \ / | | | | | | | | | | ___| * 00004 * | \/ | | | | | | | | | | |_ * 00005 * | | | | | | | | | | | _| * 00006 * | |\/| | | | | |__ | |__ | | | |__ * 00007 * |_| |_| |_| |____| |____| |_| |____| * 00008 * __________________________________________________________________________ * 00009 * Multifunctional Library For Image Processing * 00010 * * 00011 * * 00012 * * 00013 * (c) Copyright 2007 by Humbert Florent * 00014 * * 00015 * This program is free software; you can redistribute it and/or modify * 00016 * it under the terms of the GNU General Public License as published by * 00017 * the Free Software Foundation; only version 2 of the License. * 00018 * * 00019 * This program is distributed in the hope that it will be useful, * 00020 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00021 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * 00022 * GNU General Public License for more details. * 00023 * * 00024 * You should have received a copy of the GNU General Public License * 00025 * along with this program; if not, write to the Free Software * 00026 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA * 00027 * 02111-1307, USA. * 00028 ******************************************************************************/ 00029 00032 #ifndef _THRESHOLDOPERATORS_HPP_ 00033 #define _THRESHOLDOPERATORS_HPP_ 00034 00035 #include "operator/PointOperator.hpp" 00036 #include "operator/ComponentsPointOperator.hpp" 00037 00038 #include "ThresholdLocalOperator.hpp" 00039 00040 namespace Millie 00041 { 00042 00055 class ThresholdOperator : public PointOperator 00056 { 00057 00058 public: 00059 00072 ThresholdOperator(float seuil) : 00073 PointOperator(ThresholdLocalOperator(seuil)) 00074 {} 00075 00079 ThresholdOperator * clone() const 00080 { 00081 return new ThresholdOperator(*this); 00082 } 00083 00084 }; 00085 00102 class ComponentsThresholdOperator : public ComponentsPointOperator 00103 { 00104 00112 ComponentsThresholdOperator(DataBuffer<float> & vector) : 00113 ComponentsPointOperator(ThresholdLocalComponentsOperator(vector)) 00114 {} 00115 00119 ComponentsThresholdOperator * clone() const 00120 { 00121 return new ComponentsThresholdOperator(*this); 00122 } 00123 00124 }; 00125 00126 00127 }; 00128 00129 00130 #endif