/***************************************************************************** * * This file is part of Mapnik (c++ mapping toolkit) * * Copyright (C) 2010 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$ // mapnik #include #include #include #include #include "agg_basics.h" #include "agg_rendering_buffer.h" #include "agg_pixfmt_rgba.h" #include "agg_rasterizer_scanline_aa.h" #include "agg_scanline_u.h" // stl #include namespace mapnik { struct rasterizer : agg::rasterizer_scanline_aa<>, boost::noncopyable {}; template void agg_renderer::process(point_symbolizer const& sym, Feature const& feature, proj_transform const& prj_trans) { typedef coord_transform2 path_type; typedef agg::pixfmt_rgba32 pixfmt; typedef agg::renderer_base renderer_base; typedef agg::renderer_scanline_aa_solid renderer_solid; double x; double y; double z=0; std::string filename = path_processor_type::evaluate( *sym.get_filename(), feature); boost::optional data; if ( filename.empty() ) { // default OGC 4x4 black square data = boost::optional(new image_data_32(4,4)); (*data)->set(0xff000000); } else if (is_svg(filename)) { // SVG boost::optional marker; ras_ptr->reset(); ras_ptr->gamma(agg::gamma_linear()); agg::scanline_u8 sl; agg::rendering_buffer buf(pixmap_.raw_data(), width_, height_, width_ * 4); pixfmt pixf(buf); renderer_base renb(pixf); renderer_solid ren(renb); box2d extent; marker = marker_cache::instance()->find(filename, true); if (marker && *marker) { double x1, y1, x2, y2; (*marker)->bounding_rect(&x1, &y1, &x2, &y2); for (unsigned i=0; i const& m = sym.get_transform(); tr.load_from(&m[0]); tr *= agg::trans_affine_translation(x, y); tr.transform(&x1,&y1); tr.transform(&x2,&y2); extent.init(x1,y1,x2,y2); if (sym.get_allow_overlap() || detector_.has_placement(extent)) { (*marker)->render(*ras_ptr, sl, ren, tr, renb.clip_box(), sym.get_opacity()); detector_.insert(extent); } } } } else { data = mapnik::image_cache::instance()->find(filename,true); if ( data ) { for (unsigned i=0;iwidth(); int h = (*data)->height(); int px=int(floor(x - 0.5 * w)); int py=int(floor(y - 0.5 * h)); box2d label_ext (floor(x - 0.5 * w), floor(y - 0.5 * h), ceil (x + 0.5 * w), ceil (y + 0.5 * h)); if (sym.get_allow_overlap() || detector_.has_placement(label_ext)) { pixmap_.set_rectangle_alpha2(*(*data),px,py,sym.get_opacity()); detector_.insert(label_ext); } } } } } template void agg_renderer::process(point_symbolizer const&, Feature const&, proj_transform const&); }