00001 /********************************************************************************** 00002 * Copyright (c) 2003, Matthias Bader and Christoph Rueegg <opendev@cdrnet.ch> * 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 "filterposterize.h" 00031 00032 00033 PosterizeFilter::PosterizeFilter() : StatelessTransformationFilter() 00034 { 00035 } 00036 00037 PosterizeFilter::~PosterizeFilter() 00038 { 00039 } 00040 00041 void PosterizeFilter::OnTransform(Channel<unsigned char>* source, Channel<unsigned char>* target, int x0, int y0, int x1, int y1) 00042 { 00043 int width = target->GetWidth(); 00044 int height = target->GetHeight(); 00045 const int sh = 2; 00046 int diff; 00047 00048 int current; 00049 for(int x=0;x<width;x++) 00050 { 00051 for(int y=0;y<height;y++) 00052 { 00053 diff=0; 00054 current = source->Get(x,y); 00055 for(int xx=x-sh;xx<=x+sh;xx++) 00056 if (xx>=0 && xx<width) 00057 for(int yy=y-sh;yy<=y+sh;yy++) 00058 if(yy>=0 && yy<height) 00059 diff += source->Get(xx,yy)-current; 00060 00061 diff /= 25; 00062 00063 target->Set(x,y,current+(unsigned char)diff); 00064 } 00065 } 00066 00067 for(int x1=0;x1<ChannelFilter<unsigned char>::GetWidth();x1++) 00068 for(int y1=0;y1<ChannelFilter<unsigned char>::GetHeight();y1++) 00069 target->Set(x1,y1,abs((target->Get(x1,y1)/32)<<5)); 00070 00071 00072 } 00073 00074 00075 00076 00077 00078 ChannelFilter<unsigned char>* PosterizeFilter::EmptyClone() 00079 { 00080 PosterizeFilter *copy = new PosterizeFilter(); 00081 copy->SetSubChannel(StatelessTransformationFilter::GetSubChannel()); 00082 return(copy); 00083 }
1.3-rc2