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