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 "filterlevel.h" 00031 00032 LevelFilter::LevelFilter() : ChannelFilter<unsigned char>() 00033 { 00034 } 00035 00036 LevelFilter::~LevelFilter() 00037 { 00038 } 00039 00040 void LevelFilter::OnMouseEvent(const int button, const int state, int x, int y) 00041 { 00042 if(button!=0) 00043 { 00044 return; 00045 } 00046 if(state == 0 && button == 0) 00047 { 00048 unsigned char current; 00049 unsigned char min = 255; 00050 unsigned char max = 0; 00051 int x1,y1; 00052 for(x1=0;x1<GetWidth();x1++) 00053 for(y1=0;y1<GetHeight();y1++) 00054 { 00055 current = ChannelFilter<unsigned char>::Get(x1,y1); 00056 if(current < min) 00057 min = current; 00058 if(current > max) 00059 max = current; 00060 } 00061 for(x1=0;x1<GetWidth();x1++) 00062 for(y1=0;y1<GetHeight();y1++) 00063 { 00064 current = ChannelFilter<unsigned char>::Get(x1,y1); 00065 ChannelFilter<unsigned char>::Set(x1,y1,(unsigned char)((current-min)*255.0/(max-min))); 00066 } 00067 } 00068 } 00069 00070 ChannelFilter<unsigned char>* LevelFilter::EmptyClone() 00071 { 00072 LevelFilter *copy = new LevelFilter(); 00073 copy->SetSubChannel(GetSubChannel()); 00074 return(copy); 00075 } 00076
1.3-rc2