mapnik/utils/nik2img/nik2img.cpp

171 lines
5 KiB
C++
Raw Normal View History

2014-02-10 10:46:48 -08:00
#include <mapnik/map.hpp>
#include <mapnik/load_map.hpp>
#include <mapnik/agg_renderer.hpp>
#include <mapnik/version.hpp>
#include <mapnik/debug.hpp>
#include <mapnik/image_util.hpp>
#include <mapnik/graphics.hpp>
#include <mapnik/unicode.hpp>
2014-02-10 10:46:48 -08:00
#include <mapnik/datasource_cache.hpp>
2014-08-22 13:22:12 -07:00
#include <mapnik/font_engine_freetype.hpp>
2014-10-21 16:37:27 -07:00
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wunused-parameter"
#pragma GCC diagnostic ignored "-Wunused-local-typedef"
#include <boost/tokenizer.hpp>
2014-02-10 10:46:48 -08:00
#include <boost/algorithm/string.hpp>
#include <boost/program_options.hpp>
2014-10-21 16:37:27 -07:00
#pragma GCC diagnostic pop
2014-02-10 10:46:48 -08:00
#include <string>
int main (int argc,char** argv)
{
namespace po = boost::program_options;
bool verbose = false;
bool auto_open = true;
int return_value = 0;
std::string xml_file;
std::string img_file;
double scale_factor = 1;
bool params_as_variables = false;
2014-02-10 10:46:48 -08:00
mapnik::logger logger;
logger.set_severity(mapnik::logger::error);
try
{
po::options_description desc("nik2img utility");
desc.add_options()
("help,h", "produce usage message")
("version,V","print version string")
("verbose,v","verbose output")
("open","automatically open the file after rendering (os x only)")
("xml",po::value<std::string>(),"xml map to read")
("img",po::value<std::string>(),"image to render")
("scale-factor",po::value<double>(),"scale factor for rendering")
("variables","make map parameters available as render-time variables")
2014-02-10 10:46:48 -08:00
;
po::positional_options_description p;
p.add("xml",1);
p.add("img",1);
po::variables_map vm;
po::store(po::command_line_parser(argc, argv).options(desc).positional(p).run(), vm);
po::notify(vm);
if (vm.count("version"))
{
std::clog <<"version " << MAPNIK_VERSION_STRING << std::endl;
return 1;
}
if (vm.count("help"))
{
std::clog << desc << std::endl;
return 1;
}
if (vm.count("verbose"))
{
verbose = true;
}
if (vm.count("open"))
{
auto_open = true;
}
if (vm.count("xml"))
{
xml_file=vm["xml"].as<std::string>();
}
else
{
std::clog << "please provide an xml map as first argument!" << std::endl;
return -1;
}
if (vm.count("img"))
{
img_file=vm["img"].as<std::string>();
}
else
{
std::clog << "please provide an img as second argument!" << std::endl;
return -1;
}
if (vm.count("scale-factor"))
{
scale_factor=vm["scale-factor"].as<double>();
}
if (vm.count("variables"))
{
params_as_variables = true;
}
2014-02-10 10:46:48 -08:00
mapnik::datasource_cache::instance().register_datasources("./plugins/input/");
2014-08-22 13:22:12 -07:00
mapnik::freetype_engine::register_fonts("./fonts",true);
2014-02-10 10:46:48 -08:00
mapnik::Map map(600,400);
2014-08-22 13:22:12 -07:00
mapnik::load_map(map,xml_file,true);
2014-02-10 10:46:48 -08:00
map.zoom_all();
mapnik::image_32 im(map.width(),map.height());
mapnik::request req(map.width(),map.height(),map.get_current_extent());
req.set_buffer_size(map.buffer_size());
mapnik::attributes vars;
if (params_as_variables)
{
mapnik::transcoder tr("utf-8");
for (auto const& param : map.get_extra_parameters())
{
std::string const& name = param.first.substr(1);
if (!name.empty())
{
if (param.second.is<mapnik::value_integer>())
{
vars[name] = param.second.get<mapnik::value_integer>();
}
else if (param.second.is<mapnik::value_double>())
{
vars[name] = param.second.get<mapnik::value_double>();
}
else if (param.second.is<std::string>())
{
vars[name] = tr.transcode(param.second.get<std::string>().c_str());
}
}
}
}
mapnik::agg_renderer<mapnik::image_32> ren(map,req,vars,im,scale_factor,0,0);
2014-02-10 10:46:48 -08:00
ren.apply();
mapnik::save_to_file(im.data(),img_file);
2014-02-10 10:46:48 -08:00
if (auto_open)
{
std::ostringstream s;
2014-08-31 17:32:48 -07:00
#ifdef __APPLE__
s << "open ";
#elif _WIN32
s << "start ";
2014-02-10 10:46:48 -08:00
#else
2014-08-31 17:32:48 -07:00
s << "xdg-open ";
2014-02-10 10:46:48 -08:00
#endif
2014-08-31 17:32:48 -07:00
s << img_file;
2014-02-10 10:46:48 -08:00
int ret = system(s.str().c_str());
if (ret != 0)
return_value = ret;
}
else
{
std::clog << "rendered to: " << img_file << "\n";
}
}
catch (std::exception const& ex)
{
std::clog << "Error " << ex.what() << std::endl;
return -1;
}
return return_value;
}