223 lines
5.9 KiB
C++
223 lines
5.9 KiB
C++
/*****************************************************************************
|
|
*
|
|
* This file is part of Mapnik (c++ mapping toolkit)
|
|
*
|
|
* Copyright (C) 2011 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
|
|
*
|
|
*****************************************************************************/
|
|
|
|
//mapnik
|
|
#include <mapnik/symbolizer.hpp>
|
|
#include <mapnik/map.hpp>
|
|
#include <mapnik/transform_processor.hpp>
|
|
|
|
namespace mapnik {
|
|
|
|
void evaluate_transform(agg::trans_affine& tr, Feature const& feature,
|
|
transform_list_ptr const& trans_expr)
|
|
{
|
|
#ifdef MAPNIK_LOG
|
|
MAPNIK_LOG_DEBUG(transform) << "transform: evaluate "
|
|
<< (trans_expr
|
|
? transform_processor_type::to_string(*trans_expr)
|
|
: std::string("null"));
|
|
#endif
|
|
|
|
if (trans_expr)
|
|
{
|
|
transform_processor_type::evaluate(tr, feature, *trans_expr);
|
|
}
|
|
}
|
|
|
|
// default ctor
|
|
symbolizer_base::symbolizer_base()
|
|
: properties_(),
|
|
properties_complete_(),
|
|
writer_name_(),
|
|
writer_ptr_(),
|
|
comp_op_(src_over),
|
|
clip_(true),
|
|
smooth_value_(0.0)
|
|
{
|
|
}
|
|
|
|
// copy ctor
|
|
symbolizer_base::symbolizer_base(symbolizer_base const& other)
|
|
: comp_op_(other.comp_op_),
|
|
affine_transform_(other.affine_transform_),
|
|
clip_(other.clip_),
|
|
smooth_value_(other.smooth_value_) {}
|
|
|
|
void symbolizer_base::add_metawriter(std::string const& name, metawriter_properties const& properties)
|
|
{
|
|
writer_name_ = name;
|
|
properties_ = properties;
|
|
}
|
|
|
|
void symbolizer_base::add_metawriter(metawriter_ptr writer_ptr, metawriter_properties const& properties,
|
|
std::string const& name)
|
|
{
|
|
writer_ptr_ = writer_ptr;
|
|
properties_ = properties;
|
|
writer_name_ = name;
|
|
if (writer_ptr) {
|
|
properties_complete_ = writer_ptr->get_default_properties();
|
|
properties_complete_.insert(properties_.begin(), properties_.end());
|
|
} else {
|
|
properties_complete_.clear();
|
|
}
|
|
}
|
|
|
|
void symbolizer_base::cache_metawriters(Map const &m)
|
|
{
|
|
if (writer_name_.empty()) {
|
|
properties_complete_.clear();
|
|
writer_ptr_ = metawriter_ptr();
|
|
return; // No metawriter
|
|
}
|
|
|
|
writer_ptr_ = m.find_metawriter(writer_name_);
|
|
if (writer_ptr_) {
|
|
properties_complete_ = writer_ptr_->get_default_properties();
|
|
properties_complete_.insert(properties_.begin(), properties_.end());
|
|
} else {
|
|
properties_complete_.clear();
|
|
MAPNIK_LOG_WARN(symbolizer) << "Metawriter '" << writer_name_ << "' used but not defined.";
|
|
}
|
|
}
|
|
|
|
metawriter_with_properties symbolizer_base::get_metawriter() const
|
|
{
|
|
return metawriter_with_properties(writer_ptr_, properties_complete_);
|
|
}
|
|
|
|
void symbolizer_base::set_comp_op(composite_mode_e comp_op)
|
|
{
|
|
comp_op_ = comp_op;
|
|
}
|
|
|
|
composite_mode_e symbolizer_base::comp_op() const
|
|
{
|
|
return comp_op_;
|
|
}
|
|
|
|
void symbolizer_base::set_transform(transform_type const& affine_transform)
|
|
{
|
|
affine_transform_ = affine_transform;
|
|
|
|
#ifdef MAPNIK_LOG
|
|
MAPNIK_LOG_DEBUG(load_map) << "map_parser: set_transform: "
|
|
<< (affine_transform_
|
|
? transform_processor_type::to_string(*affine_transform_)
|
|
: std::string("null"));
|
|
#endif
|
|
}
|
|
|
|
transform_type const& symbolizer_base::get_transform() const
|
|
{
|
|
return affine_transform_;
|
|
}
|
|
|
|
std::string symbolizer_base::get_transform_string() const
|
|
{
|
|
if (affine_transform_)
|
|
return transform_processor_type::to_string(*affine_transform_);
|
|
else
|
|
return std::string();
|
|
}
|
|
|
|
void symbolizer_base::set_clip(bool clip)
|
|
{
|
|
clip_ = clip;
|
|
}
|
|
|
|
bool symbolizer_base::clip() const
|
|
{
|
|
return clip_;
|
|
}
|
|
|
|
void symbolizer_base::set_smooth(double smooth)
|
|
{
|
|
smooth_value_ = smooth;
|
|
}
|
|
|
|
double symbolizer_base::smooth() const
|
|
{
|
|
return smooth_value_;
|
|
}
|
|
|
|
///////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
symbolizer_with_image::symbolizer_with_image(path_expression_ptr file)
|
|
: image_filename_( file ),
|
|
image_opacity_(1.0f)
|
|
{
|
|
}
|
|
|
|
symbolizer_with_image::symbolizer_with_image( symbolizer_with_image const& rhs)
|
|
: image_filename_(rhs.image_filename_),
|
|
image_opacity_(rhs.image_opacity_),
|
|
image_transform_(rhs.image_transform_)
|
|
{
|
|
}
|
|
|
|
path_expression_ptr symbolizer_with_image::get_filename() const
|
|
{
|
|
return image_filename_;
|
|
}
|
|
|
|
void symbolizer_with_image::set_filename(path_expression_ptr image_filename)
|
|
{
|
|
image_filename_ = image_filename;
|
|
}
|
|
|
|
void symbolizer_with_image::set_opacity(float opacity)
|
|
{
|
|
image_opacity_ = opacity;
|
|
}
|
|
|
|
float symbolizer_with_image::get_opacity() const
|
|
{
|
|
return image_opacity_;
|
|
}
|
|
|
|
void symbolizer_with_image::set_image_transform(transform_type const& tr)
|
|
{
|
|
image_transform_ = tr;
|
|
|
|
#ifdef MAPNIK_LOG
|
|
MAPNIK_LOG_DEBUG(load_map) << "map_parser: set_image_transform: "
|
|
<< (image_transform_
|
|
? transform_processor_type::to_string(*image_transform_)
|
|
: std::string("null"));
|
|
#endif
|
|
}
|
|
|
|
transform_type const& symbolizer_with_image::get_image_transform() const
|
|
{
|
|
return image_transform_;
|
|
}
|
|
|
|
std::string symbolizer_with_image::get_image_transform_string() const
|
|
{
|
|
if (image_transform_)
|
|
return transform_processor_type::to_string(*image_transform_);
|
|
else
|
|
return std::string();
|
|
}
|
|
|
|
} // end of namespace mapnik
|