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 __GRAYIMAGE_H__ 00033 #define __GRAYIMAGE_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 00046 class GrayImage: public AlphaImage 00047 { 00048 protected: 00049 Channel<unsigned char> *luminancedata; 00050 Channel<unsigned char> *luminancefilter; 00051 public: 00052 GrayImage(const int height, const int width); 00053 virtual ~GrayImage(); 00054 double Draw(); 00055 unsigned char GetLuminance(const int x, const int y); 00056 void SetLuminance(const int x, const int y, const unsigned char val); 00057 void RemoveLuminanceFilters(); 00058 void AttachLuminanceFilter(ChannelFilter<unsigned char>* filter); 00059 static GrayImage* CreateFromTiff(const char* filename); 00060 void WriteToTiff(const char* filename); 00061 }; 00062 00063 #endif
1.3-rc2