Hauptseite   Klassenhierarchie   Auflistung der Dateien  

rgbimage.h

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 #ifndef __RGBIMAGE_H__
00033 #define __RGBIMAGE_H__
00034 
00035 #include <cstdlib>
00036 #include <cstring>
00037 #include <cassert>
00038 #include <iostream>
00039 #include <cmath>
00040 #include <tiff.h>
00041 #include <tiffio.h>
00042 #include <GL/glut.h>
00043 
00044 #include "alphaimage.h"
00045 #include "hybridchannel.cpp"
00046 
00047 #define  HAVE_BIGENDIAN  (*(unsigned short *)"12" == 0x3132)
00048 #define  SWAP_UINT32(x)  (( ((uint32)(x))                 << 24) |  \
00049                           ((((uint32)(x)) & 0x0000ff00UL) <<  8) |  \
00050                           ((((uint32)(x)) & 0x00ff0000UL) >>  8) |  \
00051                           ( ((uint32)(x))                 >> 24))
00052 
00053 class RgbImage: public AlphaImage
00054 {
00055 protected:
00056   HybridRgbaChannel<unsigned char> *reddata;
00057   HybridRgbaChannel<unsigned char> *greendata;
00058   HybridRgbaChannel<unsigned char> *bluedata;
00059   Channel<unsigned char> *redfilter;
00060   Channel<unsigned char> *greenfilter;
00061   Channel<unsigned char> *bluefilter;
00062 public:
00063   RgbImage(HybridRgbaChannel<unsigned char>* red, HybridRgbaChannel<unsigned char>* green, HybridRgbaChannel<unsigned char>* blue);
00064   RgbImage(const int height, const int width);
00065   virtual ~RgbImage();
00066   double Draw();
00067   unsigned char GetLuminance(const int x, const int y);
00068   void SetLuminance(const int x, const int y, const unsigned char val);
00069   virtual unsigned char GetRed(const int x, const int y);
00070   virtual unsigned char GetGreen(const int x, const int y);
00071   virtual unsigned char GetBlue(const int x, const int y);
00072   virtual void SetRed(const int x, const int y, const unsigned char val);
00073   virtual void SetGreen(const int x, const int y, const unsigned char val);
00074   virtual void SetBlue(const int x, const int y, const unsigned char val);
00075   void RemoveLuminanceFilters();
00076   void AttachLuminanceFilter(ChannelFilter<unsigned char>* filter);
00077   virtual void RemoveRedFilters();
00078   virtual void AttachRedFilter(ChannelFilter<unsigned char>* filter);
00079   virtual void RemoveGreenFilters();
00080   virtual void AttachGreenFilter(ChannelFilter<unsigned char>* filter);
00081   virtual void RemoveBlueFilters();
00082   virtual void AttachBlueFilter(ChannelFilter<unsigned char>* filter);
00083   static RgbImage* CreateFromTiff(const char* filename);
00084   void WriteToTiff(const char* filename);
00085 };
00086 
00087 #endif

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