+ use vertex_converters where applicable

This commit is contained in:
Artem Pavlenko 2012-05-09 15:45:44 +01:00
parent aad7c5e384
commit 953db9b209

View file

@ -40,6 +40,7 @@
#include <mapnik/warp.hpp> #include <mapnik/warp.hpp>
#include <mapnik/config.hpp> #include <mapnik/config.hpp>
#include <mapnik/text_path.hpp> #include <mapnik/text_path.hpp>
#include <mapnik/vertex_converters.hpp>
// cairo // cairo
#include <cairomm/context.h> #include <cairomm/context.h>
@ -51,6 +52,7 @@
#include <boost/make_shared.hpp> #include <boost/make_shared.hpp>
// agg // agg
#include "agg_conv_clip_polyline.h" #include "agg_conv_clip_polyline.h"
#include "agg_conv_clip_polygon.h" #include "agg_conv_clip_polygon.h"
#include "agg_conv_smooth_poly1.h" #include "agg_conv_smooth_poly1.h"
@ -59,9 +61,6 @@
#include "agg_path_storage.h" #include "agg_path_storage.h"
#include "agg_ellipse.h" #include "agg_ellipse.h"
// stl
#include <iostream>
namespace mapnik namespace mapnik
{ {
class cairo_pattern : private boost::noncopyable class cairo_pattern : private boost::noncopyable
@ -814,33 +813,21 @@ void cairo_renderer_base::start_map_processing(Map const& map)
else context.set_operator(src_over); else context.set_operator(src_over);
context.set_color(sym.get_fill(), sym.get_opacity()); context.set_color(sym.get_fill(), sym.get_opacity());
box2d<double> inflated_extent = query_extent_ * 1.1;
for (unsigned i = 0; i < feature->num_geometries(); ++i) typedef boost::mpl::vector<clip_poly_tag,transform_tag,affine_transform_tag,smooth_tag> conv_types;
vertex_converter<box2d<double>,cairo_context,polygon_symbolizer, proj_transform, CoordTransform, conv_types>
converter(query_extent_,context,sym,t_,prj_trans,1.0);
if (sym.clip()) converter.set<clip_poly_tag>(); //optional clip (default: true)
converter.set<transform_tag>(); //always transform
converter.set<affine_transform_tag>();
if (sym.smooth() > 0.0) converter.set<smooth_tag>(); // optional smooth converter
BOOST_FOREACH( geometry_type & geom, feature->paths())
{ {
geometry_type & geom = feature->get_geometry(i);
if (geom.num_points() > 2) if (geom.num_points() > 2)
{ {
if (sym.smooth() > 0.0) converter.apply(geom);
{
typedef agg::conv_clip_polygon<geometry_type> clipped_geometry_type;
typedef coord_transform2<CoordTransform,clipped_geometry_type> path_type;
typedef agg::conv_smooth_poly1_curve<path_type> smooth_type;
clipped_geometry_type clipped(geom);
clipped.clip_box(inflated_extent.minx(),inflated_extent.miny(),inflated_extent.maxx(),inflated_extent.maxy());
path_type path(t_,clipped,prj_trans);
smooth_type smooth(path);
smooth.smooth_value(sym.smooth());
context.add_agg_path(smooth);
}
else
{
typedef agg::conv_clip_polygon<geometry_type> clipped_geometry_type;
typedef coord_transform2<CoordTransform,clipped_geometry_type> path_type;
clipped_geometry_type clipped(geom);
clipped.clip_box(query_extent_.minx(),query_extent_.miny(),query_extent_.maxx(),query_extent_.maxy());
path_type path(t_,clipped,prj_trans);
context.add_path(path);
}
} }
} }
// fill polygon // fill polygon
@ -961,11 +948,8 @@ void cairo_renderer_base::start_map_processing(Map const& map)
mapnik::feature_ptr const& feature, mapnik::feature_ptr const& feature,
proj_transform const& prj_trans) proj_transform const& prj_trans)
{ {
typedef agg::conv_clip_polyline<geometry_type> clipped_geometry_type;
typedef coord_transform2<CoordTransform,clipped_geometry_type> path_type;
mapnik::stroke const& stroke_ = sym.get_stroke();
cairo_context context(context_); cairo_context context(context_);
mapnik::stroke const& stroke_ = sym.get_stroke();
if (sym.comp_op()) context.set_operator(*sym.comp_op()); if (sym.comp_op()) context.set_operator(*sym.comp_op());
else context.set_operator(src_over); else context.set_operator(src_over);
@ -979,20 +963,26 @@ void cairo_renderer_base::start_map_processing(Map const& map)
context.set_dash(stroke_.get_dash_array()); context.set_dash(stroke_.get_dash_array());
} }
for (unsigned i = 0; i < feature->num_geometries(); ++i)
{
geometry_type & geom = feature->get_geometry(i);
typedef boost::mpl::vector<clip_line_tag,transform_tag, offset_transform_tag, affine_transform_tag, smooth_tag> conv_types;
vertex_converter<box2d<double>,cairo_context,line_symbolizer, proj_transform, CoordTransform,conv_types>
converter(query_extent_,context ,sym,t_,prj_trans,1.0);
if (sym.clip()) converter.set<clip_line_tag>(); // optional clip (default: true)
converter.set<transform_tag>(); // always transform
if (fabs(sym.offset()) > 0.0) converter.set<offset_transform_tag>(); // parallel offset
converter.set<affine_transform_tag>(); // optional affine transform
if (sym.smooth() > 0.0) converter.set<smooth_tag>(); // optional smooth converter
BOOST_FOREACH( geometry_type & geom, feature->paths())
{
if (geom.num_points() > 1) if (geom.num_points() > 1)
{ {
//cairo_context context(context_); converter.apply(geom);
clipped_geometry_type clipped(geom);
clipped.clip_box(query_extent_.minx(),query_extent_.miny(),query_extent_.maxx(),query_extent_.maxy());
path_type path(t_,clipped,prj_trans);
context.add_path(path);
} }
} }
// stroke
context.stroke(); context.stroke();
} }
@ -1180,7 +1170,8 @@ void cairo_renderer_base::start_map_processing(Map const& map)
if (sym.comp_op()) context.set_operator(*sym.comp_op()); if (sym.comp_op()) context.set_operator(*sym.comp_op());
else context.set_operator(src_over); else context.set_operator(src_over);
while (helper.next()) { while (helper.next())
{
placements_type &placements = helper.placements(); placements_type &placements = helper.placements();
for (unsigned int ii = 0; ii < placements.size(); ++ii) for (unsigned int ii = 0; ii < placements.size(); ++ii)
{ {
@ -1273,9 +1264,6 @@ void cairo_renderer_base::start_map_processing(Map const& map)
mapnik::feature_ptr const& feature, mapnik::feature_ptr const& feature,
proj_transform const& prj_trans) proj_transform const& prj_trans)
{ {
typedef agg::conv_clip_polygon<geometry_type> clipped_geometry_type;
typedef coord_transform2<CoordTransform,clipped_geometry_type> path_type;
cairo_context context(context_); cairo_context context(context_);
if (sym.comp_op()) context.set_operator(*sym.comp_op()); if (sym.comp_op()) context.set_operator(*sym.comp_op());
else context.set_operator(src_over); else context.set_operator(src_over);
@ -1290,19 +1278,23 @@ void cairo_renderer_base::start_map_processing(Map const& map)
context.set_pattern(pattern); context.set_pattern(pattern);
for (unsigned i = 0; i < feature->num_geometries(); ++i) typedef boost::mpl::vector<clip_poly_tag,transform_tag,affine_transform_tag,smooth_tag> conv_types;
{ vertex_converter<box2d<double>,cairo_context,polygon_pattern_symbolizer, proj_transform, CoordTransform, conv_types>
geometry_type & geom = feature->get_geometry(i); converter(query_extent_,context,sym,t_,prj_trans,1.0);
if (sym.clip()) converter.set<clip_poly_tag>(); //optional clip (default: true)
converter.set<transform_tag>(); //always transform
converter.set<affine_transform_tag>();
if (sym.smooth() > 0.0) converter.set<smooth_tag>(); // optional smooth converter
BOOST_FOREACH( geometry_type & geom, feature->paths())
{
if (geom.num_points() > 2) if (geom.num_points() > 2)
{ {
clipped_geometry_type clipped(geom); converter.apply(geom);
clipped.clip_box(query_extent_.minx(),query_extent_.miny(),query_extent_.maxx(),query_extent_.maxy()); }
path_type path(t_,clipped,prj_trans); }
context.add_path(path);
}
}
// fill polygon // fill polygon
context.fill(); context.fill();
} }