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 }
1.3-rc2