/home/andreas/src/svn/mapnik/include/mapnik/gamma.hpp

Go to the documentation of this file.
00001 /*****************************************************************************
00002  * 
00003  * This file is part of Mapnik (c++ mapping toolkit)
00004  *
00005  * Copyright (C) 2006 Artem Pavlenko
00006  *
00007  * This library is free software; you can redistribute it and/or
00008  * modify it under the terms of the GNU Lesser General Public
00009  * License as published by the Free Software Foundation; either
00010  * version 2.1 of the License, or (at your option) any later version.
00011  *
00012  * This library is distributed in the hope that it will be useful,
00013  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00014  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00015  * Lesser General Public License for more details.
00016  *
00017  * You should have received a copy of the GNU Lesser General Public
00018  * License along with this library; if not, write to the Free Software
00019  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
00020  *
00021  *****************************************************************************/
00022 
00023 //$Id: gamma.hpp 39 2005-04-10 20:39:53Z pavlenko $
00024 
00025 #ifndef GAMMA_HPP
00026 #define GAMMA_HPP
00027 
00028 namespace mapnik 
00029 {
00030     struct MAPNIK_DECL gamma
00031     {
00032         unsigned char g2l[256];
00033         unsigned char l2g[256];
00034         gamma(double gamma=2.0)
00035         {
00036             int result;
00037             for (int i=0;i< 256;i++)
00038             {
00039                 result=(int)(pow(i/255.0,gamma) * 255.0 + 0.5);
00040                 g2l[i]=(unsigned char)result;
00041             }
00042             for (int i = 0; i < 256; i++)
00043             {
00044                 result = (int)(pow(i/255.0, 1/gamma) * 255.0 + 0.5);
00045                 l2g[i] = (unsigned char)result;
00046             }
00047         }
00048     };
00049 }
00050 
00051 #endif  //GAMMA_HPP

Generated on Thu Jul 19 17:59:26 2007 for Mapnik by  doxygen 1.4.7