mapnik/include/mapnik/symbolizer_default_values.hpp
2015-02-07 12:23:35 +00:00

369 lines
7.9 KiB
C++

/*****************************************************************************
*
* This file is part of Mapnik (c++ mapping toolkit)
*
* Copyright (C) 2014 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
*
*****************************************************************************/
#ifndef MAPNIK_SYMBOLIZER_DEFAULT_VALUES_HPP
#define MAPNIK_SYMBOLIZER_DEFAULT_VALUES_HPP
#include <mapnik/symbolizer_keys.hpp>
#include <mapnik/color.hpp>
#include <type_traits>
namespace mapnik {
template <typename T, keys key>
struct symbolizer_default {};
// specializations for properties
// gamma
template <>
struct symbolizer_default<value_double, keys::gamma>
{
static value_double value() { return 1.0; }
};
// gamma-method
template <>
struct symbolizer_default<gamma_method_enum, keys::gamma_method>
{
static gamma_method_enum value() { return GAMMA_POWER; }
};
// opacity
template <>
struct symbolizer_default<value_double, keys::opacity>
{
static value_double value() { return 1.0; }
};
// alignment
template <>
struct symbolizer_default<pattern_alignment_enum, keys::alignment>
{
static pattern_alignment_enum value() { return GLOBAL_ALIGNMENT; }
};
// offset
template <>
struct symbolizer_default<value_double, keys::offset>
{
static value_double value() { return 0.0; }
};
// comp-op
template <>
struct symbolizer_default<composite_mode_e, keys::comp_op>
{
static composite_mode_e value() { return src_over; }
};
// clip
template <>
struct symbolizer_default<value_bool, keys::clip>
{
static value_bool value() { return false; }
};
// fill
template <>
struct symbolizer_default<color, keys::fill>
{
static color value() { return color(128,128,128); }
};
// fill-opacity
template <>
struct symbolizer_default<value_double, keys::fill_opacity>
{
static value_double value() { return 1.0; }
};
// stroke
template <>
struct symbolizer_default<color, keys::stroke>
{
static color value() { return color(0,0,0); }
};
// stroke-width
template <>
struct symbolizer_default<value_double, keys::stroke_width>
{
static value_double value() { return 1.0; }
};
// stroke-opacity
template <>
struct symbolizer_default<value_double, keys::stroke_opacity>
{
static value_double value() { return 1.0; }
};
// stroke-linejoin
template <>
struct symbolizer_default<line_join_enum, keys::stroke_linejoin>
{
static line_join_enum value() { return MITER_JOIN; }
};
// stroke-linecap
template <>
struct symbolizer_default<line_cap_enum, keys::stroke_linecap>
{
static line_cap_enum value() { return BUTT_CAP; }
};
// stroke-gamma
template <>
struct symbolizer_default<value_double, keys::stroke_gamma>
{
static value_double value() { return 1.0; }
};
// stroke-gamma-method
template <>
struct symbolizer_default<gamma_method_enum, keys::stroke_gamma_method>
{
static gamma_method_enum value() { return GAMMA_POWER; }
};
// stroke-dashoffset
template <>
struct symbolizer_default<value_integer, keys::stroke_dashoffset>
{
static value_integer value() { return 0; }
};
// stroke-dasharray
// stroke-miterlimit
template <>
struct symbolizer_default<value_double, keys::stroke_miterlimit>
{
static value_double value() { return 4.0; }
};
// geometry-transform
// rasterizer
template <>
struct symbolizer_default<line_rasterizer_enum, keys::line_rasterizer>
{
static line_rasterizer_enum value() { return RASTERIZER_FULL; }
};
// transform
// spacing
template <>
struct symbolizer_default<value_double, keys::spacing>
{
static value_double value() { return 100.0; }
};
// max-error
template <>
struct symbolizer_default<value_double, keys::max_error>
{
static value_double value() { return 0.2; }
};
// allow-overlap
template <>
struct symbolizer_default<value_bool, keys::allow_overlap>
{
static value_bool value() { return false; }
};
// ignore-placement
template <>
struct symbolizer_default<value_bool, keys::ignore_placement>
{
static value_bool value() { return false; }
};
// width
template <>
struct symbolizer_default<value_double, keys::width>
{
static value_double value() { return 0.0; }
};
// height
template <>
struct symbolizer_default<value_double, keys::height>
{
static value_double value() { return 0.0; }
};
// file ??
template <>
struct symbolizer_default<std::string, keys::file>
{
static std::string value() { return ""; }
};
// shield-dx
template <>
struct symbolizer_default<value_double, keys::shield_dx>
{
static value_double value() { return 0.0; }
};
// shield-dy
template <>
struct symbolizer_default<value_double, keys::shield_dy>
{
static value_double value() { return 0.0; }
};
// unlock-image
template <>
struct symbolizer_default<value_bool, keys::unlock_image>
{
static value_bool value() { return false; }
};
// mode
template <>
struct symbolizer_default<value_bool, keys::mode>
{
static value_bool value() { return false; }
};
// scaling
template <>
struct symbolizer_default<value_double, keys::scaling>
{
static value_double value() { return 1.0; }
};
// filter-factor
template <>
struct symbolizer_default<value_double, keys::filter_factor>
{
static value_double value() { return 1.0; }
};
// mesh-size
template <>
struct symbolizer_default<value_integer, keys::mesh_size>
{
static value_integer value() { return 0; }
};
// premultiplied
template <>
struct symbolizer_default<value_bool, keys::premultiplied>
{
static value_bool value() { return false; }
};
// smooth
template <>
struct symbolizer_default<value_double, keys::smooth>
{
static value_double value() { return 0.0; }
};
// simplify-algorithm
template <>
struct symbolizer_default<simplify_algorithm_e, keys::simplify_algorithm>
{
static simplify_algorithm_e value() { return radial_distance; }
};
// simplify
template <>
struct symbolizer_default<value_double, keys::simplify_tolerance>
{
static value_double value() { return 0.0; }
};
// halo-rasterizer
template <>
struct symbolizer_default<halo_rasterizer_enum, keys::halo_rasterizer>
{
static halo_rasterizer_enum value() { return HALO_RASTERIZER_FULL; }
};
// text-placements
// placement (point-placement-type FIXME)
template <>
struct symbolizer_default<point_placement_enum, keys::point_placement_type>
{
static point_placement_enum value() { return CENTROID_POINT_PLACEMENT; }
};
// marker placement
template <>
struct symbolizer_default<marker_placement_enum, keys::markers_placement_type>
{
static marker_placement_enum value() { return MARKER_POINT_PLACEMENT; }
};
// multi-policy
template <>
struct symbolizer_default<marker_multi_policy_enum, keys::markers_multipolicy>
{
static marker_multi_policy_enum value() { return MARKER_EACH_MULTI; }
};
// direction
template <>
struct symbolizer_default<direction_enum, keys::direction>
{
static direction_enum value() { return DIRECTION_RIGHT; }
};
// placement
// colorizer
// halo-transform
// num-columns
// start-column
// repeat-key
// symbolizer-properties ??
// largest-box-only
// minimum-path-length
// halo-comp-op
// text-transform
// horizontal-alignment
// justify-alignment
// vertical-alignment
// upright
// avoid-edges
template <>
struct symbolizer_default<value_bool, keys::avoid_edges>
{
static value_bool value() { return false; }
};
// font-feature-settings
} // namespace mapnik
#endif // MAPNIK_SYMBOLIZER_DEFAULT_VALUES_HPP