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 }
1.3-rc2