Hauptseite   Klassenhierarchie   Auflistung der Dateien  

filterpr.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 "filterpr.h"
00031 #include <cmath>
00032 
00033 PrFilter::PrFilter() : StatefullTransformationFilter()
00034 {
00035 }
00036 
00037 PrFilter::~PrFilter()
00038 {
00039 }
00040 
00041 ChannelFilter<unsigned char>* PrFilter::EmptyClone()
00042 {
00043   PrFilter *copy = new PrFilter();
00044   copy->SetSubChannel(GetSubChannel());
00045   return(copy);
00046 }
00047 
00048 void PrFilter::OnStart(Channel<unsigned char>* source, Channel<unsigned char>* target, int x, int y)
00049 {
00050   height = target->GetHeight();
00051   width = target->GetWidth();
00052 }
00053 
00054 void PrFilter::OnEnd(Channel<unsigned char>* source, Channel<unsigned char>* target, int x0, int y0, int x1, int y1)
00055 {
00056   int height = target->GetHeight();
00057   int width = target->GetWidth();
00058   for(int x=0;x<width;x++)
00059     for(int y=0;y<height;y++)
00060       source->Set(x,y,target->Get(x,y));
00061 }
00062 
00063 bool PrFilter::OnRender(Channel<unsigned char>* source, Channel<unsigned char>* target, int x0, int y0, int x1, int y1)
00064 {
00065   int current, sum;
00066   for(int x=0;x<width;x++)
00067     for(int y=0;y<height;y++)
00068     {
00069       current = target->Get(x,y);
00070       sum = 0;
00071       if(x>0)
00072         sum+=source->Get(x-1,y);
00073       if(y>0)
00074         sum+=source->Get(x,y-1);
00075       if(x<width-1)
00076         sum+=source->Get(x+1,y);
00077       if(y<height-1)
00078         sum+=source->Get(x,y+1);
00079       sum /= 16;
00080       if(abs(sum) > 16)
00081         target->Set(x,y,(unsigned)(abs(current+(sum))%255));
00082     }
00083   return(true);
00084 }
00085 

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