Hauptseite   Klassenhierarchie   Auflistung der Dateien  

filterlevel.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 "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 

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