/***************************************************************************** * * This file is part of Mapnik (c++ mapping toolkit) * * Copyright (C) 2006 Artem Pavlenko * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA * *****************************************************************************/ //$Id: image_util.hpp 39 2005-04-10 20:39:53Z pavlenko $ #ifndef IMAGE_UTIL_HPP #define IMAGE_UTIL_HPP namespace mapnik { class MAPNIK_DECL ImageUtils { public: static void save_to_file(const std::string& filename,const std::string& type,const Image32& image); private: static void save_as_png(const std::string& filename,const Image32& image); static void save_as_jpeg(const std::string& filename,int quality, const Image32& image); }; template double distance(T x0,T y0,T x1,T y1) { double dx = x1-x0; double dy = y1-y0; return sqrt(dx * dx + dy * dy); } template inline void scale_down2(Image& target,const Image& source) { int source_width=source.width(); int source_height=source.height(); int target_width=target.width(); int target_height=target.height(); if (target_width struct image_op { static void scale_up(Image& target,const Image& source) { if (scale<3) return; int source_width=source.width(); int source_height=source.height(); int target_width=target.width(); int target_height=target.height(); if (target_width struct image_op { static void scale_up(Image& target,const Image& source) { int source_width=source.width(); int source_height=source.height(); int target_width=target.width(); int target_height=target.height(); if (target_width<2*source_width || target_height<2*source_height) return; for (int y=0;y inline void scale_up(Image& target,const Image& source,unsigned scale) { int source_width=source.width(); int source_height=source.height(); int target_width=target.width(); int target_height=target.height(); if (target_width void scale_image(Image& target,const Image& source,unsigned scale) { if (scale==2) { image_op::scale_up(target,source); } else { scale_up(target,source,scale); } } template inline void scale_image (Image& target,const Image& source) { int source_width=source.width(); int source_height=source.height(); int target_width=target.width(); int target_height=target.height(); if (source_width<1 || source_height<1 || target_width<1 || target_height<1) return; int int_part_y=source_height/target_height; int fract_part_y=source_height%target_height; int err_y=0; int int_part_x=source_width/target_width; int fract_part_x=source_width%target_width; int err_x=0; int x=0,y=0,xs=0,ys=0; int prev_y=-1; for (y=0;y=target_width) { err_x-=target_width; ++xs; } } prev_y=ys; } ys+=int_part_y; err_y+=fract_part_y; if (err_y>=target_height) { err_y-=target_height; ++ys; } } } } #endif //IMAGE_UTIL_HPP