VYM - View Your Mind: C Uwe Drechsel February 12, 2014

Download as pdf or txt
Download as pdf or txt
You are on page 1of 55

VYM

View Your Mind


Version 2.2.4

c
Uwe
Drechsel
February 12, 2014

Contents
1 Introduction

1.1

What is a vym map? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

1.2

Why should I use maps? Time, Space and your Brain. . . . . . . . . . . .

1.3

Where could I use a map? . . . . . . . . . . . . . . . . . . . . . . . . . . .

1.4

What you shouldnt do with a map... . . . . . . . . . . . . . . . . . . . . .

1.5

Internet Ressources . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

2 The Concept of the vym application

2.1

The Mainwindow and its satellites . . . . . . . . . . . . . . . . . . . . . . .

2.2

Dockable windows . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10

2.3

Toolbars . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10

2.4

Menus and Context menus . . . . . . . . . . . . . . . . . . . . . . . . . . . 10

2.5

Maps . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10

3 Mapeditor

11

3.1

Start a new map . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11

3.2

Navigate through a map . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12

3.3

Modify and move branches . . . . . . . . . . . . . . . . . . . . . . . . . . . 14

3.4

Colours and Images - Using the right side of your brain . . . . . . . . . . . 15

3.5

Design of map background and connecting links . . . . . . . . . . . . . . . 17

3.6

Links to other documents and webpages . . . . . . . . . . . . . . . . . . . 18


3.6.1

How to create an URL . . . . . . . . . . . . . . . . . . . . . . . . . 18

3.6.2

How to create a vymlink . . . . . . . . . . . . . . . . . . . . . . . . 19

3.7

Multiple maps . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19

3.8

Brainstorming . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19

4 Noteeditor

20

4.1

States . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20

4.2

Import and export notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21

4.3

Edit and print note . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21

4.4

RichText: Colours, paragraphs and formatted text . . . . . . . . . . . . . . 21

4.5

Fonts and how to switch them quickly

4.6

Find text . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22

4.7

Paste text into note editor . . . . . . . . . . . . . . . . . . . . . . . . . . . 22

. . . . . . . . . . . . . . . . . . . . 21

5 Task editor

22

5.1

Creating tasks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22

5.2

Sleeping tasks for later reminders . . . . . . . . . . . . . . . . . . . . . . . 22

5.3

Priority of tasks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23

5.4

Keeping the overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24

6 Slideeditor - presentations

24

7 Hello world - vym and other applications

24

7.1

Import . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25

7.2

Export . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25

8 Advanced usage

28

8.1

Quickly sorting branches or postponing actions . . . . . . . . . . . . . . . . 28

8.2

Properties of an object . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29

8.3

Changing the history: Undo and Redo . . . . . . . . . . . . . . . . . . . . 30

8.4

Macros . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30

8.5

Bookmarks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31

8.6

Associating images with a branch . . . . . . . . . . . . . . . . . . . . . . . 31

8.7

Modifier Modes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32

8.8

Hide links of unselected objects . . . . . . . . . . . . . . . . . . . . . . . . 32

8.9

XLinks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33

8.10 Adding and removing branches . . . . . . . . . . . . . . . . . . . . . . . . 34


8.11 Adding a whole map or a part of a map

. . . . . . . . . . . . . . . . . . . 34

8.12 Connecting vym with Bugzilla . . . . . . . . . . . . . . . . . . . . . . . . . 34


9 vym on Mac OS X

34

9.1

Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34

9.2

Contextmenu and special keys . . . . . . . . . . . . . . . . . . . . . . . . . 35

9.3

Viewing external links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35

A vym initialisation process and configuration

36

A.1 Settings menu . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36


A.2 Configuration file . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
A.3 Path to ressources . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
A.4 Command line options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38

B Scripts

38

B.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
B.2 Example scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
B.2.1 Macro to create a rounded rectangle frame . . . . . . . . . . . . . . 39
B.2.2 Batch script to export all maps as images . . . . . . . . . . . . . . 39
B.2.3 Full scripting using ruby and DBUS . . . . . . . . . . . . . . . . . . 39
B.3 Available commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40
C Contributing to vym

51

C.1 Getting help . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51


C.2 How to report bugs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
C.3 Compiling from the sources . . . . . . . . . . . . . . . . . . . . . . . . . . 52
C.3.1 Getting the sources . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
C.3.2 The Qt toolkit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
C.3.3 Compiling vym

. . . . . . . . . . . . . . . . . . . . . . . . . . . . 52

C.4 vym file format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53


C.5 New features

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53

C.6 New languages support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53


C.7 New export/import filters . . . . . . . . . . . . . . . . . . . . . . . . . . . 54

Credits
Many people have sent me their feedback and ideas, and all of that has helped a lot to
make vym better. Thanks to all of you!
For this manual I would like to send some special thanks to
Peter Adamson for lots of feedback and proofreading of my far from perfect english
The team of AClibre (Academia y Conocimiento Libre) in Colombia for their translation of the manual to spanish:
Encargado
Vanessa
Sanchez

Actividad
Carolina

Gutierrez

Traduccionl

Erika Tatiana Luque Melo

Revision y correcciones
varias

Jeffrey Steve Borbon Sanabria

Estructuracion y exporte

John Edisson Ortiz Roman

Revision y correcciones
varias

Introduction

1.1

What is a vym map?

A vym map (abbreviated below as map) is a tree-like structure:

Such maps can be drawn by hand on a sheet of paper or flip chart and help to structure
your thoughts. While a tree like structure like the illustration above can be drawn manually vym offers much more features to work with such maps. vym is not just another
drawing software application, but a tool to store and modify information in an intuitive
way. For example you can reorder parts of the map by pressing a key or add various
pieces of information like a complete email by a simple mouse click.
Once you have finished collecting and organising your ideas, you can easily generate a
variety of outputs including for example a presentation in Open Office based on a map.
Hint:

You find the map shown above and others by clicking


Help Open vym examples
in the menu bar.

1.2

Why should I use maps? Time, Space and your Brain.

Space
A map can concentrate very complex content in a small space such as a piece of paper.
It helps to use both sides of your brain: the logical side and also your creative side (e.g.
by using pictures, colours and keywords in a map, often called anchors). It is a technique
to help organize the way you think and stimulate your creativity: It can help you by
developing, sorting and helping to memorise your ideas.

Time
Because you just use keywords and drawings, it is much faster than good old fashioned
notes. Your brain memorizes things by associating them with other things a map
makes use of those connections and stimulates new asccociations.
Your Brain
In 1960 Prof. Roger Sperry discovered that both hemispheres of the human brain
undertake different tasks (of course both of them basically can do the same):
Left side
verbal speech and writing

Right side
body language

numbers

visual thinking,
dreams

logical thinking

intuition and emotion

analysing and details

overview of things

science

creativity

linear thinking

art, music, dancing

concept of time

non-linear thinking, connecting things

day

spatial awareness

In our science oriented western society we have learned to mainly rely on our left side of
the brain, the rational one. In other cultures, such as the native americans and other
old cultures, the right side is much more important. Map are just one way to stimulate
the other side and make use of additional resources we all have.

1.3

Where could I use a map?

Here are some examples, how you can use those maps
to prepare articles, papers, books, talks, . . .
to sort complex data
to memorize facts, peoples names, vocabulary, . . .
to sort emails, files and bookmarks on your computer
to moderate conferences
to brainstorm solutions to problems
to record the tasks when planning a project

1.4

What you shouldnt do with a map...

A map drawn by somebody shows the way that the author thinks. There is no question
of right or wrong in the way it is drawn, so there is no way to criticise it. It is, what
it is (F. Lehmann).The tool will be of considerable use to the author and only very
limited use to anyone else.
However, when groups share in creating a map all of the group will benefit from its use.
An example of such use is when a Tutor develops a map with a group of students during
instruction. Another group use is when a Project leader gathers a group of specialists to
help map the tasks that will be required to deliver a project.

1.5

Internet Ressources

A good starting point to learn more about Mindmaps in general is Wikipedia:


English: http://en.wikipedia.org/wiki/Mind map
German: http://de.wikipedia.org/wiki/Mindmap

2
2.1

The Concept of the vym application


The Mainwindow and its satellites

vym comes with several windows, the central one is called mainwindow. It contains one or
more tabs, each of these tabs has a mapeditor and optionionally a tree editor, representing
a different view of the same data:

The (currently visible) main areas of the mainwindow are the tree editor to the left and
the mapeditor to the right. Note that both editors represent the same data and share
their selection: Both show the heading Get valentine surprise.

More windows, each having a special purpose, can be opened and arranged around or
even in the mainwindow. These extra windows are called called satellites1 . The next
image below shows the mainwindow together with the history window. The mainwindow
itself currently has three parts: treeeditor, mapeditor and at the bottom the noteeditor

Most of the time you will work in the mapeditor by just adding new branches, moving
around and reordering them. The various ways to do this will be explained in 3. You can
store additional information e.g. the content of a email easily in a branch: Just type or
copy&paste it into the noteeditor. Working with notes is explained in 4
Here is a list of the available satellite windows, the dockable feature is explained in next
section 2.2:
Branch Property Window (see section 8.2)

Find window to search for text (dockable)

Heading editor (dockable, features are the same as in the noteeditor, see section
4)

Historywindow (see section 8.3)

Noteeditor (dockable, see section 4)

Scripteditor (dockable, see section B.1)

Slideeditor (dockable, see section 6)

Taskeditor (dockable, see section 5)

The advantage of having separate window instead of integrating them in a combined workspace is
flexibility in arranging the windows. For example I usually have the noteeditor behind the mapeditor.
On Linux my windowmanager (KDE) allows me to enter text into a small visible corner of the noteeditor
without clicking the mouse button to move focus to the window, so that it receives input from keyboard.
I just push the mouse around to set the window focus, a concept which is useful also working with
http://www.gimp.org.

2.2

Dockable windows

Beginning with vym 1.13.0 some of the windows may be docked and become a part of
an existing window. Or the other way round: Parts of a window may be undocked and
become their own independent windows or can be placed in a different position within
the mainwindow. Example: Toolbar above the map with flags can be placed below or
besides of the map, or even float independantly.

2.3

Toolbars

The toolbars in the mainwindows give quick access to many functions and also display
the state of selected objects in the map. For example a branch may show certain flags,
the corresponding flags are also set in the toolbar.
Hint:

2.4

Toolbars are dockable (see also section 2.2): You can reposition all
toolbars by simply grabbing and dragging them with the toolbar
handle to a new position. For example you can move the flagstoolbar from its original horizontal position on top of the mapeditor
to a vertical position on the right side. Or just insert it again at its
original position. Also hiding some of the toolbars is possible by
right-clicking on the toolbar handle.

Menus and Context menus

At the top of each window you will find the menubar. The options provided there are
similar to those you are probably used to from other applications. Note that many (and
even more) options are available via context menus. Those are available if you right-click
onto an object in a map (on Mac OS X Command-Click).

2.5

Maps

The map has one or more mapcenters. Each mapcenter has branches radiating out from
the centre just like the trunk of a tree. Each branch in turn may have branches again.

We will call a branch directly connected to the mapcenter a mainbranch, because it


determines the position of all its child branches.
If you want to have more than one mapcenter, open the context menu by right-clicking
onto the background of a map and select Add mapcenter. Or just press [C]. The
mapcenter and the branches all have a heading. This is the text you see in the mapeditor.

Usually it should just be one or a few key words, so that one can easily keep track of the
whole map. There are several ways to quickly edit the heading, see 3.3.
In the toolbar above the mapeditor you see various symbols.

These are called flags and can be used to mark branches in the map, e.g. if something is
important or questionable. There are also more flags set by vym automatically to show
additional information, e.g. when a note is attached to a particular branch.
By default some of these flags are set exclusively e.g. when the thumb-up flag is set,
then the thumb down is reset and vice versa. You can change this default behaviour in
the settings menu (see A.1).

Mapeditor

3.1

Start a new map

After vym is started you will see the mainwindow with two parts: the mapeditor and the
tree editor. Usually you will work in both windows, but at the moment we will just need
the mapeditor.
Select the mapcenter New map in the middle of the mapeditor by left-clicking with the
mouse. It will be highlighted yellow to show that is selected. There are several ways to
add a new branch to the center:
Using the mouse: Open the context menu by clicking with the right mouse button
(CTRL-Click on Mac) onto the mapcenter and choose Add Add branch as child
Press [Ins] or [A]
A new branch will appear and you will be able to type the heading of the branch. Finish
adding the new branch by pressing [Enter]. Sometimes it comes in handy to be able to
add a new branch above or below the current one.
Use [Shift-A] to add a branch above the selected one or...
[Ctrl-A] to add one below.
It is also possible to add a branch in such a way, that the current selection becomes the
child of the new branch, which is like inserting it before the selection. This can be done
using the context menu.
Hint:

To delete a branch press [CTRL-X]. If enabled in the Settings menu


(see A.1), you can also use the [Del] key.

3.2

Navigate through a map

Select branches
To select branches you can use the left button of your mouse or also the arrow keys. Depending on the orientation of a branch tap [] or [] to move nearer to the mapcenter
or deeper down into the branches. Within a set of branches, lets call them a subtree, you
can use [PgUp] and [PgDn] to go up and down. You can also use [Home] and [End] to
select the first and last branch.
You can also select branches in the tree editor. Once this editor is active, you can also
use [] and [], which have a slightly different meaning than in mapeditor: dont forget
to click back into mapeditor to continue working there.
There is also a selection history: Use [CTRL-I] and [CTRL-O] to go back to previous or
later selections.
Panning the view of a map
While adding more and more branches the size of the map may become larger than the
mapeditor window. You can use the scrollbars on the right and the bottom of your
mapeditor window to scroll the view up or down or left or right. It is easier to just scroll
using the left mouse button: Click anywhere on the canvas itself. Choose an empty space
somewhere between the branches. The mouse pointer will change from an arrow to a
hand, now move or drag the visible map to show the desired part.
If you select branches using the arrow keys, the map will scroll to ensure that the selected
branch is always visible.
Zooming the view of a map
Working with huge maps, the zoom-function comes in handy: You can use
from the menu: View Zoom in, View Zoom out, View reset Zoom.
the toolbar buttons

Clicking the crossed magnifying lens icon will reset the zoomed view to its original size.
The keyboard shortcuts for zooming are [+] and [-]. [,] resets the zoom and [.] centers
view on selection.
Alternatively you can zoom using the mouse: Press [CTRL] while using the scrollwheel.
With [CTRL] and middle-mouse you reset the zoom.
Find Function
Choose Edit Find or just press [CTRL+F] to open the Findwidget. The image below
shows the findwidget above the noteeditor and the mapeditor:

The text you enter here will be searched in all the branch headings and also in the
associated notes. Just click on one of the results shown to select the found heading or an
occurance in a note. In above example we searched for opensuse, which had a number
of occurences in this map, e.g. in the note of HowTo check into in editors on Factory
branch.
Press [CTRL+F] again to hide the widget once its no longer needed. Or you could also
undock it (see 2.2).
Keep the overview scroll a part of the map
A very big subtree of a map e.g. a branch with hundreds of child branches would make
it very hard to keep an overview over the whole map. You can hide all the children of a
branch by scrolling it in other software also called folding. Think of the whole subtree
as painted onto a broadsheet newspaper. You can scroll or fold the paper to a small roll,
leaving just the headline visible.
To scroll or unscroll a branch and its children,
press the [S]
press the middle-mouse button or
choose the scroll icon from the toolbar.
If you select parts of a scrolled branch e.g. using the find function or by using the arrowkeys, it will unscroll temporary. This is shown as a scroll with a little hour glass. If the
temporary unscrolled part is no longer needed, it will be hidden again automatically. It
is also possible to unscroll all branches using EditUnscroll all scrolled branches.
You can also hide parts of the map while exporting it e.g. to a webpage or a presentation,
see 7.2 for details.

3.3

Modify and move branches

Modify the heading


You can edit the heading by selecting the branch and then
pressing [Enter]
double-clicking with left mouse.
Just type the new heading (or edit the old one) and press [Enter]. You can also open the
heading editor by pressing [E] or clicking

in the toolbar. The heading editor allows you to enter richtext, just like the note editor
does for notes (see section 4).
Move a branch
The easiest way to move a branch is to select it with left-mouse and drag it to the
destination while keeping the mouse button pressed. Depending on the branch it will be
moved to the destination or
linked to a new parent (mapcenter or branch)
If you drag the branch over another one or over the mapcenter, you will notice that the
link connecting it to the old parent will be changed to lead to the new parent which is
now under your mousepointer. If you release the button now, the branch will be relinked.
If you release the button in the middle of nowhere, the result will depend on the type of
branch you are releasing:
A mainbranch is directly connected to the mapcenter. It will stay on its new position.

An ordinary branch will snap back to its original position 2 .


Thus you can easily rearrange the layout of the mainbranches to avoid overlapping of
their subtrees. There is another convenient way to move branches, especially if you want
to reorder a subtree: You can move a branch up or down in a subtree by
pressing [] and []
selecting Edit Move branch
clicking on the toolbar buttons:

There is yet another way to move branches: If you press [Shift] or [Ctrl] while moving
with the mouse, the branch will be added above or below the one the mouse pointer is
over. This can also be used to reorder branches in a map.
Another special way to move or select branches are targets, see 8.1. Branches with targets
use this flag:

3.4

Colours and Images - Using the right side of your brain

Change colour of a heading


You can also use colours to add more information to a map, e.g. use red, green and more
colours to prioritize tasks. Again you can
use the menu and choose e.g Format Set Color
use the toolbar

The first button (black in the graphic above) shows the current colour. Clicking on it
lets you choose another colour. You can also pick another colour by selecting a branch
with the desired colour and using the pick colour button. Both of the icons showing
a palette actually apply the current colour to the selected branch. While the first one
just colours the heading of the selection, the last one also colours all the children of the
selected branch.
A very useful function is the pick color modifier of the mouse: Select the branch which
should get the new colour, then press [Shift] and simultanously click with left-mouse on
another branch to copy its colour to the currently selected subtree. If you only want to
color the branch, not the whole subtree, press [Shift]+[Ctrl] simultanously.
2

In newer versions of vym the snap back is animated. Animation can be configured, see section A.1

Use flags
vym provides various flags. They are usually displayed in the toolbar on top of the
mapeditor window. (Note: Like all toolbars you can also move them to the left or the
right side of the window or even detach them. Just grab the very left dotted part of
the toolbar with your left-mouse button.)

If you have a branch selected, you can set any number of flags by clicking them in the
toolbar. The toolbar buttons change their state and always reflect the flags set in the
selected branch. So, to remove a flag from a branch, select the branch and then click the
highlighted flag on the toolbar.
At present vym uses two kinds of flags: System Flags and Standard Flags. The standard
flags are those shown in the toolbar. System flags are set by vym to indicate e.g. that
there is additional information in a note (more on this in 4). Later versions of vym may
have another kind of flags, which may be edited by the user.
Images
The easiest way to add an image to a branch is by dragging it e.g. from a webbrowser to
the mapeditor while a branch is selected there.
You can also add an image to a branch by opening the context menu of the branch. Right
click the selected branch, choose Add Image. A dialog window enables you choose the
image to load. 3 While an image is selected in the dialog, a preview of the image is
displayed. It is also possible to select multiple images.
You can position the image anywhere you want, just drag it with left mouse. To relink it
to another branch, press [Shift] while moving it. To delete it, press [Del].
If you right-click onto an image, a context menu will open which lets you first choose one
of several image formats. Then a file dialog opens to save the image.
Hint:

This is used to export the image as separate file. As part of the


map it always will be saved anyway in the map itself! You can also
cut and copy images.

Note that it is not possible to add objects to an image, which would make working with
the map much more complex if e.g. images could be linked to images.
The option Use for export controls the output of exports e.g. to HTML: If set to no,
the image wont appear in the text part of the output. This is useful for large images or
if images are used as a kind of frame e.g. the famous cloud symbol around a part of the
map. Those shouldnt appear in the middle of the text.
Resizing images has been added to /vym in version 1.13.20. Later versions will include
more functionality like changing its z-value (put it into background) etc.
3

Supported image types are: PNG, BMP, XBM, XPM and PNM. It may also support JPEG, MNG
and GIF, if specially configured during compilation (as done when vym is part of SUSE LINUX).

Frames
Various types of frame can be added to a branch in the property window (see 8.2), e.g.
ellipses, rectangle and cloud. The frames can optionally also include the children of
the the framed branch, thus allowing even to put boxes of contents into other boxes.
Alternatively, you can use use images as frames:

3.5

Design of map background and connecting links

The design of the background of a map and also of the links connecting various parts of
the map can be changed by
Selecting Format from the menu
Right clicking on the canvas, which will open a context menu
Background
The colour is set (and also displayed) as Set background colour. Alternatevily you can
set an background image, though this is not recommended in general. Working on the
map becomes slow and the image currently cannot be positioned freely.
Link colour
Links connecting branches can be coloured in one of two ways:
use the same colour for the heading and for the branch link line.
use one colour for all links and choose different colours for the branch headings text.
The default colour for branch link lines is blue.

The latter can be set with Set link colour. Check or uncheck the Use colour of heading
for link option to toggle between the two designs for your map.
Link style
vym offers four different styles for the appearences of links:
Line
Parabel
Thick Line
Thick Parabel
The thick styles only apply to links starting at the mapcenter, link lines for the rest of
the map are always painted thin.

3.6

Links to other documents and webpages

vym supports two kind of external links:


Documents, viewed with an external webbrowser. Examples are .pdf and .html
files. References are called URLs and marked with the globe flag:

A special type of URLs are those pointing to Novell Bugzilla, they have the Bugzilla
bug instead of the globe:

vym even can get data from Novell Bugzilla, for details see 8.12.
vym maps, viewed in vym itself. References are called a vymlinks and marked with
the vym flag:

3.6.1

How to create an URL

Use one of the following:


Drag and drop URL from a webbrowser
Use the URLs and vymlinks toolbal:

Keyboard shortcut: Press [U] or right-click onto a branch to open the contextmenu
then choose ReferencesEdit URL. If you want to use a file dialog to conveniently choose a local file you can use [U]. Also drag and drop from a browser can
be used to create a new branch with an URL.
Context menu: Right click onto branch, in the context menu there is also an option
to open all URLs found in the selected subtree of the map. Thats useful to simultanously open a collection of URLs in the webbrowser, especially if the browser can
open them in tabs.
After an URL was entered, a little globe will appear in the branch. By clicking on the
globe in the toolbar or the context menu an external browser4 will be launched. For more
information on working with bookmarks and webbrowsers see section 8.5.
If support for Bugzilla is enabled (see 8.12), all Bugzilla references in a subtree can be
updated automatically e.g. by pressing [CTRL-B].
3.6.2

How to create a vymlink

Creation is possible both from the URLs and vymlinks toolbar or from the context
menu of a branch:

A file dialog opens where you can choose the map. Clicking this flag beside the branch
heading, in the toolbar or in the context menu of a branch will open the map in another
tab (see 3.7 for working with multiple maps). To delete an existing link, just right click
the branch and select Delete vym link.
Hint:

Open a linked map in background by pressing [Ctrl] while clicking


on the icon in the map

In the context menu there is also an option to open all vymlinks found in the selected
subtree of the map. Thats useful to simultanously open a collection of related maps5 .

3.7

Multiple maps

You can work on multiple maps at the same time. Each new map is opened in another
tab. The available tabs are shown just above the mapeditor. You can use the normal
cut/copy/paste functions to copy data from one map to another.

3.8

Brainstorming

When brainstorming you collect quickly a number of thoughts or ideas, without sorting,
discussing or otherwise spending any amount of time on a particular idea.
vym helps you to quickly create mapcenter, either by pressing [C] or clicking the
4

The browser can be changed in the Settings Menu (see A.1).


Technical note: Internally vym uses absolute paths, to avoid opening several tabs containing the
same map. When a map is saved, this path is converted to a relative one (e.g. /home/user/vym.map
might become ./vym.map. This makes it fairly easy to use multiple maps on different computers or export
them to HTML in future.
5

If you want to place the new mapcenter at a specific position, you could also open the
context menu by right-clicking on the background and selecting Add mapcenter.
Once you are done adding new items, you can start to sort them and arrange them by
moving and relinking them to create a new map.
Hint:

If you have enabled Automatic Layout in the Settings menu, the


new parts will move around to avoid overlapping

Noteeditor

If you want to attach more text to a branch e.g. a complete email, a cooking recipe, or the
whole source code of a software project, you can use the noteeditor. (The Headingeditor
has the same features.)

This editor displays text associated with a branch selected in the mapeditor. The noteeditor shows different background colours depending on whether text is associated with a
selected branch.

4.1

States

Before you can type or paste text into it, you have to select a branch in the mapeditor.
Note that the background colour of the noteeditor indicates its state:
grey: no text entered yet
white: some text has been entered

In the mapeditor itself, to signal that there is a note with more information for a particular
branch, a little note flag will appear next to the heading of the branch. This is illustrated
in the lower branch on the right hand side:

4.2

Import and export notes

The note is always saved automatically within the vym map itself. Nevertheless sometimes it is nice to import a note from an external file or write it. In the Note Editor use
File Import and File Export to do so.

4.3

Edit and print note

Editing works like in any simple texteditor, including undo and redo functions. You can
delete the complete note by clicking the trashcan. Only the note itself is printed by
clicking the printer icon.

4.4

RichText: Colours, paragraphs and formatted text

Notes and also the headings of branches can either use a default font or all text attributes
availabe in RichText, like bold, italic, colors, etc. To enable the latter, click the RichText
button:

4.5

Fonts and how to switch them quickly

If you just want to do quick notes and dont need fully formatted RichText as mentioned
above, you still can select either a fixed font width font or a variable width font by clicking

The fixed font is usually used for emails, source code etc. while the variable font is used
for simple notes, where one doesnt need fixed character widths.
In the Settings menu both fonts can be set. The default font can also be toggled between
the fixed and variable font by selecting or deselecting the fixed font is default menu
item.
Hint:

Additionally to the default fonts any font installed on your system


can be used. Please note, that the chosen font also will be used for
HTML exports, so if your VYM mind map should be exported to
a web page you should only use fonts which are available generally.

4.6

Find text

The noteeditor itself has no Find function, use Find in the mapeditor, which will also
display occurences of text in notes (see 3.2).

4.7

Paste text into note editor

Often you will paste text into the editor from another application e.g. an email.

Task editor

Tasks are used to easily create and maintain a Todo-list. The taskeditor is visible on
the left side in the image below.

5.1

Creating tasks

To create a task press [Shift + W]. The branch will get an additional flag and its name
will be visible in the taskeditor.
A task can have three different states:
Not started
Work in progress
Finished
You can cycle these states by pressing [W].

5.2

Sleeping tasks for later reminders

A task may be set to sleep, which can be used to get a reminder after a certain amount
of time. The flag will change to one of these:

Not started - sleeping


Work in progress - sleeping
You can set the amount of days a task should sleep by right clicking on the task flag in
the mapeditor or the task in the taskeditor. Reset sleepwill wake up a currently sleeping
task. These tasks will get a new flag and status in the taskeditor:
Not started - morning
Work in progress - morning
Additionally these poor tasks, which have just been woken up, will get a way higher
priority, so that they pop up on top of your list in the taskeditor, see next section.

5.3

Priority of tasks

The tasks visible in the taskeditor are ordered by their priorities, listed on the left side of
the editor. The lower(!) the priority, the more important is a task.
There are several principles that influence the priority of a task:
Old tasks tend to bubble up: If you have a task named water the flowers and you
have postponed it since 187 days, better delete the task. And create a new task to
dump the remains of the flowers.
Colors in the map: If you use the Function keys to assigne the colors red, amber,
green, etc. the tasks will get a different priority accordingly
The stopsign flag

will increase the priority. Use it for your shipstoppers. . .

Sleeping tasks and finished tasks will tend to fall to the bottom of your task list.
The freshly woken up morning tasks will tend to pop up right at the top, so that
they cannot be missed. Remove the morning state by pressing [W] once.
The priorities are calculated based on the next visible columns:
Status: Shows the state and if the task is currently sleeping
Age total: Days, since the task has been created
Age modified: Days, since the task has been changed
Sleep: Days, which will pass until task will wake up
Note that the priorities cannot be set manually, but e.g. you can reset the Age modified
by pressing [W] three times to cycle through the states. Also the priorites are maintained
for all currently opened maps, so if the top priority in your current map is a sleeping 2034,
then there is another open map, which certainly has a priority 1 task.

5.4

Keeping the overview

The taskeditor has filters:


Current map: Show only tasks from current active map
Active tasks: Show only the tasks, which are neither finished nor sleeping

Slideeditor - presentations

vym can be used to do animated presentations using the slideeditor as seen on the right
side of the image below:

The slideeditor can be opened by pressing [S] or from the View menu. The (currently)
available action are:

Select previous slide

Select next slide

Create a new slide by snapshotting the current selection. The exact set of actions
performed when selecting the new snapshot defined in a script called slideeditor-snapshot.vys.
The script is one of the vym macros, see 8.4.

Open the scripteditor to manually edit the current slide


(More on scripting in appendix B).

Delete the current slide

Move current slide up in slidedeck

Move current slide down in slidedeck

Hello world - vym and other applications

This section is about how vym can interact with other applications. Many applications
can now read and write their data using XML, the eXtensible Markup Language. vym
also uses XML to save its maps, see C.4 for a more detailed description.

So if you make use of another application that understands XML, chances are good that
someone could write import/export filters for vym . Volunteers are always welcome ;-)

7.1

Import

KDE Bookmarks
The integrated bookmark editor in KDE (Konqueror etc.) is somewhat limited, so why
not use vym to maintain the bookmark mess? To create a new map containing your
current KDE bookmarks just choose
File ImportKDE Bookmarks
Mind Manager
vym has currently a very basic import filter to convert maps created by Mind Manager6
into vym maps. Notes and pictures are not converted at the moment. You can import
files with
File ImportMind Manager
Directory structure
vym can read a directory structure. This is mainly for testing vym e.g. to easily create
huge maps used for benchmarks (yes, there is still room to optimize vym ;-)

7.2

Export

Often you may not want to export the whole map, but just parts of it. For example
you may have additional info you want to talk about in a presentation, while those parts
should not be visible to the audience. To achieve this you can hide parts of the map
during exports by setting the hide in export flag.

You can toggle this flag in the toolbar or by pressing [H]. Note that there is a global
option in the settings menu ( A.1) to toggle the use of this flag. By default the flag is
enabled.
Last used format
Repeats the last export action without further dialogs like asking for directories. The
associated export type and filepaths are stored within the map and thus map specific.
Note: Not all export types support this feature yet.
6
Mind Manager is a commercial i.e. non free, software application by Mindjet for Windows and the
Mac. Both names are registered trademarks by Mindjet. For more information see their website at
http://mindjet.com

Image
vym supports all image formats which are natively supported by the QT toolkit: BMP,
JPEG, PBM, PGM, PNG, PPN, XPM, and XBM. For use in websites and for sending
images by email PNG is a good recommodation regarding quality and size of the image.
vym uses QTs default options for compressing the images.
PDF
Exports to Portable Document Format.
SVG
Exports to Scalable Vector Graphics.
Open Office
Open Office beginning with version 2 uses the so called Open Document Format, which
can be written by vym . The options are currently limited, but it possible to export
presentations which can be opened in Open Office Impress. By selecting
File ExportOpen Office
you get a file dialogue where you can choose the output file and the file type:

The file types represent various templates, which can be created with some manual work
from an existing Open Office document. The structure of vym map is then inserted into
a template. There are some limitations at the moment:
vym cant take care of page lengths, so you have to check and probably reedit in
Open Office to avoid text running over the end of a page

Images and flags are not used at the moment


Notes are just written as plain text, without RichText
The full range of templates are not available in all distributions.
Some of the templates make use of sections i.e sections insert the headings of mainbranches
as chapters for sections into the presentation.
HTML (Webpages)
This is the format to use if you wish to create a webpage. To see an example visit the
vym homepage: www.InSilmaril.de/vym A dialog allows the user to set various options:
Include image: If set, vym will create an image map at the top of the HTML
output. Clicking on a branch in the map will jump to the corresponding section in
the output.
Colored headings: If set to yes, vym will colour the headings in the text part
with the same colours used in the vym map.
Save settings: If set to yes, vym will save above settings in the map.
A & O Achievements and Objectives
A specialized form of ASCII export (see next section), which is used for workreports.
Currently it is considered experimental.
ASCII
Exporting a map as text is somewhat experimental at the moment. Later this will probably be done using stylesheets. So the output may change in future versions of vym
.
CSV
Exports map into a Comma Separated Value file, which can be used to import into all
kinds spreadsheet software.
KDE Bookmarks
vym will overwrite the KDE bookmarks file and then try to notify running Konquerors
via DBUS of the changed file. vym does not create a backup!
File Export KDE Bookmarks
Taskjuggler
Used to export to Taskjuggler project management software. Currently considered experimental.

LATEX
vym can generate an input file for LATEX. Currently this is considered as experimental,
there are no options (yet). By selecting
File ExportLATEX
you will be asked in a file dialog for the name of the output file. This file may then be
included in a LATEXdocument using command:
\include{inputfile.tex}
New in version 2.2.0: You can configure the names of the sections in the vym config file,
depending on your platform e.g. in
$HOME/.config/InSilmaril/vym.conf
Just add e.g. these entries
/export/latex/sectionName-0=chapter
/export/latex/sectionName-1=section
/export/latex/sectionName-2=subsection
/export/latex/sectionName-3=subsubsection
/export/latex/sectionName-4=paragraph
XML
The map is written into a directory both as an image and as an XML file. The directory
is set in a file dialog. If the directory is not empty, you will be warned and offered choices
if you are at risk of overwriting existing contents.
It is possible to export different maps into the same directory. Each file generated will have
the maps name as prefix, e.g. todo.vym becomes todo.xml, todo.png, todo-image-1.png
and so on. This is useful if, for example, a website comprises several combined maps that
have to be stored in the same directory.
Export a part of a map
Select a branch you want to export together with its children, then open the context
menu and choose Save Selection. This will create a file with the suffix .vyp, which is an
abbreviation for vym part.

8
8.1

Advanced usage
Quickly sorting branches or postponing actions

Sometimes its very handy to have a small number of shortcuts to quickly select a certain
branch or move something somewhere and proceed with next item. This can be used for
quick sorting to a number of destination. For example if used in timeplanning, you could
quickly move something to next tuesday. The destinations are called targets and are
marked with

The target flag is toggled with [T]. If you want to Goto a target, press [G]. Similar if
you want to Move a branch, press [M]. A context menu will open and lets you select
the target.

8.2

Properties of an object

For any branch you can open a satellite window (see 2.1): the property window:

Frame
sets the appearance of the frame of a branch. Currently there are
No frame
Rectangle
Ellipse
Cloud
The Include Children checkmark is used to, well, include the children of the branch.
Padding sets the distance between both neighbouring branches and frame and also the
frame and branch itself. The width sets the thickness of the frame.
Two colors can be assigned to background of the frame and frame itself.
Layout
The images belonging to a branch can use different layouts, e.g. floating freely alongside
or being included within the branch. For details and illustration see 8.6).

Link
The advantage of hiding a link, which is the connection between a branch (or image) and
its parent, is to make the branch itself appear a mapcenter of its own. Details are in 8.8).

8.3

Changing the history: Undo and Redo

vym keeps track of all changes done in a map. The default number of changes which can
be undone is 75. The complete history can be seen in the historywindow:

A single step back be undone or redone with [CTRL-Z] or [CTRL-Y], or by using the
buttons in the toolbar or the historywindow. Inside the historywindow, you can click on
a line to unwind all actions done until that point in time or redo all changes by clicking
on the last line.
Hint:

8.4

You can paste from the past: Go back in time by e.g. with
[CTRL-Z], then copy to clipboard by pressing [CTRL-C].
Now do all actions again, e.g. by [CTRL-Y] or clicking on the last
action in historywindow. Now paste from the past with [CTRL-V].

Macros

Each function key [F1] to [F12] holds a macro, which is executed on the current selection
if the key is pressed. The default macros change the colour of a subtree or set the frame
of a branch:

Each macro is a vym script, which is executed when the associated key is pressed. The
default location of the scripts can be changed in the Settings menu. More information on
using scripts in vym is found in appendix B.

8.5

Bookmarks

Open new tabs instead of new windows


If you use konqueror as your browser, vym will remember the konqueror session which
was opened first by vym . You can also press [Ctrl] and click to open the link in a new
tab.
vym can also open a new tab in Mozilla or Firefox using the remote command7 of these
browsers.
Drag and Drop
If you want to keep bookmarks in a map, select a branch where you want to add the
bookmark, then simply drag the URL from your browser to the map. Also you could
use an existing heading as URL: Right click onto the branch and select Use heading for
URL.
Directly access bookmark lists of a browser
Please see the sections 7.1 and 7.2 about Import and Export filters.

8.6

Associating images with a branch

The default setting for an image is for it to float freely. Images can be positioned
anywhere on the canvas, but may end up in the same place as other parts of the map
obscuring that part of the map.
The solution is to insert or include them into a branch. This can be done via the
property window (see 8.2):
Include images horizontally
Include images vertically
The image is still positioned relative to its parent branch, but the heading and border of
the branch frame adapt to the floating image, see below:
7

http://www.mozilla.org/unix/remote.html

8.7

Modifier Modes

Modifiers are for example the [Shift]- the [Ctrl]- ot the [Alt]-keys. When pressed while
applying mouse actions, they will cause vym to use a modified version of the action
which usually would be done.
Without a modifier key pressed, the first mouse click on a branch just selects it. For
the behaviour of the [Shift] modifier there are several options, which can be set from the
modifier toolbar:

The default mode is to copy the colour from the clicked branch to the already selected
branch. The figure above shows the toolbar with the default modifier selected. If press
both [Shift] + [Ctrl] only the selected branch will change color, instead of the whole
subtree.
The second modifier lets you create links between branches called xLinks. They will be
explained in the next section 8.9.

8.8

Hide links of unselected objects

Sometimes it would be useful to position a branch freely, just like a mainbranch or an


image. This is possible for all branches, you can use a mainbranch and hide its connecting
link to the mapcenter or hide the link between a child branch and its parent. This can
be used e.g. for legends or a collection of vymLinks pointing to other maps:

To hide the link between a branch and its parent open the 8.2 and check Hide link if
object is not selected on Link tab.

8.9

XLinks

So far all the data in the vym map has been treelike. Using xLinks you can link one
branch to any other, just like attaching a rope between two branches in a real tree. This
is especially useful in complex maps, where you want to have crossreferences which can
not be displayed on the same visible area of the mapeditor window. The following example
map still fits on one screen, but shows how data can be crosslinked. In the graphics there
is a link from a task (prepare a presentation) to general information:

Note that a xLink which points to a branch, that is not visible (because it is scrolled), is
just shown as a little horizontal arrow. In the image above have a look at the Screenshot
branch.
Create a xLink
Choose the link mode from the modifier toolbar (by clicking the toolbar icon or pressing
[L]). Select the branch, where the xLink should start. Press the modifier key [Shift]
drag the mouse pointer to the branch where the link should end. (The link is drawn to
follow the mouse pointer). When you release the mouse over a branch the xLink becomes
permanent.
Modify or delete a xLink
First select the link, either in the tree editor or by clicking the xLink itself in the mapeditor.
A dialogue opens, where you can set colour, width and also delete the xLink.
You can also move the control points of the link to change the curve and change the
appearance of the xlink by right clicking on one of the control points:

Follow a xLink
In a complex vym map it sometimes comes in handy to be able to jump to the other end
of a xLink. You can do this by opening the context menu of the branch and clicking on
Goto xLinkand selecting the xLink you want to follow. Even easier is to click on the
lower right end of a branch a popup menu will show up with all xLinked branches. Click
one of them to jump to it.

8.10

Adding and removing branches

The context menu of a branch shows some more ways to add and delete data e.g. you
can delete a branch while keeping its children. The children become linked to the parent
of the previously removed branch. Similar branches can be inserted into existing maps.
For keyboard shortcuts also have a look at the context menu.

8.11

Adding a whole map or a part of a map

Select a branch where you want to add a previously saved map (.vym)or a part of a map
(.vyp) , then open the context menu and choose Add Add Map (Insert). For the
import you can choose between Add Map (Insert) and Add Map (Replace): The imported
data will be added after the selected branch.

8.12

Connecting vym with Bugzilla

vym can get data from SUSE Bugzilla, if you install an additional package. Make sure
you have the ruby programming language and rubygems installed and get bicho8 :
gem install bicho
Once you have the bicho installed, you can just enter a bug ID into a heading and
press [B]: vym will create the URL from the ID and try to get the heading directly from
Bugzilla.
Also drag and drop of a URL from your webbrowser into vym will trigger retrieving the
data. You can can also update a subtree of Bugzilla URLs by pressing [Ctrl+B].

vym on Mac OS X

9.1

Overview

Sorry, currently (vym 2.2.2) there is no Mac port available. Please contact the author9 if
you are interested in a Mac version.
8
9

http://rubygems.org/gems/bicho
Email Uwe Drechsel: vym@insilmaril.de

9.2

Contextmenu and special keys

Most Macs unfortunatly just have a single mouse button. In order to show the context
menu which usually would be opened with the right mouse button, you can click while
pressing the [kommand]-key.
Especially on Laptops some of the keys usually used on PC keyboards seem to be missing.
The QT-Mac Edition of vym has its own keyboard shortcuts. To find the shortcuts just
have a look at all the menu entries, the shortcut is visible next to an entry. Toolbar
buttons also may have shortcuts, just position the mouse pointer over a button and wait
for the little help window to appear.

9.3

Viewing external links

vym on Mac uses the system call /usr/bin/open to view links. Mac OS determines
automatically if the link is a pdf or www page and opens the right browser.

A
A.1

vym initialisation process and configuration


Settings menu

The Settings menu allows to configure vym to your needs:


Set application to open PDF files
Choose a PDF viewer like acrobat or konqueror which is installed on your system.
Set application to open external links
Choose your favourite webbrowser here.
Set path for macros
Set the default search path for macros, which will be executed when you press one of the
function keys. Each key corresponds to a file (macro-1.vys..macro12.vys) in the search
path.
Set number of undo levels
Sets the number of undo/redo levels. The default setting is 75 levels.
Autosave and autosave time
Automatic saving of modified maps can be toggled on or off. The autosave time is entered
in seconds.
Write backup on save
When saving a map called example.vym, vym will rename the existing file to example.vym~
before writing the example.vym itself.
Edit branch after adding it
If set, the heading of a new branch will be edited immediatly after adding the branch.
Select branch after adding it
If set, a new branch will be selected immediatly after adding it. When you brainstorm
on a given keyword, you dont want to go deeper and deeper into details, but keep the
focus on the keyword. So the default setting here is to not select the freshly added branch.

Select existing heading


If set and you begin to edit the heading of a branch, the heading text in the dialog will
be selected. Usefully to copy&paste to other applications.
Delete key
If set, the [Delete] is enabled to, well, delete objects. This can be switched off to avoid
confusing with the nearby [Insert]-key on PC keyboards.
Exclusive flags
If set, some of the standard flags can only be used exclusively, e.g. the smileys.
Use hide flags
If set, every branch which also has the hide flag set (see 7.2) will be hidden in exports.
Note editor is dockable
If set (default), the note editor can be docked into the main widget. Changing this setting
needs a restart of vym . Details see 2.2.
Animation
If set (default), some animation will be used, e.g. for snapping back of released branches.
Autolayout
If set (not on default), vym will try to autolayout mainbranches. Currently considered
experimental and only working under certain circumstances.

A.2

Configuration file

On startup vym will look for a configuration for user specific settings like window positions, toolbars etc. If this file does not already exist, it will be created. The file is located
in the users home directory. The exact position depends on the platform:
Platform Configuration file
Linux
/.config/InSilmaril/vym.conf
Mac OS X /Users/NAME/Library/Preferences/com.insilmaril.vym.plist
The file can be edited manually, or on Mac OS X with Property List Editor (installed
with xtools).

A.3

Path to ressources

vym will try to find its ressources (images, stylesheets, filters, etc.) in the following places:
1. Path given by the environment variable VYMHOME.
2. If called with the local option (see A.4 below), vym will look for its data in the
current directory.
3. /usr/share/vym
4. /usr/local/share/vym

A.4

Command line options

Usage: vym [OPTION]... [FILE]...


Open FILEs with vym
-b
-c
-d
-h
-l
-n STRING
-q
-r FILE
-R
-s
-sl
start
-t
setting
-v

batch
commands
debug
help
local
name
quit
run
restore
shortcuts
LaTeX

batch mode: hide windows


List all available commands
Show debugging output
Show this help text
Run with ressources in current directory
Set name of instance for DBus access
Quit immediatly after start for benchmarking
Run script
Restore last session
Show Keyboard shortcuts on start
Show Keyboard shortcuts in LaTeX format on

testmode

Test mode, e.g. no autosave and changing of its

version

Show vym version

You can also give several filenames at the commandline to let vym open several maps at
once.

Scripts

B.1

Overview

Scripts within vym are so far just a set of instructions, telling vym what to do. Scripts
are internally used for
Undo and Redo
Macros on function keys
Slideshow

So far the scripts have no loop constructs, conditionals, variables, etc. The good news:
You can use external ruby scripts to get all that, see the examples in B.2.
The scripts within vym are edited using the script editor:

Open the scripteditor by pressing [Alt + S] or from the View-menu.

B.2
B.2.1

Example scripts
Macro to create a rounded rectangle frame

# Macro F12
setFrameType ("RoundedRectangle");
setFramePadding (10);
setFrameIncludeChildren (true);
B.2.2

Batch script to export all maps as images

This script can be used to export all maps in a directory automatically. If the script is
named export-image.vys, call vym with
$ vym --quit --run export-image.vys *.vym
B.2.3

Full scripting using ruby and DBUS

Nearly every action in vym can be controlled via DBUS (on Linux machines). You can
have several vym instances running at the same time, e.g. for production and development. Before controlling one, you need to give it a name, here test is used:
vym -n test
You can now access vym via DBUS, if you have Qt installed, try qdbusviewer. In
the scripts directory, which is part of vym , youll find the script vym-ruby.rb. This
rubyscript provides two classes to manage and control vym instances. A short script to
set the heading of a branch might be:
#!/usr/bin/env ruby
require "#{ENV[PWD]}/scripts/vym-ruby"
vym_mgr=VymManager.new
vym=Vym.new(vym_mgr.find(test) )
vym.select "mc:0"
vym.setHeading "This is a new heading!"

An full example how this is used is in the automated vym testing:


test/vym-test.rb

B.3

Available commands

Start vym with the command option to get a listing of available commands:
vym --commands --quit
The currently available commands are:
addBranch
Selection:
Parameter:
Comment:
Type:
Optional:

Branch
0:
Index of new branch
Int
yes

addBranchBefore
Selection: Branch
addMapCenter
Selection: Any
Parameter: 0:
Comment: Position x
Type: Double
Optional: No
Parameter: 1:
Comment: Position y
Type: Double
Optional: No
addMapInsert
Selection: Any
Parameter: 0:
Comment: Filename of map to load
Type: String
Optional: No
Parameter: 1:
Comment: Index where map is inserted
Type: Int
Optional: yes
Parameter: 2:
Comment: Content filter
Type: Int
Optional: yes
addMapReplace
Selection: Branch
Parameter: 0:
Comment: Filename of map to load
Type: String
Optional: No

addSlide
Selection:
addXLink
Selection:
Parameter:
Comment:
Type:
Optional:
Parameter:
Comment:
Type:
Optional:
Parameter:
Comment:
Type:
Optional:
Parameter:
Comment:
Type:
Optional:
Parameter:
Comment:
Type:
Optional:

Branch
BranchLike
0:
Begin of XLink
String
No
1:
End of XLink
String
No
2:
Width of XLink
Int
yes
3:
Color of XLink
Color
yes
4:
Penstyle of XLink
String
yes

branchCount
Selection: BranchLike
centerOnID
Selection:
Parameter:
Comment:
Type:
Optional:
clearFlags
Selection:

Any
0:
UUID of object to center on
String
No
BranchLike

colorBranch
Selection:
Parameter:
Comment:
Type:
Optional:

Branch
0:
New color
Color
yes

colorSubtree
Selection:
Parameter:
Comment:
Type:
Optional:

Branch
0:
New color
Color
yes

copy
Selection:

BranchOrImage

cut
Selection:

BranchOrImage

cycleTask
Selection:
Parameter:
Comment:
Type:
Optional:
delete
Selection:

BranchOrImage
0:
True, if cycling in reverse order
Bool
yes
TreeItem

deleteChildren
Selection: Branch
deleteKeepChildren
Selection: Branch
deleteSlide
Selection:
Parameter:
Comment:
Type:
Optional:

Any
0:
Index of slide to delete
Int
No

exportAO
Selection:
Parameter:
Comment:
Type:
Optional:

Any
0:
Filename for export
String
No

exportASCII
Selection:
Parameter:
Comment:
Type:
Optional:

Any
0:
Filename for export
String
No

exportHTML
Selection:
Parameter:
Comment:
Type:
Optional:

Any
0:
Filename for export
String
No

exportImage
Selection:
Parameter:
Comment:
Type:
Optional:
Parameter:
Comment:
Type:
Optional:

Any
0:
Filename for export
String
No
1:
Image format
String
yes

exportLaTeX
Selection:
Parameter:
Comment:
Type:
Optional:

Any
0:
Filename for export
String
No

exportImpress
Selection: Any
Parameter: 0:
Comment: Filename for export
Type: String
Optional: No
Parameter: 1:
Comment: Configuration file for export
Type: String
Optional: No
exportPDF
Selection:
Parameter:
Comment:
Type:
Optional:

Any
0:
Filename for export
String
No

exportPDF
Selection:
Parameter:
Comment:
Type:
Optional:

Any
0:
Filename for export
String
No

exportSVG
Selection:
Parameter:
Comment:
Type:
Optional:

Any
0:
Filename for export
String
No

exportXML
Selection:
Parameter:
Comment:
Type:
Optional:

Any
0:
Filename for export
String
No

getDestPath
Selection: Any
getFileDir
Selection:

Any

getFrameType
Selection: Branch
getHeading
Selection: TreeItem

getSelectString
Selection: TreeItem
getURL
Selection:

TreeItem

getVymLink
Selection: Branch
getXLinkColor
Selection: XLinkItem
getXLinkWidth
Selection: XLinkItem
getXLinkPenStyle
Selection: XLinkItem
hasActiveFlag
Selection: TreeItem
Parameter: 0:
Comment: Name of flag
Type: String
Optional: No
importDir
Selection:
Parameter:
Comment:
Type:
Optional:
isScrolled
Selection:

Branch
0:
Directory name to import
String
No
Branch

loadImage
Selection:
Parameter:
Comment:
Type:
Optional:

Branch
0:
Filename of image
String
No

loadNote
Selection:
Parameter:
Comment:
Type:
Optional:

Branch
0:
Filename of note
String
No

moveDown
Selection: Branch
moveUp
Selection:

Branch

moveSlideDown
Selection: Any

moveSlideUp
Selection: Any
move
Selection:
Parameter:
Comment:
Type:
Optional:
Parameter:
Comment:
Type:
Optional:

BranchOrImage
0:
Position x
Double
No
1:
Position y
Double
No

moveRel
Selection:
Parameter:
Comment:
Type:
Optional:
Parameter:
Comment:
Type:
Optional:

BranchOrImage
0:
Position x
Double
No
1:
Position y
Double
No

nop
Selection:

Any

note2URLs
Selection: Branch
paste
Selection:

Branch

redo
Selection:

Any

relinkTo
Selection:
Parameter:
Comment:
Type:
Optional:
Parameter:
Comment:
Type:
Optional:
Parameter:
Comment:
Type:
Optional:
Parameter:
Comment:
Type:
Optional:

TreeItem
0:
Selection string of parent
String
No
1:
Index position
Int
No
2:
Position x
Double
yes
3:
Position y
Double
yes

saveImage
Selection:
Parameter:
Comment:
Type:
Optional:
Parameter:
Comment:
Type:
Optional:

Image
0:
Filename of image to save
String
No
1:
Format of image to save
String
No

saveNote
Selection:
Parameter:
Comment:
Type:
Optional:

Branch
0:
Filename of note to save
String
No

scroll
Selection:

Branch

select
Selection:
Parameter:
Comment:
Type:
Optional:

Any
0:
Selection string
String
No

selectID
Selection:
Parameter:
Comment:
Type:
Optional:

Any
0:
Unique ID
String
No

selectLastBranch
Selection: Branch
selectLastImage
Selection: Branch
selectLatestAdded
Selection: Any
setFlag
Selection:
Parameter:
Comment:
Type:
Optional:

TreeItem
0:
Name of flag
String
No

setTaskSleep
Selection:
Parameter:
Comment:
Type:
Optional:

Branch
0:
Days to sleep
Int
No

setFrameIncludeChildren
Selection: BranchOrImage
Parameter: 0:
Comment: Include or dont include children in frame
Type: Bool
Optional: No
setFrameType
Selection: BranchOrImage
Parameter: 0:
Comment: Type of frame
Type: String
Optional: No
setFramePenColor
Selection: BranchOrImage
Parameter: 0:
Comment: Color of frame border line
Type: Color
Optional: No
setFrameBrushColor
Selection: BranchOrImage
Parameter: 0:
Comment: Color of frame background
Type: Color
Optional: No
setFramePadding
Selection: BranchOrImage
Parameter: 0:
Comment: Padding around frame
Type: Int
Optional: No
setFrameBorderWidth
Selection: BranchOrImage
Parameter: 0:
Comment: Width of frame borderline
Type: Int
Optional: No
setHeading
Selection:
Parameter:
Comment:
Type:
Optional:

TreeItem
0:
New heading
String
No

setHideExport
Selection: BranchOrImage
Parameter: 0:
Comment: Set if item should be visible in export
Type: Bool
Optional: No

setIncludeImagesHorizontally
Selection: Branch
Parameter: 0:
Comment: Set if images should be included horizontally in parent branch
Type: Bool
Optional: No
setIncludeImagesVertically
Selection: Branch
Parameter: 0:
Comment: Set if images should be included vertically in parent branch
Type: Bool
Optional: No
setHideLinksUnselected
Selection: BranchOrImage
Parameter: 0:
Comment: Set if links of items should be visible for unselected items
Type: Bool
Optional: No
setMapAnimCurve
Selection: Any
Parameter: 0:
Comment: EasingCurve used in animation in MapEditor
Type: Int
Optional: No
setMapAuthor
Selection: Any
Parameter: 0:
Comment:
Type: String
Optional: No
setMapAnimDuration
Selection: Any
Parameter: 0:
Comment: Duration of animation in MapEditor in milliseconds
Type: Int
Optional: No
setMapComment
Selection: Any
Parameter: 0:
Comment:
Type: String
Optional: No
setMapBackgroundColor
Selection: Any
Parameter: 0:
Comment: Color of map background
Type: Color
Optional: No

setMapDefLinkColor
Selection: Any
Parameter: 0:
Comment: Default color of links
Type: Color
Optional: No
setMapLinkStyle
Selection: Any
Parameter: 0:
Comment: Link style in map
Type: String
Optional: No
setMapRotation
Selection: Any
Parameter: 0:
Comment: Rotation of map
Type: Double
Optional: No
setMapZoom
Selection:
Parameter:
Comment:
Type:
Optional:

Any
0:
Zoomfactor of map
Double
No

setNote
Selection:
Parameter:
Comment:
Type:
Optional:

Branch
0:
Note of branch
String
No

setScale
Selection:
Parameter:
Comment:
Type:
Optional:
Parameter:
Comment:
Type:
Optional:

Image
0:
Scale image x
Double
No
1:
Scale image y
Double
No

setSelectionColor
Selection: Any
Parameter: 0:
Comment: Color of selection box
Type: Color
Optional: No
setURL

Selection:
Parameter:
Comment:
Type:
Optional:

TreeItem
0:
URL of TreeItem
String
No

setVymLink
Selection:
Parameter:
Comment:
Type:
Optional:

Branch
0:
Vymlink of branch
String
No

sleep
Selection:
Parameter:
Comment:
Type:
Optional:

Any
0:
Sleep (seconds)
Int
No

sortChildren
Selection:
Parameter:
Comment:
Type:
Optional:

Branch
0:
Sort children of branch in revers order if set
Bool
yes

toggleFlag
Selection:
Parameter:
Comment:
Type:
Optional:

Branch
0:
Name of flag to toggle
String
No

toggleFrameIncludeChildren
Selection: Branch
toggleScroll
Selection: Branch
toggleTarget
Selection: Branch
toggleTask
Selection:

Branch

undo
Selection:

Any

unscroll
Selection:

Branch

unscrollChildren
Selection: Branch

unsetFlag
Selection:
Parameter:
Comment:
Type:
Optional:

Branch
0:
Name of flag to unset
String
No

Contributing to vym

So far Id say I have written 98% of the code on my own. No surprise, that vym exactly
fits my own needs. Nevertheless I would like to encourage all users of vym to contribute.
Maybe not only with feature requests, but also with code, new import/export filters,
translations etc. In this appendix Ill try to show how easy it is to expand the things you
can do already with vym . I really look forward to hear from you!

C.1

Getting help

Frequently asked questions


Please refer to the FAQ available on the vym website:
http://www.InSilmaril.de/vym/faq.html
Mailinglists
There are several mailinglists: vym-forum is the vym users forum to discuss various
questions, while vym-devel is intended for people interested in contributing to vym .
The third list is vym-trans to coordinate translations. You can view the archives and
subscribe at
https://sourceforge.net/mail/?group id=127802
Contacting the author
Especially for support questions please try the mailinglists first. If everything else fails
you can contact the author Uwe Drechsel at
vym@InSilmaril.de

C.2

How to report bugs

Though Sourceforge has its own bugreporting system, Id rather prefer if you contact me
directly (see C.1) or even better: You can file a bugreport in Bugzilla, the bugtracking
system of openSUSE:
http://en.opensuse.org/Submit a bug

I build vym regulary for openSUSE, so you may report it against a recent version there,
even if you use another Operating System. Please dont forget to tell me what you are
using:
the exact steps needed to reproduce the bug
the version and build date of vym (see the Help About vym )
hardware and Operating System

C.3
C.3.1

Compiling from the sources


Getting the sources

You find the latest version of vym at the project site:


https://sourceforge.net/projects/vym/
There you can check them out of the source repository:

git clone git://vym.git.sourceforge.net/gitroot/vym/vym


or access the git repository directly:
http://vym.git.sourceforge.net/git/gitweb-index.cgi
C.3.2

The Qt toolkit

Qt is C++ toolkit for multiplatform GUI and application development. It provides singlesource portability across MS Windows, Mac OS X, Linux and all major commercial Unix
variants. Qt is also available for embedded devices. Qt is a Nokia product. For more
information see
www.qt.nokia.com
C.3.3

Compiling vym

Make sure you have installed your Qt environment properly, see the Qt documentation
for details. You need to have the Qt command qmake in your PATH-environment, then run
$ qmake
$ make
$ make install
The last command make install needs root-permissions. Of course it may be omitted,
if you just want to test vym . For testing you should also use the -l (local) option on
startup (see A.4).

C.4

vym file format

vym maps usually have the suffix .vym and represent a compressed archive of data. If
you want to have a closer look into the data structure map called mapname.vym, just
edit the XML data by using the vivym script or by uncompressing manually by calling
$ unzip mapname.vym
This will create directories named images and flags in your current directory and also
the map itself, usually named mapname.xml. The XML structure of vym is pretty self
explaining, just have a look at mapname.xml.
This XML file can be loaded directly into vym , it does not have to be compressed. If
you want to compress all the data yourself, use
$ zip -r mapname.vym .
to compress all data in your current directory.

C.5

New features

There are lots of features which might find their way into vym . Together with vym you
should have received a directory with several example maps. You find them by clicking
Help Open vym example maps. There you will find the map vym-projectplan.vym.
It lists quite a lot of things to be done in future. If you have more ideas, contact the
development team at vym-devel@lists.sourceforge.net.

C.6

New languages support

In order to add a new language to vym you need the sources (see C.3.1) and an installation
of Trolltechs QT. A part of QT are the development tools, from those tools especially the
translation tool Linguist is needed.
In some Linux distributions the development tools are in an extra package, e.g. on SUSE
LINUX you should have installed:
libqt4-devel.rpm
libqt4-devel-doc.rpm
libqt4-devel-tools.rpm
If you dont have QT in your system, you can get it from http://www.qt.nokia.com Once
you are able to compile vym yourself, you can translate the text in vym itself by performing
the following steps:
Lets assume now your encoding is NEW instead of for example de for german
or en for english
Copy the file lang/vym en.ts to lang/vym NEW.ts (The code itself contains the
english version.)
Add lang/vym NEW.ts to the TRANSLATIONS section of vym.pro

Run Linguist on vym NEW.ts and do the translation


Run lrelease to create vym NEW.qm
Do a make install to install the new vym and check your translation
If you feel brave, you can also translate the manual. It is written in LaTeX, you just have
to change the file tex/vym.tex. (Linguist and Qt are not needed, but it is useful to know
how to work with LaTeX and esp. pdflatex to create the PDF.)
Please mail me every translation you have done. I can also give you a developer access to
the project, if you want to provide translations regulary.

C.7

New export/import filters

vym supports various kinds of filters. Data can be written directly, inserted into templates
or it can be written as XML data and then processed by XSL transformations.
Most of the import/export functionality is available in the classes ImportBase and ExportBase and subclasses. All of them can be found in imports.h and exports.h.
Direct import/export
An example for a direct export is the XML export. This method touches the implementation of nearly every object of vym , so whenever possible you should better use a XSL
transformation instead.
If you still want to know how it is done, start looking at MapEditor::saveToDir in
mapeditor.cpp.
Templates
Templates have been introduced to export to opendoc format used e.g. by Open Office.
While I read the spec (> 500 pages) about the format10 I had the feeling that I did not
want to write the export from scratch. It would be too complex to adapt the styles to
your own wishes, e.g. the layout.
Instead I analyzed existing Open Office documents. I found out that there are lots of
redundant bits of information in a standard presentation, for example each list item is
contained in its own list. In the end I came up with the default presentation style, which
still could be simplified, just in case you have free time. . .
The existing templates are still work in progress, before you spend too much time developing your own style, please contact me. Basically the following steps are needed to build
your own style:
1. Create an example in Open Office. Use a title, authors name, page heading etc.
which you can easily grep for in the output file.
2. Unzip the Open Office document into a directory.
3. The main file is called content.xml. All data is in one single line. You can split the
XML tags using the script scripts/niceXML, which is part of the vym distribution.
10

http://www.oasis-open.org/

4. Copy the output of niceXML to content-template.xml.


5. Looking closer you will find lots of unused definitions, for example of styles. You
can delete or simply ignore them.
6. Try to find your title, authors name. vym will replace the following strings while
exporting:
<!-<!-<!-<!--

INSERT
INSERT
INSERT
INSERT

TITLE -->
AUTHOR-->
COMMENT -->
PAGES-->

title of map
author
comment
content of map

The content itself is generated in a similar way by inserting lists into page-template.
Here the following substitutions are made:
<!-- INSERT PAGE HEADING-->

<!-- INSERT LIST -->

heading of a page (mainbranch or child


of mainbranch, depending on the use of
sections)
all children of the branch above

Currently images are exported and notes just will appear as text without formatting and
colours.

You might also like