Hauptseite   Klassenhierarchie   Auflistung der Dateien  

filtergrave.cpp

00001 /**********************************************************************************
00002 * Copyright (c) 2003, Christoph Rueegg <opendev@cdrnet.ch> and Matthias Bader     *
00003 * All rights reserved.                                                            *
00004 *                                                                                 *
00005 * Project Website: http://www.cdrnet.net/projects/painter/                        *
00006 *                                                                                 *
00007 * Redistribution and use in source and binary forms, with or without modification,*
00008 * are permitted provided that the following conditions are met:                   *
00009 *                                                                                 *
00010 * 1. Redistributions of source code must retain the above copyright notice,       *
00011 * this list of conditions and the following disclaimer.                           *
00012 *                                                                                 *
00013 * 2. Redistributions in binary form must reproduce the above copyright notice,    *
00014 * this list of conditions and the following disclaimer in the documentation       *
00015 * and/or other materials provided with the distribution.                          *
00016 *                                                                                 *
00017 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"     *
00018 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE       *
00019 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE      *
00020 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE        *
00021 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR             *
00022 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF            *
00023 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS        *
00024 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN         *
00025 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)         *
00026 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF          *
00027 * THE POSSIBILITY OF SUCH DAMAGE.                                                 *
00028 **********************************************************************************/
00029 
00030 #include "filtergrave.h"
00031 #include <cmath>
00032 
00033 GraveFilter::GraveFilter() : StatelessTransformationFilter() {}
00034 
00035 GraveFilter::~GraveFilter() {}
00036 
00037 ChannelFilter<unsigned char>* GraveFilter::EmptyClone()
00038 {
00039   GraveFilter *copy = new GraveFilter();
00040   copy->SetSubChannel(StatelessTransformationFilter::GetSubChannel());
00041   return(copy);
00042 }
00043 
00044 void GraveFilter::OnTransform(Channel<unsigned char>* source, Channel<unsigned char>* target, int x0, int y0, int x1, int y1)
00045 {
00046   int sh = abs(x1-x0) + abs(y1-y0);
00047   if(sh == 0)
00048     sh = 1;
00049   double diff;
00050   unsigned char current;
00051   for(int x=0;x<source->GetWidth();x++)
00052   {
00053     for(int y=0;y<source->GetHeight();y++)
00054     {
00055       diff=0;
00056       current = source->Get(x,y);
00057       if(x>=sh)
00058       {
00059         diff += abs(source->Get(x-sh,y)-current);
00060       }
00061       if(x<source->GetWidth()-sh)
00062       {
00063         diff += abs(source->Get(x+sh,y)-current);
00064       }
00065       if(y>=sh)
00066       {
00067         diff += abs(source->Get(x,y-sh)-current);
00068       }
00069       if(y<source->GetHeight()-sh)
00070       {
00071         diff += abs(source->Get(x,y+sh)-current);
00072       }
00073       diff /= 256/2;
00074       diff = tanh(diff); // diff=[0..4[
00075         //diff *= 255;
00076         //if(x1>0 && y1>0)
00077         //  diff *= ChannelFilter<unsigned char>::Get(x1-1,y1-1);
00078         //else
00079       diff *= source->Get(x,y);  
00080       target->Set(x,y,(unsigned char)(source->Get(x,y)-diff));;
00081     }
00082   }
00083 }

Erzeugt am Fri Jan 31 15:27:35 2003 für OOP Miniprojekt von doxygen1.3-rc2