File: manual.rst

package info (click to toggle)
aafigure 0.5-4
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 332 kB
  • ctags: 307
  • sloc: python: 1,697; xml: 247; makefile: 107
file content (213 lines) | stat: -rw-r--r-- 6,290 bytes parent folder | download | duplicates (5)
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
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
========
 Manual
========

Overview
========

The original idea was to parse ASCII art images, embedded in reST documents and
output an image. This would mean that simple illustrations could be embedded as
ASCII art in the reST source and still look nice when converted to e.g. HTML.

aafigure can be used to write documents that contain drawings in plain text
documents and these drawings are converted to appropriate formats for e.g. HTML
or PDF versions of the same document.

Since then aafigure also grew into a standalone application providing a command
line tool for ASCII art to image conversion.


ASCII Art
---------
The term "ASCII Art" describes a `wide field`_.

* (small) drawings found in email signatures
* smilies :-)
* raster images (this was popular to print images on text only printers a *few*
  years ago)
* simple diagrams using lines, rectangles, arrows

aafigure aims to parse the last type of diagrams.

.. _`wide field`: http://en.wikipedia.org/wiki/ASCII_art


Other text to image tools
-------------------------
There are of course also a lot of other tools doing text to image conversions
of some sort. One of the main differences is typically that other tools use a
description language to generate images from rules. This is a major difference
to aafigure which aims to convert good looking diagrams/images etc. in text
files to better looking images as bitmap or vector graphics.

Graphviz
    Graphviz is a very popular tool that is excellent for displaying graphs and
    networks. It does this by reading a list of relations between nodes and it
    automatically finds the best way to place all the nodes in a visually
    appealing way.

    This is quite different from aafigure and both have their strengths.
    Graphviz is very well suited to document state machines, class hierarchies
    and other graphs.


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

aafigure
--------
This installs a package that can be used from python (``import aafigure``) and
a command line script called ``aafigure``.

The Python Imaging Library (PIL) needs to be installed when support for bitmap
formats is desired and it will need ReportLab for PDF output.

To install the module for all users on the system, administrator rights (root)
is required..

From source (tar.gz or checkout)
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Unpack the archive, enter the ``aafigure-x.y`` directory and run::

    python setup.py install

Setuptools/PyPI
~~~~~~~~~~~~~~~
Alternatively it can be installed from PyPy, either manually downloading the
files and installing as described above or using::

    easy_install -U aafigure

Packages
~~~~~~~~
There are also packaged versions for some Linux distributions and Windows:

Ubuntu
    Add the repository to ``/etc/apt/sources.list`` as described on this page:
    https://launchpad.net/~aafigure-team/+archive/ppa

    Then run ``apt-get update`` and ``apt-get install aafigure``

Arch Linux
    "aafigure" (or "aafigure-bzr") are found in the category "unsupported".

Windows
    For users that have Python already installed, there is an installer for
    the extension on http://pypi.python.org/pypi/aafigure


Docutils plug-in
----------------
The docutils-aafigure_ extension depends on the aafigure package also requires
``setuptools`` (often packaged as ``python-setuptools``) and Docutils_ itself
(0.5 or newer) must be installed.

After that, the ``aafigure`` directive will be available.

.. _docutils-aafigure: http://pypi.python.org/pypi/aafigure
.. _Docutils: http://docutils.sf.net


Sphinx plug-in
--------------
sphinxcontrib-aafig_ is a plug-in similar to the Docutils_ plug-in, but it
automatically selects the image format depending on the output format.

XXX elaborate

.. _sphinxcontrib-aafig: http://pypi.python.org/pypi/sphinxcontrib-aafig


MoinMoin plug-in
----------------
MoinMoin_ is a popular Wiki engine. The plug-in allows to use aafigure drawings
within wiki pages.

Copy the file ``aafig.py`` from ``examples/moinmoin`` to
``wiki/data/plugin/parser`` of the wiki. The aafigure module itself needs to
be installed for the Python version that is used to run MoinMoin_ (see above for
instructions).

Tested with MoinMoin 1.8.

See also: http://moinmo.in/ParserMarket/AaFigure

.. _MoinMoin: http://moinmo.in


Usage
=====
Command line tool
-----------------
::

    aafigure test.txt -t png -o test.png

The tool can also read from standard in and supports many options. Please look
at the command's help (or man page)::

    aafigure --help

Within Docutils
---------------
A ``aafigure`` directive is provided that allows to insert images::

    .. aafigure::

        DD o--->

::

    ./rst2html.py README.txt >README.html

This results in the ``README.html`` file and a ``.svg`` file (or the specified
file type) for each ``aafigure``.

The resulting ``README.html`` file can be viewed with a SVG capable browser. It
has been tested with Firefox 1.5, 2.0 and 3.0.

Within Sphinx
-------------
In ``conf.py`` add::

    extensions = ['sphinxcontrib.aafig']

This provides the ``aafig`` directive::

    .. aafig::

        DD o--->

The output format is automatically chosen depending on the generated document
format (e.g. HTML or PDF).

Within MoinMoin
---------------
ASCII Art figures can be inserted into a MoinMoin_ WikiText page the following
way::

    {{{#!aafig scale=1.5 foreground=#ff1010
    DD o--->
    }}}

The parser name is ``aafig`` and options are appended, separated with spaces.
Options that require a value take that after a ``=`` without any whitespace
between option and value.  Supported options are:

    - ``scale=<float>``
    - ``aspect=<float>``
    - ``textual``
    - ``proportional``
    - ``linewidth=<float>``
    - ``foreground=#rrggbb``
    - ``fill=#rrggbb``

There is no ``background`` as the SVG backend ignores that. And it is not possible
to pass generic options.

The images are generated and stored in MoinMoin's internal cache. So there is
no mess with attached files on the page. Each change on an image generates a
new cache entry so the cache may grow over time. However the files can be
deleted with no problem as they can be rebuilt when the page is viewed again
(the old files are not automatically deleted as they are still used when older
revision of a page is displayed).