File: README.rst

package info (click to toggle)
vectorgraphics2d 0.13-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 884 kB
  • sloc: java: 7,562; makefile: 3
file content (114 lines) | stat: -rw-r--r-- 3,353 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
.. image:: https://eseifert.github.io/vectorgraphics2d/logo.png

.. image:: https://travis-ci.org/eseifert/vectorgraphics2d.svg?branch=master
    :target: https://travis-ci.org/eseifert/vectorgraphics2d

VectorGraphics2D
################

VectorGraphics2D provides implementations of Java's ``Graphics2D`` interface
and exports the graphics in various vector file formats.
Currently, there is support for the following vector file formats:

- Encapsulated PostScript® (EPS)
- Scalable Vector Graphics (SVG)
- Portable Document Format (PDF)

Additional formats can be easily added.


Features
========

- Support for EPS, PDF, and SVG formats
- Rendering of all geometric shapes provided by the ``java.awt.Graphics2D``
  interface
- Shapes and text can be made transparent (except in EPS)
- Arbitrary clipping paths can be defined
- Output of bitmap images
- Easily extensible
- Small footprint (JAR is below 100 kilobytes)

Currently, most operations are supported, i.e. VectorGraphics2D is able to
handle clipping gradients, or compression. Some features are still missing,
like text encodings, embedded fonts, or metadata support. Although its early
stage VectorGraphics2D is already used successfully in several projects to
export vector graphics.

Requirements
============

VectorGraphics2D requires at least Java 7 and Gradle 4 or higher to build.

Installation
============

Without build management system
-------------------------------

You can just add ``VectorGraphics2D-0.13.jar`` to the classpath of your project.

Using VectorGraphics2D with Maven
---------------------------------

.. code:: xml

	<dependency>
	    <groupId>de.erichseifert.vectorgraphics2d</groupId>
	    <artifactId>VectorGraphics2D</artifactId>
	    <version>0.13</version>
	</dependency>

Using VectorGraphics2D with Gradle
----------------------------------

.. code:: groovy

    dependencies {
        compile group: 'de.erichseifert.vectorgraphics2d', name: 'VectorGraphics2D', version: '0.13'
    }

Using VectorGraphics2D with sbt
-------------------------------

.. code:: scala

    libraryDependencies += "de.erichseifert.vectorgraphics2d" % "VectorGraphics2D" % "0.13"


Usage
=====

A ``VectorGraphics2D`` object can be used as a replacement for a ``Graphics2D``
object. All calls to the ``VectorGraphics2D`` instance will be recorded and can
later be retrieved as a ``CommandSequence``:

.. code:: java

    Graphics2D vg2d = new VectorGraphics2D();
    vg2d.draw(new Rectangle2D.Double(0.0, 0.0, 20.0, 20.0));
    CommandSequence commands = vg2d.getCommands();

This command sequence can then be exported to a EPS, PDF or SVG document using
a processor for the desired file type, i.e. ``EPSProcessor`` for EPS,
``PDFProcessor`` for PDF and ``SVGProcessor`` for SVG. Additionally, format
specific output options can be passed to the processor when it is created.
For example, a compression option can be passed for PDF:

.. code:: java

    PDFProcessor pdfProcessor = new PDFProcessor(true);

Another method to get a processor is ``Processors.get(String)``:

.. code:: java

    Processor pdfProcessor = Processors.get("pdf");

Finally, a document can be generated from the commands and written to an output
stream:

.. code:: java

    Document doc = pdfProcessor.getDocument(commands, PageSize.A4);
    doc.writeTo(new FileOutputStream("rect.pdf"));