2006-03-31 12:32:02 +02:00
|
|
|
/*****************************************************************************
|
|
|
|
*
|
|
|
|
* This file is part of Mapnik (c++ mapping toolkit)
|
2005-06-14 17:06:59 +02:00
|
|
|
*
|
2006-03-31 12:32:02 +02:00
|
|
|
* Copyright (C) 2006 Artem Pavlenko, Jean-Francois Doyon
|
2005-06-14 17:06:59 +02:00
|
|
|
*
|
2006-03-31 12:32:02 +02:00
|
|
|
* 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,
|
2005-06-14 17:06:59 +02:00
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2006-03-31 12:32:02 +02:00
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
2005-06-14 17:06:59 +02:00
|
|
|
*
|
2006-03-31 12:32:02 +02:00
|
|
|
* 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
|
|
|
|
*
|
|
|
|
*****************************************************************************/
|
2006-02-01 00:09:52 +01:00
|
|
|
//$Id$
|
2005-06-14 17:06:59 +02:00
|
|
|
|
2008-02-07 11:14:14 +01:00
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#include <png.h>
|
|
|
|
}
|
2008-01-25 15:40:48 +01:00
|
|
|
|
|
|
|
// boost
|
2006-09-11 11:48:27 +02:00
|
|
|
#include <boost/python.hpp>
|
|
|
|
#include <boost/python/module.hpp>
|
|
|
|
#include <boost/python/def.hpp>
|
2008-01-25 15:40:48 +01:00
|
|
|
// mapnik
|
2006-10-04 13:22:18 +02:00
|
|
|
#include <mapnik/graphics.hpp>
|
2007-06-12 21:30:58 +02:00
|
|
|
#include <mapnik/image_util.hpp>
|
2008-01-25 15:40:48 +01:00
|
|
|
#include <mapnik/jpeg_io.hpp>
|
|
|
|
#include <mapnik/png_io.hpp>
|
2008-02-19 12:28:20 +01:00
|
|
|
#include <mapnik/image_reader.hpp>
|
2008-01-25 15:40:48 +01:00
|
|
|
#include <sstream>
|
2009-01-17 21:34:58 +01:00
|
|
|
// cairo
|
|
|
|
#if defined(HAVE_CAIRO) && defined(HAVE_PYCAIRO)
|
|
|
|
#include <cairomm/surface.h>
|
|
|
|
#include <pycairo.h>
|
|
|
|
#endif
|
2005-06-14 17:06:59 +02:00
|
|
|
|
2009-12-16 21:02:06 +01:00
|
|
|
using mapnik::image_32;
|
|
|
|
using mapnik::image_reader;
|
2008-02-19 12:28:20 +01:00
|
|
|
using mapnik::get_image_reader;
|
|
|
|
using mapnik::type_from_filename;
|
2006-03-30 00:26:55 +02:00
|
|
|
using namespace boost::python;
|
2007-06-12 21:30:58 +02:00
|
|
|
using mapnik::save_to_file;
|
2006-03-30 00:26:55 +02:00
|
|
|
|
2008-01-25 15:40:48 +01:00
|
|
|
// output 'raw' pixels
|
2009-12-16 21:02:06 +01:00
|
|
|
PyObject* tostring1( image_32 const& im)
|
2005-06-14 17:06:59 +02:00
|
|
|
{
|
2006-03-30 00:26:55 +02:00
|
|
|
int size = im.width() * im.height() * 4;
|
|
|
|
return ::PyString_FromStringAndSize((const char*)im.raw_data(),size);
|
2006-02-01 00:09:52 +01:00
|
|
|
}
|
2005-06-14 17:06:59 +02:00
|
|
|
|
2008-01-25 15:40:48 +01:00
|
|
|
// encode (png,jpeg)
|
2009-12-16 21:02:06 +01:00
|
|
|
PyObject* tostring2(image_32 const & im, std::string const& format)
|
2008-01-25 15:40:48 +01:00
|
|
|
{
|
2010-06-02 13:03:30 +02:00
|
|
|
std::string s = save_to_string(im, format);
|
|
|
|
return ::PyString_FromStringAndSize(s.data(),s.size());
|
2008-01-25 15:40:48 +01:00
|
|
|
}
|
|
|
|
|
2009-12-16 21:02:06 +01:00
|
|
|
void (*save_to_file1)( mapnik::image_32 const&, std::string const&,std::string const&) = mapnik::save_to_file;
|
|
|
|
void (*save_to_file2)( mapnik::image_32 const&, std::string const&) = mapnik::save_to_file;
|
2007-08-01 11:59:23 +02:00
|
|
|
|
2009-12-16 21:02:06 +01:00
|
|
|
boost::shared_ptr<image_32> open_from_file(std::string const& filename)
|
2008-02-19 12:28:20 +01:00
|
|
|
{
|
2009-12-16 21:02:06 +01:00
|
|
|
boost::optional<std::string> type = type_from_filename(filename);
|
|
|
|
if (type)
|
|
|
|
{
|
2010-06-02 13:03:30 +02:00
|
|
|
std::auto_ptr<image_reader> reader(get_image_reader(filename,*type));
|
|
|
|
if (reader.get())
|
|
|
|
{
|
|
|
|
boost::shared_ptr<image_32> image_ptr(new image_32(reader->width(),reader->height()));
|
|
|
|
reader->read(0,0,image_ptr->data());
|
|
|
|
return image_ptr;
|
|
|
|
}
|
|
|
|
throw mapnik::image_reader_exception("Failed to load: " + filename);
|
2009-12-16 21:02:06 +01:00
|
|
|
}
|
|
|
|
throw mapnik::image_reader_exception("Unsupported image format:" + filename);
|
2008-02-19 12:28:20 +01:00
|
|
|
}
|
2009-12-16 21:02:06 +01:00
|
|
|
|
|
|
|
void blend (image_32 & im, unsigned x, unsigned y, image_32 const& im2, float opacity)
|
2007-08-01 11:59:23 +02:00
|
|
|
{
|
2010-06-02 13:03:30 +02:00
|
|
|
im.set_rectangle_alpha2(im2.data(),x,y,opacity);
|
2007-08-01 11:59:23 +02:00
|
|
|
}
|
|
|
|
|
2009-01-28 22:11:10 +01:00
|
|
|
#if defined(HAVE_CAIRO) && defined(HAVE_PYCAIRO)
|
2009-12-16 21:02:06 +01:00
|
|
|
boost::shared_ptr<image_32> from_cairo(PycairoSurface* surface)
|
2009-01-17 21:34:58 +01:00
|
|
|
{
|
|
|
|
Cairo::RefPtr<Cairo::ImageSurface> s(new Cairo::ImageSurface(surface->surface));
|
2009-12-16 21:02:06 +01:00
|
|
|
boost::shared_ptr<image_32> image_ptr(new image_32(s));
|
2009-01-17 21:34:58 +01:00
|
|
|
return image_ptr;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2006-02-01 00:09:52 +01:00
|
|
|
void export_image()
|
|
|
|
{
|
|
|
|
using namespace boost::python;
|
2009-12-16 21:02:06 +01:00
|
|
|
class_<image_32,boost::shared_ptr<image_32> >("Image","This class represents a 32 bit RGBA image.",init<int,int>())
|
2010-06-02 13:03:30 +02:00
|
|
|
.def("width",&image_32::width)
|
|
|
|
.def("height",&image_32::height)
|
|
|
|
.def("view",&image_32::get_view)
|
|
|
|
.add_property("background",make_function
|
|
|
|
(&image_32::get_background,return_value_policy<copy_const_reference>()),
|
|
|
|
&image_32::set_background, "The background color of the image.")
|
|
|
|
.def("blend",&blend)
|
|
|
|
.def("tostring",&tostring1)
|
|
|
|
.def("tostring",&tostring2)
|
|
|
|
.def("save", save_to_file1)
|
|
|
|
.def("save", save_to_file2)
|
|
|
|
.def("open",open_from_file)
|
|
|
|
.staticmethod("open")
|
2009-01-28 22:11:10 +01:00
|
|
|
#if defined(HAVE_CAIRO) && defined(HAVE_PYCAIRO)
|
2010-06-02 13:03:30 +02:00
|
|
|
.def("from_cairo",&from_cairo)
|
|
|
|
.staticmethod("from_cairo")
|
2009-01-17 21:34:58 +01:00
|
|
|
#endif
|
2010-06-02 13:03:30 +02:00
|
|
|
;
|
2008-02-19 12:28:20 +01:00
|
|
|
|
2006-02-01 00:09:52 +01:00
|
|
|
}
|