allow customization of JPEG output image quality using syntax similar to png256, but using 0-100 as suffix, e.g. render_to_file(m,'image.jpeg','jpeg80') - closes #198 - patch from Dennis Luxen
This commit is contained in:
parent
39bdab7762
commit
4276ae24fe
3 changed files with 49 additions and 6 deletions
|
@ -11,6 +11,14 @@ Developers: Please commit along with changes.
|
||||||
For a complete change history, see the SVN log.
|
For a complete change history, see the SVN log.
|
||||||
|
|
||||||
|
|
||||||
|
0.6.1 SVN
|
||||||
|
---------
|
||||||
|
|
||||||
|
- AGG Renderer: Added option to control output JPEG quality (r1078) (#198)
|
||||||
|
|
||||||
|
- Plugins: Fixed segfault in OGC Plugin with empty geometries (r1074) (#292)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Mapnik 0.6.0 Release
|
Mapnik 0.6.0 Release
|
||||||
--------------------
|
--------------------
|
||||||
|
|
|
@ -31,7 +31,7 @@
|
||||||
|
|
||||||
// boost
|
// boost
|
||||||
#include <boost/algorithm/string.hpp>
|
#include <boost/algorithm/string.hpp>
|
||||||
|
#include <boost/lexical_cast.hpp>
|
||||||
// stl
|
// stl
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
|
|
@ -39,6 +39,7 @@ extern "C"
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
|
#include <sstream>
|
||||||
|
|
||||||
namespace mapnik
|
namespace mapnik
|
||||||
{
|
{
|
||||||
|
@ -50,7 +51,24 @@ namespace mapnik
|
||||||
//all this should go into image_writer factory
|
//all this should go into image_writer factory
|
||||||
if (type=="png") save_as_png(ss,image);
|
if (type=="png") save_as_png(ss,image);
|
||||||
else if (type == "png256") save_as_png256(ss,image);
|
else if (type == "png256") save_as_png256(ss,image);
|
||||||
else if (type=="jpeg") save_as_jpeg(ss,85,image);
|
else if (boost::algorithm::istarts_with(type,std::string("jpeg")))
|
||||||
|
{
|
||||||
|
int quality = 85;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if(type.substr(4).length() != 0)
|
||||||
|
{
|
||||||
|
quality = boost::lexical_cast<int>(type.substr(4));
|
||||||
|
if(quality<1 || quality>100)
|
||||||
|
throw ImageWriterException("invalid jpeg quality: " + type.substr(4));
|
||||||
|
}
|
||||||
|
save_as_jpeg(ss,quality,image);
|
||||||
|
}
|
||||||
|
catch(boost::bad_lexical_cast &)
|
||||||
|
{
|
||||||
|
throw ImageWriterException("invalid jpeg quality: " + type.substr(4));
|
||||||
|
}
|
||||||
|
}
|
||||||
else throw ImageWriterException("unknown file type: " + type);
|
else throw ImageWriterException("unknown file type: " + type);
|
||||||
return ss.str();
|
return ss.str();
|
||||||
}
|
}
|
||||||
|
@ -66,11 +84,28 @@ namespace mapnik
|
||||||
//all this should go into image_writer factory
|
//all this should go into image_writer factory
|
||||||
if (type=="png") save_as_png(file,image);
|
if (type=="png") save_as_png(file,image);
|
||||||
else if (type == "png256") save_as_png256(file,image);
|
else if (type == "png256") save_as_png256(file,image);
|
||||||
else if (type=="jpeg") save_as_jpeg(file,85,image);
|
else if (boost::algorithm::istarts_with(type,std::string("jpeg")))
|
||||||
else throw ImageWriterException("unknown file type: " + type);
|
{
|
||||||
}
|
int quality = 85;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if(type.substr(4).length() != 0)
|
||||||
|
{
|
||||||
|
quality = boost::lexical_cast<int>(type.substr(4));
|
||||||
|
if(quality<0 || quality>100)
|
||||||
|
throw ImageWriterException("invalid jpeg quality: " + type.substr(4) + " out of bounds");
|
||||||
|
}
|
||||||
|
save_as_jpeg(file,quality,image);
|
||||||
|
}
|
||||||
|
catch(boost::bad_lexical_cast &)
|
||||||
|
{
|
||||||
|
throw ImageWriterException("invalid jpeg quality: " + type.substr(4) + " not a number");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else throw ImageWriterException("unknown file type: " + type);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
void save_to_file(T const& image,std::string const& filename)
|
void save_to_file(T const& image,std::string const& filename)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Add table
Reference in a new issue