Hauptseite   Klassenhierarchie   Auflistung der Dateien  

alphaimage.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 "alphaimage.h"
00031 #include "grayimage.h"
00032 
00033 AlphaImage::AlphaImage(const int height, const int width)
00034 {
00035   alphadata = new Channel<unsigned char>(height,width);
00036   alphafilter = alphadata;
00037   this->width = width;
00038   this->height = height;
00039 }
00040 
00041 AlphaImage::~AlphaImage()
00042 {
00043   delete alphadata;
00044 }
00045 
00046 inline unsigned char AlphaImage::GetAlpha(const int x, const int y)
00047 {
00048   return(alphafilter->Get(x,y));
00049 }
00050 
00051 inline void AlphaImage::SetAlpha(const int x, const int y, const unsigned char val)
00052 {
00053   alphafilter->Set(x,y,val);
00054 }
00055 
00056 void AlphaImage::AttachAlphaFilter(ChannelFilter<unsigned char>* filter)
00057 {
00058   filter->SetSubChannel(alphafilter);
00059   alphafilter = filter;
00060 }
00061 
00062 void AlphaImage::RemoveAlphaFilters()
00063 {
00064   alphafilter->ResetChannel();
00065   alphafilter = alphadata;
00066 }
00067 
00068 void AlphaImage::LoadAlphaMap(const char* filename)
00069 {
00070   AlphaImage *a = GrayImage::CreateFromTiff(filename);
00071   for(int x=0;x<width && x<a->width;x++)
00072     for(int y=0;y<height && y<a->height;y++)
00073       alphafilter->Set(x,y,a->GetLuminance(x,y));
00074 }
00075 
00076 int AlphaImage::GetWidth()
00077 {
00078   return(width);
00079 }
00080 
00081 int AlphaImage::GetHeight()
00082 {
00083   return(height);
00084 }

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