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 00033 #include "ComponentsPointOperator.hpp" 00034 00035 using namespace Millie; 00036 00037 00038 ComponentsPointOperator::ComponentsPointOperator(const LocalComponentsPointOperator& localOp) 00039 { 00040 _localOperator = 0; 00041 _localOperator = localOp.clone(); 00042 } 00043 00044 ComponentsPointOperator::~ComponentsPointOperator() 00045 { 00046 delete _localOperator; 00047 } 00048 00049 00050 ComponentsPointOperator* ComponentsPointOperator::ComponentsPointOperator::clone() const 00051 { 00052 return new ComponentsPointOperator(*this); 00053 } 00054 00055 ComponentsPointOperator::ComponentsPointOperator(const ComponentsPointOperator& pointOp) 00056 { 00057 _localOperator = pointOp._localOperator->clone(); 00058 } 00059 00060 LocalComponentsPointOperator& ComponentsPointOperator::getLocalComponentsPointOperator() 00061 { 00062 return *_localOperator; 00063 } 00064 00065 void ComponentsPointOperator::compute(Image& out, const Image& in) 00066 { 00067 if(out.getNumComponents() != in.getNumComponents()) 00068 throw IllegalArgument("ComponentsPointOperator : num components problem"); 00069 00070 DataBuffer<float> colors(in.getNumComponents()); 00071 00072 00073 out.resize(in.getWidth(), in.getHeight()); 00074 00075 00076 LocalComponentsPointOperator & localOp = getLocalComponentsPointOperator(); 00077 00078 if(localOp.getNumComponents() != in.getNumComponents()) 00079 throw IllegalArgument("ComponentsPointOperator : Bad local operator"); 00080 00081 for (int y=0; y<in.getHeight(); y++) 00082 for (int x=0; x< in.getWidth(); x++) 00083 { 00084 localOp.computeColors(in, x, y, colors); 00085 for(int canal=0; canal< in.getNumComponents(); canal++) 00086 out.setPixel(x, y, canal, colors[canal]); 00087 } 00088 } 00089 00090