Hauptseite   Klassenhierarchie   Auflistung der Dateien  

filterselect.cpp

00001 /**********************************************************************************
00002 * Copyright (c) 2003, Christoph Rueegg <opendev@cdrnet.ch> and Matthias Bader     *
00003 * Partially based on ideas of Tim Weyrich <weyrich@inf.ethz.ch>                   *
00004 * and/or the Swiss Federal Institute of Technology http://www.ethz.ch             *
00005 * All rights reserved.                                                            *
00006 *                                                                                 *
00007 * Project Website: http://www.cdrnet.net/projects/painter/                        *
00008 *                                                                                 *
00009 * Redistribution and use in source and binary forms, with or without modification,*
00010 * are permitted provided that the following conditions are met:                   *
00011 *                                                                                 *
00012 * 1. Redistributions of source code must retain the above copyright notice,       *
00013 * this list of conditions and the following disclaimer.                           *
00014 *                                                                                 *
00015 * 2. Redistributions in binary form must reproduce the above copyright notice,    *
00016 * this list of conditions and the following disclaimer in the documentation       *
00017 * and/or other materials provided with the distribution.                          *
00018 *                                                                                 *
00019 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"     *
00020 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE       *
00021 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE      *
00022 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE        *
00023 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR             *
00024 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF            *
00025 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS        *
00026 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN         *
00027 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)         *
00028 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF          *
00029 * THE POSSIBILITY OF SUCH DAMAGE.                                                 *
00030 **********************************************************************************/
00031 
00032 #include "filterselect.h"
00033 
00034 ChannelSelectBoxFilter::ChannelSelectBoxFilter() : ChannelFilter<unsigned char>()
00035 {
00036   active = false;
00037   x0 = y0 = x1 = y1 = 0;
00038 }
00039 
00040 ChannelSelectBoxFilter::~ChannelSelectBoxFilter()
00041 {
00042 }
00043 
00044 void ChannelSelectBoxFilter::OnMouseEvent(const int button, const int state, int x, int y)
00045 { 
00046   bool activity = active;
00047   if(!activity && button==0 && state==0)
00048   {
00049     active = true;
00050     ChannelFilter<unsigned char>::Normalize(&x,&y);
00051     x0 = x1 = x;
00052     y0 = y1 = y;
00053   }
00054   if(activity && button==0 && state==1)
00055   {
00056     active = false;
00057     x1 = x;
00058     y1 = y;
00059     ChannelFilter<unsigned char>::Normalize(&x0,&y0,&x1,&y1);
00060     InvertArea(x0,y0,x1,y1);
00061     OnAction(x0,y0,x1,y1);
00062   }
00063 }
00064 
00065 void ChannelSelectBoxFilter::OnMotionEvent(int x, int y)
00066 {
00067   ChannelFilter<unsigned char>::Normalize(&x,&y);
00068   if(active)
00069   {
00070     InvertArea(x0,y0,x1,y1,x,y);
00071     x1 = x;
00072     y1 = y;
00073   }
00074 }
00075 
00076 unsigned char ChannelSelectBoxFilter::Get(const int x, const int y)
00077 {
00078   return(active&&(x>=x0&&x<=x1||x>=x1&&x<=x0)&&(y>=y0&&y<=y1||y>=y1&&y<=y0)
00079     ? InvertPixel(ChannelFilter<unsigned char>::Get(x,y)) : ChannelFilter<unsigned char>::Get(x,y));
00080 }
00081 
00082 void ChannelSelectBoxFilter::Set(const int x, const int y, const unsigned char val)
00083 {
00084   if(active&&(x>=x0&&x<=x1||x>=x1&&x<=x0)&&(y>=y0&&y<=y1||y>=y1&&y<=y0))
00085     ChannelFilter<unsigned char>::Set(x,y,InvertPixel(val));
00086   else
00087     ChannelFilter<unsigned char>::Set(x,y,val);;
00088 }
00089 
00090 inline unsigned char ChannelSelectBoxFilter::InvertPixel(unsigned char val)
00091 {
00092   return(255 - val);
00093 }
00094 
00095 void ChannelSelectBoxFilter::InvertArea(int x0, int y0, int x1, int y1)
00096 {
00097   ChannelFilter<unsigned char>::Normalize(&x0,&y0,&x1,&y1);
00098   for(int x=x0;x<x1;x++)
00099     for(int y=y0;y<y1;y++)
00100       ChannelFilter<unsigned char>::Set(x,y,InvertPixel(ChannelFilter<unsigned char>::Get(x,y)));
00101 
00102 }
00103 void ChannelSelectBoxFilter::InvertArea(int x0, int y0, int x1a, int y1a, int x1b, int y1b)
00104 {
00105   InvertArea(x0,y1a,x1a,y1b);
00106   InvertArea(x1a,y0,x1b,y1b);
00107 }
00108 
00109 void ChannelSelectBoxFilter::ResetChannel()
00110 {
00111   if(active)
00112   {
00113     InvertArea(x0,y0,x1,y1);
00114     active = false;
00115   }
00116   ChannelFilter<unsigned char>::ResetChannel();
00117 }

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