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 #include "UniformNoiseGenerator.hpp" 00033 #include "LocalUniformNoiseGenerator.hpp" 00034 00035 using namespace Millie; 00036 00037 00038 UniformNoiseGenerator::UniformNoiseGenerator(int distance) : 00039 PointOperator(LocalUniformNoiseGenerator(distance)) 00040 {} 00041 00042 /* 00043 void UniformNoiseGenerator::compute(Image& out, const Image& in) 00044 { 00045 if(out.getNumComponents() != in.getNumComponents()) 00046 throw IllegalArgument("uniformNoiseOperator : bad count"); 00047 00048 00049 out.resize(in.getWidth(), in.getHeight()); 00050 00051 for(int canal = 0; canal<in.getNumComponents(); canal++) 00052 for(int j = 0; j<in.getHeight(); j++) 00053 for(int i = 0; i<in.getWidth(); i++) 00054 { 00055 out.setPixel(i,j, canal, 00056 in.getPixel(i,j, canal) + _uniform.get() 00057 ); 00058 } 00059 00060 00061 }*/ 00062 00063 UniformNoiseGenerator * UniformNoiseGenerator::clone() const 00064 { 00065 return new UniformNoiseGenerator(*this); 00066 } 00067 00068 void Millie::uniformNoiseGenerator(Image& out, const Image& in, 00069 int distance) 00070 { 00071 UniformNoiseGenerator generator(distance); 00072 generator.compute(out, in); 00073 }