Skip to main content

Compress svg graphics

Project description

SVGCompress
===========

SVGcompress is a pure python module for simplifying/compressing svg (Scalable Vector Graphics) files. Have you ever tried to output a plot in vector format (pdf, svg, eps, etc.) and been surprised that your file weighs 10 or 20MB? Needed to submit a vector figure for publication but run up against the file size limit? Before you try to get away with the old standby of embedding a raster image in your vector and hoping the journal doesn’t notice, try SVGCompress! SVGCompress can help pare down your file size by:
* Removing tiny polygons - Reduce the number of polygons in your image by removing those below a small threshold size. The size threshold can be based on polygon area or circumference.
* Simplifying shapes - Reduce the complexity of your polygons using the Ramer–Douglas–Peucker algorithm.
* Merging adjacent or overlapping shapes - Merging can be accomplished by taking the union of overlapping polygons or through the construction of a minimum convex hull.


Installation
============
SVGCompress has only been tested in Python 2.x
Installation should be through pip (pip install SVGCompress)
Requires the following non-standard libraries:
* Numpy; svg.path; Shapely; rdp


Usage Notes
===========
Usage of SVGCompress is through the class Compress, or through the convenience function compress_by_method. The function svg_compress.test() contains usage examples demonstrating all of the compression methods with compress_by_method.
Producing your figures in svg format can be done through Matplotlib. This is especially convenient if you have a graphics editor such as Inkscape (free) which will allow you to do things such as modify the font and color of text or lines directly in the svg, without having to re-run your code. You can also use this to convert one of your svg files into an alternate vector format such as pdf or eps.


Examples
========
SVGCompress/test contains examples of each compression algorithm on three different files: One is a demonstration graphic (test_vector.svg) and the second and third are actual vector plots (map_test.svg, matplotlib_test.svg)


Version
=======
0.17 - Not extensively tested. Please email me to let me know of any issues.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

SVGCompress-0.17.tar.gz (1.7 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

SVGCompress-0.17-py2-none-any.whl (1.7 MB view details)

Uploaded Python 2

File details

Details for the file SVGCompress-0.17.tar.gz.

File metadata

  • Download URL: SVGCompress-0.17.tar.gz
  • Upload date:
  • Size: 1.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for SVGCompress-0.17.tar.gz
Algorithm Hash digest
SHA256 2d82cb7a7d37e8c6c1a3a90d246bb4caa26acb8ea083fb21362469bb0bcb40e8
MD5 b261cc264c6bbd780f7c9873a9d8187f
BLAKE2b-256 a1f0c9d5c3e82fceb4b15e3ab2d50025f2a93ddd3a2fd5a9d1fa48eb728aaa5f

See more details on using hashes here.

File details

Details for the file SVGCompress-0.17-py2-none-any.whl.

File metadata

File hashes

Hashes for SVGCompress-0.17-py2-none-any.whl
Algorithm Hash digest
SHA256 e09267329c80a1c7c397bdb70b3276c37dd868a5bcabb361ca261495ce650ba2
MD5 549e56f97a6a3641fd74dd19722dbaa6
BLAKE2b-256 9691b5fa25ca9b0bd0f16e2ad542a2e6520844dbd728c6358e9f04716122a055

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page