tex/vym.tex
author insilmaril
Tue Jun 19 14:20:29 2007 +0000 (2007-06-19)
changeset 513 5f576e56ad99
parent 493 a3caa8bed260
child 514 497fab7d1404
permissions -rw-r--r--
Exports can (partly) be scripted
insilmaril@509
     1
\documentclass[12pt,a4paper]{article}
insilmaril@509
     2
\usepackage[utf8]{inputenc}
insilmaril@28
     3
\usepackage{verbatim}
insilmaril@28
     4
\usepackage{hyperref}
insilmaril@28
     5
\usepackage{graphicx}
insilmaril@493
     6
%\usepackage{longtable}
insilmaril@28
     7
insilmaril@509
     8
\setlength{\headheight}{0cm}
insilmaril@509
     9
\setlength{\headsep}{0cm}
insilmaril@509
    10
\setlength{\topskip}{0cm}
insilmaril@509
    11
\setlength{\topmargin}{-0.5cm}
insilmaril@509
    12
insilmaril@509
    13
\setlength{\parskip}{1.5ex}
insilmaril@509
    14
\setlength{\parindent}{0cm}
insilmaril@509
    15
\setlength{\oddsidemargin}{0cm}
insilmaril@509
    16
\setlength{\textwidth}{16cm}
insilmaril@509
    17
\setlength{\textheight}{27cm}
insilmaril@509
    18
insilmaril@509
    19
\newlength{\maximgwidth}
insilmaril@509
    20
\setlength{\maximgwidth}{14cm}
insilmaril@509
    21
\newcommand{\maximage}[1]{	
insilmaril@509
    22
	\begin{center}
insilmaril@509
    23
		\includegraphics[width=\maximgwidth]{#1} 
insilmaril@509
    24
	\end{center}
insilmaril@509
    25
}
insilmaril@509
    26
\newcommand{\hint}[1]{
insilmaril@509
    27
	\begin{center}
insilmaril@509
    28
		\begin{tabular}{|rp{12cm}|} \hline
insilmaril@509
    29
			
insilmaril@509
    30
			{\bf Hint}:& #1\\	\hline
insilmaril@509
    31
		\end{tabular}
insilmaril@509
    32
	\end{center}
insilmaril@509
    33
}
insilmaril@509
    34
insilmaril@509
    35
\newcommand{\vym}{{\sc vym }}
insilmaril@509
    36
\newcommand{\ra}{$\longrightarrow$}
insilmaril@509
    37
\newcommand{\la}{$\longleftarrow$}
insilmaril@509
    38
\newcommand{\ua}{$\uparrow$}
insilmaril@509
    39
\newcommand{\da}{$\downarrow$}
insilmaril@509
    40
\newcommand{\key}[1]{[#1]}
insilmaril@509
    41
insilmaril@28
    42
\hypersetup{bookmarks, bookmarksopen,
insilmaril@28
    43
  pdftitle={VYM - a tool for visual thinking },
insilmaril@28
    44
  pdfauthor={Uwe Drechsel},    
insilmaril@28
    45
  pdfsubject={map},
insilmaril@28
    46
  pdfkeywords={map, tool},
insilmaril@28
    47
  pdfpagemode={UseOutlines},                                 
insilmaril@28
    48
  bookmarksopenlevel={1},   
insilmaril@28
    49
  colorlinks={true},     
insilmaril@28
    50
  linkcolor={blue},
insilmaril@28
    51
  urlcolor={green},
insilmaril@28
    52
  citecolor={red}} 
insilmaril@28
    53
insilmaril@28
    54
insilmaril@28
    55
\begin{document}
insilmaril@233
    56
\title{
insilmaril@450
    57
	\includegraphics[width=8cm]{images/vym-logo-new.png}
insilmaril@233
    58
	\\
insilmaril@493
    59
VYM \\ -- \\View Your Mind\\ {\small Version 1.9.0}}
insilmaril@28
    60
\author{\textcopyright Uwe Drechsel  }
insilmaril@28
    61
insilmaril@233
    62
insilmaril@28
    63
\maketitle
insilmaril@28
    64
insilmaril@233
    65
\newpage
insilmaril@233
    66
insilmaril@28
    67
\tableofcontents
insilmaril@28
    68
insilmaril@28
    69
\newpage
insilmaril@28
    70
insilmaril@28
    71
\section{Introduction}
insilmaril@28
    72
\subsection{What is a \vym map?}
insilmaril@486
    73
A \vym map (abbreviated below as {\em map}) is a tree like structure:
insilmaril@509
    74
\maximage{images/example1.png}
insilmaril@486
    75
Such maps can be drawn by hand on a sheet of paper or flip chart and help to
insilmaril@486
    76
structure your thoughts. While a tree like structure like the illustration above can be
insilmaril@264
    77
drawn manually \vym offers much more features to work with such maps.
insilmaril@486
    78
\vym is not just another drawing software application, but a tool to store and modify
insilmaril@264
    79
information in an intuitive way. For example you can reorder parts of
insilmaril@486
    80
the map by pressing a key or add various pieces of information like a complete
insilmaril@264
    81
email by a simple mouse click.
insilmaril@264
    82
insilmaril@486
    83
Once you have finished collecting and organising your ideas, you can
insilmaril@509
    84
easily generate a variety of outputs including for example a
insilmaril@509
    85
presentation in Open~Office based on a {\em map}.
insilmaril@509
    86
insilmaril@509
    87
\hint{You find the map shown above and others by clicking \begin{center}Help \ra Open vym
insilmaril@509
    88
examples\end{center} in the menu bar.}
insilmaril@28
    89
insilmaril@486
    90
\subsection{Why should I use {\em maps}? Time, Space and your Brain.}
insilmaril@28
    91
\subsubsection*{Space}
insilmaril@486
    92
A {\em map} can concentrate very complex content in a small space such as a
insilmaril@28
    93
piece of paper. It helps to use both sides of your brain: the logical
insilmaril@486
    94
side and also your creative side (e.g. by using pictures, colours and
insilmaril@486
    95
keywords in a map, often called {\em anchors}).  It is a technique to help
insilmaril@486
    96
organize the way you think and stimulate your creativity: It can help you by developing, sorting and helping to memorise your ideas. 
insilmaril@28
    97
insilmaril@28
    98
\subsubsection*{Time}
insilmaril@28
    99
Because you just use keywords and drawings, it is much faster than good
insilmaril@486
   100
old fashioned 'notes'. Your brain memorizes things by associating them with
insilmaril@486
   101
other things -- a {\em map} makes use of those connections and stimulates
insilmaril@28
   102
new asccociations. 
insilmaril@28
   103
insilmaril@125
   104
insilmaril@28
   105
\subsubsection*{Your Brain}
insilmaril@486
   106
In 1960 Prof. {\sc Roger Sperry} discovered that both hemispheres
insilmaril@486
   107
of the human brain undertake different tasks (of course both of them
insilmaril@125
   108
basically {\em can} do the same): 
insilmaril@125
   109
\begin{center}
insilmaril@125
   110
\begin{tabular}{|p{5.5cm}|p{5.5cm}|} \hline
insilmaril@125
   111
	Left side & Right side \\ \hline
insilmaril@125
   112
	\begin{itemize}
insilmaril@125
   113
	   \item verbal speech and writing 
insilmaril@125
   114
	   \item numbers
insilmaril@125
   115
	   \item logical thinking
insilmaril@486
   116
	   \item analysing and details
insilmaril@125
   117
	   \item science
insilmaril@125
   118
	   \item linear thinking
insilmaril@125
   119
	   \item concept of time
insilmaril@125
   120
	\end{itemize} &
insilmaril@125
   121
	\begin{itemize}
insilmaril@125
   122
		\item body language
insilmaril@125
   123
		\item visual thinking, day dreams
insilmaril@125
   124
		\item intuition and emotion
insilmaril@125
   125
		\item overview of things
insilmaril@125
   126
		\item creativity
insilmaril@125
   127
		\item art, music, dancing
insilmaril@125
   128
		\item non-linear thinking, connecting things
insilmaril@125
   129
		\item spatial awareness
insilmaril@125
   130
	\end{itemize}     \\ \hline
insilmaril@125
   131
\end{tabular}	
insilmaril@125
   132
\end{center}
insilmaril@486
   133
In our science oriented western society we have learned to mainly rely on our
insilmaril@486
   134
left side of the brain, the "rational" one. In other cultures, such as the native americans and other "old" cultures, the right
insilmaril@486
   135
side is much more important. {\em Map} are just one way to stimulate the
insilmaril@486
   136
other side and make use of additional resources we all have.
insilmaril@28
   137
insilmaril@28
   138
insilmaril@486
   139
\subsection{Where could I use a {\em map}?}
insilmaril@486
   140
Here are some examples, how you can use those {\em maps}
insilmaril@28
   141
\begin{itemize}
insilmaril@28
   142
    \item to prepare articles, papers, books, talks, \ldots
insilmaril@28
   143
    \item to sort complex data
insilmaril@486
   144
    \item to memorize facts, peoples names, vocabulary, \ldots
insilmaril@28
   145
    \item to sort emails, files and bookmarks on your computer
insilmaril@28
   146
    \item to moderate conferences
insilmaril@486
   147
    \item to brainstorm solutions to problems
insilmaril@486
   148
    \item to record the tasks when planning a project
insilmaril@28
   149
\end{itemize}
insilmaril@28
   150
insilmaril@486
   151
\subsection{What you shouldn't do with a {\em map}...}
insilmaril@486
   152
A {\em map} drawn by somebody shows the way that the author thinks. There is
insilmaril@486
   153
no question of right or wrong in the way it is drawn, so there is no way to criticise
insilmaril@486
   154
it. "It is, what it is" ({\sc F.~Lehmann}).The tool will be of considerable use to the author and only very limited use to anyone else. 
insilmaril@486
   155
insilmaril@486
   156
However, when groups share in creating a {\em map} all of the group will benefit from its use. An example of such use is when a Tutor develops a {\em map} with a group of students during instruction. Another group use is when a Project leader gathers a group of specialists to help {\em map} the tasks that will be required to deliver a project.
insilmaril@28
   157
insilmaril@28
   158
%\section{Tutorials}
insilmaril@28
   159
%TODO
insilmaril@28
   160
insilmaril@125
   161
\subsection{Internet Ressources} 
insilmaril@486
   162
A good starting point to learn more about Mindmaps in general is Wikipedia:
insilmaril@125
   163
\begin{itemize}
insilmaril@125
   164
	\item English: 
insilmaril@125
   165
		\href{http://en.wikipedia.org/wiki/Mind_map}{http://en.wikipedia.org/wiki/Mind\_map}
insilmaril@125
   166
	\item German: 
insilmaril@125
   167
		\href{http://de.wikipedia.org/wiki/Mindmap}{http://de.wikipedia.org/wiki/Mindmap}
insilmaril@125
   168
\end{itemize}
insilmaril@125
   169
insilmaril@28
   170
insilmaril@245
   171
insilmaril@245
   172
insilmaril@486
   173
\section{The Concept of the \vym application}
insilmaril@28
   174
%TODO may add a general introduction here...
insilmaril@493
   175
\subsection{The Mainwindow and its satellites} \label{satellite}
insilmaril@493
   176
\vym comes with several windows, the central one being the {\em
insilmaril@493
   177
mapeditor}.
insilmaril@493
   178
More windows, each having a special purpose, can be opened and arranged
insilmaril@493
   179
around the mainwindow\footnote{
insilmaril@493
   180
	The advantage of having separate window instead of integrating them
insilmaril@493
   181
	in a combined workspace is flexibility in arranging the windows. For
insilmaril@493
   182
	example I usually have the {\em noteeditor} "behind" the {\em
insilmaril@493
   183
	mapeditor}. On Linux my windowmanager (KDE) allows me to enter text
insilmaril@493
   184
	into a small visible corner of the {\em noteeditor} withour clicking
insilmaril@493
   185
	the mouse button in it. I just push the mouse around to set the
insilmaril@493
   186
	window focus, a concept which is useful also working with 
insilmaril@493
   187
	\href{http://www.gimp.org}{http://www.gimp.org}.
insilmaril@493
   188
}. 
insilmaril@493
   189
The image below shows the {\em mapeditor}
insilmaril@493
   190
together with the often used {\em noteeditor}: 
insilmaril@509
   191
\maximage{images/windows.png}
insilmaril@486
   192
Most of the time you will work in the {\em mapeditor} by just adding new
insilmaril@28
   193
branches, moving around and reordering them. The various ways to do this
insilmaril@28
   194
will be explained in \ref{mapeditor}. You can store additional
insilmaril@28
   195
information e.g. the content of a email easily in a {\em branch}: Just
insilmaril@28
   196
type or copy\&paste it into the {\em noteeditor}. Working with notes is
insilmaril@28
   197
explained in \ref{noteeditor}
insilmaril@420
   198
 
insilmaril@493
   199
Here is a list of the available satellite windows:
insilmaril@493
   200
\begin{itemize}
insilmaril@493
   201
	\item Noteeditor (see \ref {noteeditor})
insilmaril@493
   202
	\item Historywindow (see \ref{historywindow})
insilmaril@493
   203
	\item Branch Property Window (see \ref{propwindow})
insilmaril@493
   204
\end{itemize}
insilmaril@493
   205
insilmaril@28
   206
insilmaril@245
   207
\subsection{Menus and Context menus}
insilmaril@486
   208
At the top of each window you will find the menubar. The options provided there
insilmaril@486
   209
are similar to those you are probably used to from other applications. Note that
insilmaril@245
   210
many (and even more) options are availabe via {\em context menus}. Those
insilmaril@245
   211
are available if you right-click onto an object in a map (on Mac~OS~X
insilmaril@245
   212
Command-Click).
insilmaril@245
   213
insilmaril@245
   214
\subsection{Toolbars}
insilmaril@245
   215
The toolbars in the mainwindows give quick access to many functions and
insilmaril@493
   216
also display the state of selected objects in the map. For example a
insilmaril@493
   217
branch may show certain {\em flags}, the corresponding flags are also
insilmaril@493
   218
set in the toolbar. 
insilmaril@245
   219
insilmaril@509
   220
\hint {You can reposition all toolbars by simply grabbing and
insilmaril@493
   221
dragging them with the toolbar handle to a new position. For example you
insilmaril@493
   222
can move the flags-toolbar from its original horizontal position on top
insilmaril@493
   223
of the mapeditor to a vertical position on the right side.  Or just
insilmaril@493
   224
insert it again at its original position. Also hiding some of the
insilmaril@509
   225
toolbars is possible by right-clicking on the toolbar handle.}
insilmaril@245
   226
insilmaril@245
   227
\subsection{Maps}
insilmaril@486
   228
The  {\em map} itself has always a {\em mapcenter}.  The
insilmaril@509
   229
mapcenter has {\em branches} radiating out from the centre just like the trunk 
insilmaril@509
   230
of a tree. Each branch in turn may have branches again.
insilmaril@509
   231
	\maximage{images/branches.png}
insilmaril@28
   232
We will call a branch directly connected to the mapcenter a {\em
insilmaril@28
   233
mainbranch}, because it determines the position of all its child
insilmaril@28
   234
branches.
insilmaril@28
   235
insilmaril@28
   236
The mapcenter and the branches all have a {\em heading}. This is the
insilmaril@28
   237
text you see in the mapeditor. Usually it should just be one or a few
insilmaril@486
   238
key words, so that one can easily keep track of the whole map.
insilmaril@28
   239
insilmaril@28
   240
insilmaril@28
   241
In the toolbar above the mapeditor you see various symbols.
insilmaril@509
   242
	\maximage{images/default-flags.png}
insilmaril@28
   243
These are called {\em flags} and can be used to mark branches in the
insilmaril@486
   244
{\em map}, e.g. if something is important or questionable. 
insilmaril@28
   245
There are also more flags set by \vym automatically to show additional
insilmaril@486
   246
information, e.g. when a note is attached to a  particular branch.
insilmaril@28
   247
insilmaril@260
   248
By default some of these flags are set exclusively e.g. when the 
insilmaril@486
   249
"thumb-up" flag is set, then the "thumb down" is reset and vice
insilmaril@104
   250
versa. You can change this default behaviour in the settings menu.
insilmaril@104
   251
insilmaril@28
   252
\section{Mapeditor} \label {mapeditor}
insilmaril@28
   253
\subsection{Start a new map}
insilmaril@486
   254
After \vym is started two windows will open: the {\em mapeditor} and the {\em noteditor}. Usually you will work in both windows, but at the moment we
insilmaril@28
   255
will just need the mapeditor. 
insilmaril@28
   256
insilmaril@28
   257
Select the mapcenter "New map" in the middle of the mapeditor by
insilmaril@486
   258
left-clicking with the mouse. It will be highlighted yellow to show that is
insilmaril@103
   259
selected. There are several ways to add a new branch to the center:
insilmaril@28
   260
\begin{itemize}
insilmaril@486
   261
	\item Using the mouse: Open the context menu by clicking with the
insilmaril@103
   262
	right mouse button (CTRL-Click on Mac) onto the
insilmaril@486
   263
	mapcenter and choose Add \ra Add branch as child
insilmaril@103
   264
	\item Press \key{Ins} or \key{A}
insilmaril@28
   265
\end{itemize}
insilmaril@28
   266
A new branch will appear and you will be able to type the heading of the
insilmaril@28
   267
branch. Finish adding the new branch by pressing \key{Enter}.
insilmaril@28
   268
%tipp
insilmaril@486
   269
Sometimes it comes in handy to be able to add a new branch above or below the current
insilmaril@486
   270
one. 
insilmaril@486
   271
\begin{itemize}
insilmaril@509
   272
	\item Use \key{Shift-A} to add a branch above the selected one or... 
insilmaril@509
   273
	\item \key{Ctrl-A} to add one below. 
insilmaril@486
   274
\end{itemize}
insilmaril@486
   275
It is also
insilmaril@104
   276
possible to add a branch in such a way, that the current selection
insilmaril@104
   277
becomes the child of the new branch, which is like inserting it {\em
insilmaril@104
   278
before} the selection. This can be done using the context menu.
insilmaril@28
   279
insilmaril@509
   280
\hint{To delete a branch press \key{CTRL-X}. If enabled in the Settings
insilmaril@509
   281
menu, you can also use the \key{Del} key.}
insilmaril@509
   282
insilmaril@28
   283
\subsection{Navigate through a map}
insilmaril@28
   284
\subsubsection*{Select branches}
insilmaril@28
   285
To select branches you can use the left button of your mouse or also the
insilmaril@486
   286
arrow keys. Depending on the {\em orientation} of a branch tap
insilmaril@486
   287
\key{\la} or \key{\ra} to move nearer to the mapcenter or deeper
insilmaril@28
   288
down into the branches. Within a set of branches, let's call them a 
insilmaril@28
   289
{\em subtree}, you can use \key{\ua} and \key{\da} to go up and down. You can
insilmaril@486
   290
also use \key{Home} and \key{End} to select the first and last branch.
insilmaril@28
   291
insilmaril@28
   292
insilmaril@486
   293
\subsubsection*{Panning the view of a map}
insilmaril@28
   294
While adding more and more branches the size of the map may become
insilmaril@486
   295
larger than the mapeditor window. You can use the scrollbars on the
insilmaril@486
   296
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 {\em canvas} itself. Choose an empty space somewhere between the branches. The
insilmaril@486
   297
mouse pointer will change from an arrow to a hand, now move or drag the visible
insilmaril@486
   298
map to show the desired part.
insilmaril@28
   299
insilmaril@28
   300
If you select branches using the arrow keys, the map will scroll
insilmaril@28
   301
to ensure that the selected branch is always visible.
insilmaril@28
   302
insilmaril@486
   303
\subsubsection*{Zooming the view of a map}
insilmaril@28
   304
Working with huge maps, the {\em zoom}-function comes in handy: You can
insilmaril@28
   305
use 
insilmaril@28
   306
\begin{itemize}
insilmaril@486
   307
	\item from the menu: View \ra Zoom in, View \ra Zoom out, View \ra reset Zoom.
insilmaril@28
   308
	\item the toolbar buttons 
insilmaril@28
   309
		\begin{center}
insilmaril@450
   310
			\includegraphics[width=3cm]{images/zoom-buttons.png}
insilmaril@28
   311
		\end{center}	
insilmaril@28
   312
\end{itemize}	
insilmaril@486
   313
Clicking the crossed magnifying lens icon will reset the zoomed view to its original size.
insilmaril@28
   314
insilmaril@28
   315
insilmaril@28
   316
\subsubsection*{Find Function} \label{findwindow}
insilmaril@28
   317
With huge maps there is the need to have a
insilmaril@28
   318
find function. Choose Edit \ra Find to open the Find Window:
insilmaril@28
   319
\begin{center}
insilmaril@450
   320
	\includegraphics[width=6cm]{images/find-window.png}
insilmaril@28
   321
\end{center}	
insilmaril@486
   322
The find function will search for, the text you enter here, in all the branch headings and also in the associated notes. Everytime you press the "Find"-button it will look for the next occurence, which will then be selected automatically. If the search
insilmaril@486
   323
fails, a short message "Nothing found" will appear for a few
insilmaril@28
   324
seconds in the {\em statusbar} on the bottom of the mapeditor.
insilmaril@28
   325
insilmaril@260
   326
\subsubsection*{Keep the overview -- scroll a part of the map}
insilmaril@486
   327
A very big subtree of a map e.g. a branch with hundreds of child branches would make
insilmaril@28
   328
it very hard to keep an overview over the whole map. You can hide all
insilmaril@486
   329
the children of a branch by {\em scrolling} it -- this function is often called {\em folding}. Think of the whole subtree as painted onto a
insilmaril@486
   330
broadsheet newspaper. You can scroll or fold the paper to a small roll, leaving just
insilmaril@486
   331
the headline visible.
insilmaril@28
   332
insilmaril@486
   333
To scroll or unscroll a branch and its children,
insilmaril@28
   334
\begin{itemize}
insilmaril@486
   335
	\item press either the \key{Scroll Lock} key or the \key{S}
insilmaril@28
   336
	\item press the middle-mouse button or
insilmaril@486
   337
	\item choose the scroll icon from the toolbar.
insilmaril@28
   338
\end{itemize}
insilmaril@28
   339
If you select parts of a scrolled branch e.g. using the find function or
insilmaril@28
   340
by using the arrow-keys, it will unscroll temporary. This is shown as a
insilmaril@486
   341
scroll with a little hour glass. If the temporary unscrolled part is no
insilmaril@28
   342
longer needed, it will be hidden again automatically. It is also
insilmaril@486
   343
possible to unscroll all branches using "Edit\ra Unscroll all scrolled
insilmaril@486
   344
branches".
insilmaril@28
   345
insilmaril@264
   346
You can also hide parts of the map while exporting it e.g. to a webpage
insilmaril@264
   347
or a presentation, see \ref{hideexport} for details.
insilmaril@28
   348
insilmaril@28
   349
\subsection{Modify and move branches}
insilmaril@260
   350
\subsubsection*{Modify the heading}
insilmaril@28
   351
You can edit the heading by selecting the branch and then
insilmaril@28
   352
\begin{itemize}
insilmaril@28
   353
	\item pressing \key{Enter}
insilmaril@486
   354
	\item pressing \key{F2}
insilmaril@28
   355
	\item double-clicking with left mouse.
insilmaril@28
   356
\end{itemize}
insilmaril@28
   357
Just type the new heading (or edit the old one) and press \key{Enter}.
insilmaril@28
   358
insilmaril@28
   359
\subsubsection*{Move a branch}
insilmaril@28
   360
The easiest way to move a branch is to select it with left-mouse and
insilmaril@28
   361
drag it to the destination while keeping the mouse button pressed.
insilmaril@28
   362
Depending on the branch  it will be
insilmaril@28
   363
\begin{itemize}
insilmaril@28
   364
	\item moved to the destination or
insilmaril@28
   365
	\item {\em linked} to a new {\em parent} (mapcenter or branch)
insilmaril@28
   366
\end{itemize}
insilmaril@28
   367
If you drag the branch over another one or over the mapcenter, you will
insilmaril@28
   368
notice that the  link connecting it to the old parent will be changed to
insilmaril@28
   369
lead to the  new parent which is now under your mousepointer. 
insilmaril@28
   370
If you release the button now, the branch will be relinked.
insilmaril@28
   371
insilmaril@28
   372
If you release the button in the middle of nowhere, the result will
insilmaril@28
   373
depend on the type of branch you are releasing:
insilmaril@28
   374
\begin{itemize}
insilmaril@28
   375
	\item A mainbranch is directly connected to the mapcenter.
insilmaril@28
   376
		It will stay on its new position.
insilmaril@28
   377
	\item An ordinary branch will "jump" back to its original position.	
insilmaril@28
   378
\end{itemize}
insilmaril@28
   379
Thus you can easily rearrange the layout of the mainbranches to avoid
insilmaril@28
   380
overlapping of their subtrees.
insilmaril@28
   381
There is another convenient way to move branches, especially if you want
insilmaril@28
   382
to {\em reorder} a subtree: You can move a branch up or down in a
insilmaril@28
   383
subtree by
insilmaril@28
   384
\begin{itemize}
insilmaril@28
   385
	\item pressing \key{\ua} and \key {\da}
insilmaril@28
   386
	\item selecting Edit \ra Move branch
insilmaril@28
   387
	\item clicking on the toolbar buttons:
insilmaril@28
   388
		\begin{center}
insilmaril@450
   389
			\includegraphics[width=1.5cm]{images/move-buttons.png}
insilmaril@28
   390
		\end{center}	
insilmaril@28
   391
\end{itemize}
insilmaril@28
   392
%tipp
insilmaril@28
   393
There is yet another way to move branches: If you press \key{Shift} or
insilmaril@28
   394
\key{Ctrl} while moving with the mouse, the branch will be added above
insilmaril@486
   395
or below the one the mouse pointer is over. This can also be used to reorder branches in a map.
insilmaril@28
   396
insilmaril@486
   397
\subsection{Colours and Images - Using the right side of your brain}
insilmaril@486
   398
\subsubsection*{Change colour of a heading}
insilmaril@486
   399
You can also use colours to add more information to a map, e.g. use
insilmaril@486
   400
red, green and more colours to prioritize tasks. Again you can
insilmaril@28
   401
\begin{itemize}
insilmaril@486
   402
	\item use the menu and choose e.g Format \ra Set Color
insilmaril@28
   403
	\item use the toolbar
insilmaril@28
   404
		\begin{center}
insilmaril@493
   405
			\includegraphics[width=3cm]{images/color-buttons.png}
insilmaril@28
   406
		\end{center}	
insilmaril@28
   407
\end{itemize}
insilmaril@486
   408
The first button (black in the graphic above) shows the current colour.
insilmaril@486
   409
Clicking on it let's you choose another colour. You can also "pick"
insilmaril@486
   410
another colour by selecting a branch with the desired colour and using the
insilmaril@486
   411
"pick colour" button. Both of the icons showing a palette actually apply
insilmaril@486
   412
the current colour to the selected branch. While the first one just
insilmaril@486
   413
colours the heading of the selection, the last one also colours all the
insilmaril@486
   414
children of the selected branch.
insilmaril@28
   415
insilmaril@28
   416
%tipp
insilmaril@486
   417
A very useful function is the "copy colour" using the mouse: Select the
insilmaril@486
   418
branch which should get the new colour, then press \key{Ctrl} and
insilmaril@486
   419
simultanously click with left-mouse on another branch to copy its colour
insilmaril@486
   420
to the first one. Here the children of the selection also will get the new
insilmaril@486
   421
colour, if you just want to colour the selection itself, additionally
insilmaril@28
   422
press \key{Shift}.
insilmaril@28
   423
insilmaril@28
   424
\subsubsection*{Use flags}
insilmaril@486
   425
\vym provides various flags. They are usually displayed in the toolbar on top of the
insilmaril@28
   426
mapeditor window. (Note: Like all toolbars you can also move them to the
insilmaril@28
   427
left or the right side of the window or even detach them. Just grab the
insilmaril@28
   428
very left "dotted" part of the toolbar with your left-mouse button.) 
insilmaril@509
   429
	\maximage{images/default-flags.png}
insilmaril@28
   430
If you have a branch selected, you can set any number of flags by
insilmaril@28
   431
clicking them in the toolbar. The toolbar buttons change their state and
insilmaril@486
   432
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.
insilmaril@28
   433
insilmaril@486
   434
At present \vym uses two kinds of flags: {\em System Flags} and {\em
insilmaril@28
   435
Standard Flags}. The standard flags are those shown in the toolbar.
insilmaril@28
   436
System flags are set by \vym to indicate e.g. that there is additional
insilmaril@28
   437
information in a note (more on this in \ref{noteeditor}). Later versions
insilmaril@28
   438
of \vym may have another kind of flags, which may be edited by the user.
insilmaril@28
   439
insilmaril@28
   440
\subsubsection*{Images}
insilmaril@125
   441
The easiest way to add an image to a branch is by dragging it e.g. from a
insilmaril@125
   442
webbrowser to the mapeditor while a branch is selected there.
insilmaril@125
   443
insilmaril@486
   444
You can also add an image to a branch by opening the context menu of the
insilmaril@493
   445
branch. Right click the selected branch, choose "Add Image". A
insilmaril@486
   446
dialog window enables you choose the image to load. 
insilmaril@28
   447
\footnote{Supported image types are: PNG, BMP, XBM, XPM and PNM. It may
insilmaril@28
   448
	also support JPEG, MNG and GIF, if specially configured during
insilmaril@28
   449
	compilation (as done when \vym is part of SUSE LINUX).}
insilmaril@486
   450
While an image is selected in the dialog, a preview of the
insilmaril@486
   451
image is displayed. It is also possible to select multiple images.	
insilmaril@28
   452
insilmaril@28
   453
You can position the image anywhere you want, just drag it with left
insilmaril@28
   454
mouse. To relink it to another branch, press \key{Shift} while moving
insilmaril@28
   455
it. To delete it, press \key{Del}. 
insilmaril@28
   456
insilmaril@28
   457
If you right-click onto an image, a context menu will open which let's
insilmaril@28
   458
you first choose one of several image formats. Then a file dialog opens
insilmaril@486
   459
to save the image. 
insilmaril@486
   460
insilmaril@486
   461
Hint: This is used to "export" the image, it will be
insilmaril@28
   462
saved anyway in the map itself! You can also cut and
insilmaril@28
   463
copy images, but it is not possible to add objects to an image\footnote{
insilmaril@28
   464
	Images are regarded as "extra feature". It would make working with
insilmaril@28
   465
	the map much more complex if e.g. images could be linked to images.}
insilmaril@28
   466
insilmaril@28
   467
The option \lq{\bf Use for export} \rq controls the output of exports
insilmaril@28
   468
e.g. to HTML: If set to no, the image won't appear in the {\em text}
insilmaril@28
   469
part of the output. This is useful for large images or if images are
insilmaril@28
   470
used as a kind of frame e.g. the famous cloud symbol around a part of
insilmaril@28
   471
the map. Those shouldn't appear in the middle of the text.
insilmaril@28
   472
insilmaril@28
   473
At the moment image support is preliminary: Images will be saved
insilmaril@28
   474
together with all the other data of a map in the {\tt .vym}-file.
insilmaril@28
   475
Later versions will include more functionality like resizing the images,
insilmaril@28
   476
changing its z-value (put it into background) etc.
insilmaril@28
   477
insilmaril@28
   478
\subsubsection*{Frames}
insilmaril@493
   479
A frame can be added to a branch in the {\em property window} (see
insilmaril@493
   480
\ref{propwindow}). 
insilmaril@493
   481
Alternatively, you can use use images as frames. Have a look at the demo
insilmaril@493
   482
map {\tt todo.vym} as an example, where the mapcenter is a cloud. You
insilmaril@493
   483
can use an external drawing program like {\tt gimp} to create an image,
insilmaril@28
   484
preferable with an transparency channel, so that you can design frames
insilmaril@493
   485
which don't use a rectangular borderline, just like that cloud.
insilmaril@28
   486
insilmaril@28
   487
insilmaril@493
   488
\subsection{Design of map background and connecting links }
insilmaril@28
   489
The design of the background of a map and also of the links connecting
insilmaril@28
   490
various parts of the map can be changed by
insilmaril@28
   491
\begin{itemize}
insilmaril@28
   492
	\item Selecting Format from the menu
insilmaril@486
   493
	\item Right clicking on the canvas, which will open a context menu
insilmaril@28
   494
\end{itemize}
insilmaril@28
   495
insilmaril@493
   496
\subsubsection*{Background }
insilmaril@486
   497
The colour is set (and also displayed) as "Set background colour".
insilmaril@493
   498
Alternatevily you can set an background image, though this is not
insilmaril@493
   499
recommended in general. Working on the map becomes slow and the image
insilmaril@493
   500
currently cannot be positioned freely.
insilmaril@28
   501
insilmaril@486
   502
\subsubsection*{Link colour}
insilmaril@486
   503
Links connecting branches can be coloured in one of two ways:
insilmaril@28
   504
\begin{itemize}
insilmaril@486
   505
	\item use the same colour for the heading and for the branch link line.
insilmaril@486
   506
	\item use {\em one} colour for all links and choose different colours for the branch headings text. The default colour for branch link lines is blue.
insilmaril@28
   507
\end{itemize}
insilmaril@486
   508
The latter can be set with "Set link colour". Check or uncheck the "Use
insilmaril@486
   509
colour of heading for link" option to toggle between the two designs for
insilmaril@28
   510
your map.
insilmaril@28
   511
insilmaril@28
   512
\subsubsection*{Link style}
insilmaril@28
   513
\vym offers four different styles for the appearences of links:
insilmaril@28
   514
\begin{itemize}
insilmaril@28
   515
	\item Line
insilmaril@28
   516
	\item Parabel
insilmaril@28
   517
	\item Thick Line
insilmaril@28
   518
	\item Thick Parabel
insilmaril@28
   519
\end{itemize}
insilmaril@486
   520
The "thick" styles only apply to links starting at the mapcenter, link lines for the rest
insilmaril@486
   521
of the map are always painted "thin".
insilmaril@28
   522
insilmaril@28
   523
insilmaril@260
   524
\subsection{Links to other documents and webpages}
insilmaril@260
   525
\vym supports two kind of external links:
insilmaril@28
   526
\begin{itemize}
insilmaril@28
   527
	\item Document, which will be opened in an external webbrowser
insilmaril@28
   528
	\item \vym map, which will be opened in \vym itself
insilmaril@28
   529
\end{itemize}
insilmaril@260
   530
In addition to the external links there also internal ones, leading from one
insilmaril@486
   531
branch in a map to another one. Those are called {\em XLinks} and are explained
insilmaril@260
   532
in section~\ref{xlinks}.
insilmaril@28
   533
insilmaril@28
   534
\subsubsection*{Webbrowser}
insilmaril@486
   535
Modern Webbrowsers like {\tt konqueror and Firefox} are able to display various
insilmaril@486
   536
types of files, both local or on the internet. To enter the URL of
insilmaril@486
   537
any document, right-click  onto a branch to open the contextmenu then choose "Edit URL". Enter the path to your document (or copy and paste it from your browser). Examples for valid paths are:
insilmaril@28
   538
\begin{verbatim}
insilmaril@28
   539
	http://www.insilmaril.de/vym/index.html
insilmaril@28
   540
	file:/usr/share/doc/packages/vym/doc/vym.pdf
insilmaril@28
   541
\end{verbatim}
insilmaril@28
   542
If an URL was entered, a little globe will appear in the branch. By
insilmaril@28
   543
clicking on the globe in the toolbar or the context menu an external
insilmaril@28
   544
browser\footnote{
insilmaril@28
   545
	The browser can be changed in the Settings Menu.}
insilmaril@486
   546
will be launched.
insilmaril@28
   547
\begin{center}
insilmaril@450
   548
	\includegraphics[width=0.5cm]{images/flag-url.png}
insilmaril@28
   549
\end{center}
insilmaril@340
   550
For more information on working with bookmarks and webbrowsers see
insilmaril@340
   551
section \ref{bookmarks}.
insilmaril@266
   552
insilmaril@493
   553
In the context menu there is also an option to open all URLs found
insilmaril@493
   554
in the selected subtree of the map. That's useful to simultanously open
insilmaril@493
   555
a collection of URLs in the webbrowser, especially if the browser can
insilmaril@493
   556
open them in tabs (like Konqueror).
insilmaril@493
   557
insilmaril@28
   558
insilmaril@28
   559
\subsubsection*{\vym map}
insilmaril@486
   560
To link to to another map right click on a branch and choose "Edit \vym link". A file dialog opens where you can choose the map. A
insilmaril@28
   561
branch with a link is marked with 
insilmaril@28
   562
\begin{center}
insilmaril@450
   563
	\includegraphics[width=0.5cm]{images/flag-vymlink.png}
insilmaril@28
   564
\end{center}
insilmaril@486
   565
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 \ref{tabs} for working with
insilmaril@486
   566
multiple maps). To delete an existing link, just right click the branch and select "Delete \vym link".
insilmaril@28
   567
insilmaril@493
   568
In the context menu there is also an option to open all vymlinks found
insilmaril@493
   569
in the selected subtree of the map. That's useful to simultanously open
insilmaril@493
   570
a collection of related maps.
insilmaril@493
   571
insilmaril@28
   572
Technical note: Internally \vym uses absolute paths, to avoid opening
insilmaril@28
   573
several tabs containing the same map. When a map is saved, this path is
insilmaril@28
   574
converted to a relative one (e.g. {\tt /home/user/vym.map} might become
insilmaril@28
   575
{\tt ./vym.map}. This makes it fairly easy to use multiple maps on
insilmaril@28
   576
different computers or export them to HTML in future.
insilmaril@28
   577
insilmaril@28
   578
\subsection{Multiple maps} \label{tabs}
insilmaril@28
   579
You can work on multiple maps at the same time. Each new map is opened
insilmaril@28
   580
in another {\em tab}. The available tabs are shown just above the
insilmaril@28
   581
mapeditor. You can use the normal cut/copy/paste functions to
insilmaril@28
   582
copy data from one map to another.
insilmaril@28
   583
insilmaril@28
   584
%todo
insilmaril@28
   585
insilmaril@28
   586
%TODO
insilmaril@28
   587
%\subsubsection{Menus}
insilmaril@28
   588
%\subsubsection{Keyboard shortcuts}
insilmaril@28
   589
insilmaril@28
   590
% Settings
insilmaril@28
   591
% Images
insilmaril@28
   592
% Copy & Paste
insilmaril@28
   593
% Working with tabs (multiple maps)
insilmaril@28
   594
% Exporting
insilmaril@28
   595
% Scrolling
insilmaril@28
   596
insilmaril@28
   597
\section{Noteeditor} \label {noteeditor}
insilmaril@486
   598
If you want to attach more text to a branch e.g. a complete email, a
insilmaril@28
   599
cooking recipe, or the whole source code of a software project, you can
insilmaril@125
   600
use the noteeditor. 
insilmaril@509
   601
	\maximage{images/noteeditor.png}
insilmaril@486
   602
This editor displays text associated with a branch selected in the mapeditor. The noteeditor
insilmaril@486
   603
shows different background colours depending on whether text is associated with a selected branch.
insilmaril@28
   604
insilmaril@125
   605
\subsection{States}
insilmaril@28
   606
Before you can type or paste text into it, you have
insilmaril@486
   607
to select a branch in the mapeditor. Note that the background colour
insilmaril@28
   608
of the noteeditor indicates its state:
insilmaril@28
   609
\begin{itemize}
insilmaril@28
   610
	\item grey: no text entered yet
insilmaril@486
   611
	\item white: some text has been entered
insilmaril@28
   612
\end{itemize}	
insilmaril@486
   613
In the mapeditor itself, to signal that there is a note with more
insilmaril@486
   614
information for a particular branch, a little "note" flag will appear next
insilmaril@486
   615
to the heading of the branch. This is illustrated in the lower branch on the right hand side:
insilmaril@509
   616
	\maximage{images/branches-flags.png}
insilmaril@28
   617
insilmaril@125
   618
\subsection{Import and export notes}
insilmaril@420
   619
The note is always saved automatically within the \vym map itself.
insilmaril@28
   620
Nevertheless sometimes it is nice to import a note from an external file
insilmaril@486
   621
or write it. In the Note Editor use "File\ra~Import" and "File\ra~Export" to do so. 
insilmaril@28
   622
insilmaril@125
   623
\subsection{Edit and print note}
insilmaril@28
   624
Editing works like in any simple texteditor, including undo and redo
insilmaril@28
   625
functions. You can delete the complete note by clicking the
insilmaril@28
   626
trashcan. Only the note itself is printed by clicking the printer icon.
insilmaril@28
   627
insilmaril@486
   628
\subsection{RichText: Colours, paragraphs and formatted text}
insilmaril@233
   629
\vym supports formatted text (QT Rich Text) in the noteeditor since
insilmaril@486
   630
version 1.4.7.  Colours and text attributes (e.g. italic, bold) can be
insilmaril@486
   631
set with the buttons above the text.  The text itself is divided into
insilmaril@233
   632
paragraphs. For each paragraph the format can be set (e.g. centered,
insilmaril@233
   633
right). A paragraph is ended when a \key{Return} is entered. If you just
insilmaril@233
   634
want to begin a new line, press \key{CTRL-Return}.
insilmaril@233
   635
insilmaril@486
   636
\subsection{Fonts and how to switch them quickly}
insilmaril@486
   637
The noteeditor is designed to be used for simple notes, not really as a full
insilmaril@493
   638
featured word processor. Because of many requests \vym supports 
insilmaril@28
   639
formatted text in the noteeditor\footnote{
insilmaril@28
   640
	\vym uses the QRichtText format, which is basically a subset of the
insilmaril@28
   641
	formatting provided in HTML.}
insilmaril@28
   642
Two default fonts are supported which can be set in the Settings menu.
insilmaril@28
   643
One is a fixed width font, the other has variable width. The fixed font
insilmaril@28
   644
is usually used for emails, source code etc.\ while the variable font is
insilmaril@28
   645
used for simple notes, where one doesn't need fixed character widths.
insilmaril@28
   646
Both fonts can easily switched using the following symbol from the
insilmaril@28
   647
toolbar:
insilmaril@28
   648
\begin{center}
insilmaril@450
   649
	\includegraphics[width=0.5cm]{images/formatfixedfont.png}
insilmaril@28
   650
\end{center}
insilmaril@486
   651
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.
insilmaril@28
   652
insilmaril@28
   653
Additionally to the default fonts any font installed on your system can
insilmaril@28
   654
be used. Please note, that the chosen font also will be used for HTML
insilmaril@486
   655
exports, so if youy VYM mind map could ever be exported to a web or intranet page you should only use fonts which are available generally.
insilmaril@28
   656
insilmaril@217
   657
\subsection{Find text}
insilmaril@28
   658
The noteeditor itself has no Find function, use Find in the mapeditor,
insilmaril@28
   659
which will also search all notes (see \ref{findwindow}).
insilmaril@28
   660
insilmaril@217
   661
\subsection{Paste text into note editor}
insilmaril@28
   662
Often you will paste text into the editor from another application e.g.
insilmaril@28
   663
an email. Normally \vym will generate a new paragraph for each new line.
insilmaril@28
   664
This usually is not what you want, so you can choose from the menu
insilmaril@28
   665
insilmaril@493
   666
insilmaril@28
   667
\section{Hello world}
insilmaril@233
   668
This section is about how \vym can interact with other applications.
insilmaril@486
   669
Many applications can now read and write their data using XML, the
insilmaril@233
   670
eXtensible Markup Language. \vym also uses XML to save its maps, see
insilmaril@233
   671
\ref{fileformat} for a more detailed description. 
insilmaril@233
   672
insilmaril@486
   673
So if you make use of another application that understands XML, chances are good that someone
insilmaril@233
   674
could write import/export filters for \vym. Volunteers are always
insilmaril@233
   675
welcome ;-)
insilmaril@233
   676
insilmaril@340
   677
\subsection{Import} \label{import}
insilmaril@233
   678
insilmaril@233
   679
\subsubsection*{KDE Bookmarks}
insilmaril@486
   680
The integrated bookmark editor in KDE (Konqueror etc.) is somewhat limited, so why not
insilmaril@233
   681
use \vym to maintain the bookmark mess? To create a new map containing
insilmaril@233
   682
your current KDE bookmarks just choose
insilmaril@233
   683
\begin{itemize}
insilmaril@486
   684
	\item File \ra Import\ra KDE Bookmarks
insilmaril@233
   685
\end{itemize}
insilmaril@233
   686
insilmaril@233
   687
\subsubsection*{Mind Manager}
insilmaril@233
   688
\vym has currently a very basic import filter to convert maps created by
insilmaril@486
   689
{\em Mind Manager}\footnote{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
insilmaril@486
   690
\href{http://mindjet.com}{http://mindjet.com}} into \vym maps. Notes and
insilmaril@233
   691
pictures are not converted at the moment. You can import files with
insilmaril@233
   692
\begin{itemize}
insilmaril@486
   693
	\item File \ra Import\ra Mind Manager
insilmaril@233
   694
\end{itemize}
insilmaril@233
   695
insilmaril@233
   696
insilmaril@233
   697
\subsubsection*{Directory structure}
insilmaril@233
   698
\vym can read a directory structure. This is mainly for
insilmaril@233
   699
testing \vym e.g. to easily create huge maps used for benchmarks (yes,
insilmaril@233
   700
there is still room to optimize \vym ;-)
insilmaril@28
   701
insilmaril@340
   702
insilmaril@340
   703
insilmaril@340
   704
insilmaril@340
   705
\subsection{Export}  \label{export}
insilmaril@264
   706
\label{hideexport}
insilmaril@486
   707
Often you may not want to export the whole map, but just parts of it. For
insilmaril@264
   708
example you may have additional info you want to talk about in a
insilmaril@264
   709
presentation, while those parts should not be visible to the audience.
insilmaril@264
   710
To achieve this you can "hide" parts of the map during exports by
insilmaril@291
   711
setting the "hide in export" flag.
insilmaril@264
   712
\begin{center}
insilmaril@450
   713
	\includegraphics[width=0.5cm]{images/flag-hideexport.png}
insilmaril@264
   714
\end{center}
insilmaril@291
   715
You can toggle this flag in the toolbar or by pressing \key{H}.
insilmaril@264
   716
Note that there is a global option in the settings menu to toggle the
insilmaril@264
   717
use of this flag. By default the flag is enabled.
insilmaril@233
   718
insilmaril@233
   719
\subsubsection*{Open Office}
insilmaril@486
   720
Open Office beginning with version~2 uses the so called "Open Document Format", which can be written by \vym. The options are
insilmaril@233
   721
currently limited, but it possible to export presentations which can be
insilmaril@233
   722
opened in Open Office Impress. By selecting
insilmaril@28
   723
\begin{itemize}
insilmaril@486
   724
	\item File  \ra Export\ra Open Office
insilmaril@28
   725
\end{itemize}
insilmaril@233
   726
you get a file dialogue where you can choose the output file and the
insilmaril@233
   727
file type:
insilmaril@509
   728
	\maximage{images/export-oo.png}
insilmaril@233
   729
The file types represent various templates, which can be created with
insilmaril@233
   730
some manual work from an existing Open Office document. The structure of
insilmaril@233
   731
\vym map is then inserted into a template. 
insilmaril@233
   732
There are some limitations at the moment:
insilmaril@233
   733
\begin{itemize}
insilmaril@233
   734
	\item \vym can't take care of page lengths, so you have to check and
insilmaril@233
   735
	probably reedit in Open Office to avoid text running over the end of
insilmaril@233
   736
	a page
insilmaril@233
   737
	\item Images and flags are not used at the moment
insilmaril@486
   738
	\item Notes are just written as plain text, without RichText 
insilmaril@486
   739
	\item The full range of templates are not available in all distributions.	
insilmaril@233
   740
\end{itemize}
insilmaril@486
   741
Some of the templates make use of {\em sections} i.e sections insert the
insilmaril@233
   742
headings of mainbranches as chapters for sections into the presentation.
insilmaril@28
   743
insilmaril@28
   744
\subsubsection*{Image}
insilmaril@28
   745
\vym supports all image formats which are natively supported by the
insilmaril@28
   746
QT~toolkit:
insilmaril@28
   747
BMP, JPEG, PBM, PGM, PNG, PPN, XPM, and XBM.
insilmaril@28
   748
For use in websites and for sending images by email PNG is a good
insilmaril@28
   749
recommodation regarding quality and size of the image. \vym uses QTs
insilmaril@28
   750
default options for compressing the images.
insilmaril@28
   751
insilmaril@28
   752
\subsubsection*{ASCII}
insilmaril@28
   753
Exporting an image as text is somewhat experimental at the moment. Later
insilmaril@486
   754
this will probably be done using stylesheets. So the output may change in
insilmaril@28
   755
future versions of \vym.
insilmaril@28
   756
insilmaril@233
   757
\subsubsection*{\LaTeX}
insilmaril@233
   758
\vym can generate an input file for \LaTeX. Currently this is considered
insilmaril@233
   759
as experimental, there are no options (yet). 
insilmaril@233
   760
By selecting
insilmaril@233
   761
\begin{itemize}
insilmaril@486
   762
	\item File  \ra Export\ra \LaTeX 
insilmaril@233
   763
\end{itemize}
insilmaril@233
   764
you will be asked in a file dialog for the name of the output file. This
insilmaril@486
   765
file may then be included in a \LaTeX document using command: 
insilmaril@233
   766
\begin{verbatim}
insilmaril@233
   767
	\include{inputfile.tex}
insilmaril@233
   768
\end{verbatim}
insilmaril@233
   769
insilmaril@340
   770
\subsubsection*{KDE Bookmarks}
insilmaril@340
   771
\vym will overwrite the KDE bookmarks file and then try to notify
insilmaril@486
   772
running Konquerors via DCOP of the changed file. \vym does not create a
insilmaril@340
   773
backup!
insilmaril@340
   774
\begin{itemize}
insilmaril@486
   775
	\item File \ra Export \ra KDE Bookmarks
insilmaril@340
   776
\end{itemize}
insilmaril@340
   777
insilmaril@340
   778
insilmaril@233
   779
\subsubsection*{XHTML (Webpages)}
insilmaril@233
   780
insilmaril@486
   781
This is the format to use if you wish to create a webpage. To see an example
insilmaril@486
   782
visit the \vym homepage: 
insilmaril@233
   783
\href{http://www.InSilmaril.de/vym}{www.InSilmaril.de/vym}
insilmaril@233
   784
insilmaril@486
   785
Some explanation on how this works: 
insilmaril@233
   786
Before a map is exported as XHTML, it will be first written as XML into a
insilmaril@28
   787
directory (see \ref{xmlexport}). Then the external program {\tt
insilmaril@486
   788
xsltproc}\footnote{On SUSE Linux and some other distributions {\tt xsltproc} is installed by
insilmaril@28
   789
default.}
insilmaril@28
   790
will be called to process the XML file and generate HTML code.
insilmaril@486
   791
A dialog allows the user to set various options:
insilmaril@28
   792
\begin{itemize}
insilmaril@28
   793
	\item {\bf Include image:} If set, \vym will creat an image map at
insilmaril@28
   794
	the top of the HTML output. Clicking on a branch in the map will
insilmaril@28
   795
	jump to the corresponding section in the output.
insilmaril@28
   796
insilmaril@28
   797
	\item {\bf Colored headings:}
insilmaril@486
   798
	If set to yes, \vym will colour the headings in the text part  with the
insilmaril@486
   799
	same colours used in the \vym map.
insilmaril@28
   800
	\item {\bf Show Warnings:}
insilmaril@28
   801
	If set to yes, \vym will ask before overwriting data.
insilmaril@28
   802
	\item {\bf Show output:}
insilmaril@28
   803
	This is useful mainly for debugging. It will show how the processing of
insilmaril@28
   804
	the XML file works by calling the external {\tt xsltproc}.
insilmaril@28
   805
\end{itemize}
insilmaril@28
   806
Additionally the paths to the CSS and XSL stylesheets can be set. By
insilmaril@28
   807
default on SUSE~Linux they will be in {\tt /usr/share/vym/styles}.
insilmaril@28
   808
insilmaril@28
   809
insilmaril@28
   810
\subsubsection*{XML} \label{xmlexport}
insilmaril@486
   811
The map is written into a directory both as an image and as an XML file. The
insilmaril@28
   812
directory is set in a file dialog. If the directory is not empty, you
insilmaril@486
   813
will be warned and offered choices if you are at risk of overwriting existing contents.
insilmaril@28
   814
insilmaril@28
   815
It is possible to export different maps into the same directory. Each
insilmaril@28
   816
file generated will have the map's name as prefix, e.g. {\tt todo.vym}
insilmaril@28
   817
becomes {\tt todo.xml}, {\tt todo.png}, {\tt todo-image-1.png} and so
insilmaril@486
   818
on. This is useful if, for example, a website comprises several combined maps that have to be stored in the same directory.
insilmaril@28
   819
insilmaril@105
   820
\subsubsection*{Export a part of a map}
insilmaril@486
   821
Select a branch you want to export together with its children, then open
insilmaril@105
   822
the context menu and choose {\em Save Selection}. This will create a
insilmaril@486
   823
file with the suffix {\tt .vyp}, which is an abbreviation for \lq vym
insilmaril@105
   824
part\rq.
insilmaril@105
   825
insilmaril@125
   826
insilmaril@125
   827
\section{Advanced Editing}
insilmaril@340
   828
insilmaril@493
   829
\subsection{Properties of an object} 
insilmaril@493
   830
For any branch you can open a satellite window (see \ref{satellite}):
insilmaril@493
   831
the {\em property window}:
insilmaril@493
   832
\begin{center}
insilmaril@493
   833
	\includegraphics[width=8cm]{images/propwindow.png}
insilmaril@493
   834
	\label{propwindow}
insilmaril@493
   835
\end{center}
insilmaril@493
   836
%FIXME create screenshot
insilmaril@493
   837
%FIXME explain the tabs
insilmaril@493
   838
insilmaril@493
   839
\begin{itemize}
insilmaril@493
   840
	\item Frame
insilmaril@493
   841
	\item Link (see \ref{hideunselected})
insilmaril@493
   842
	\item Layout (see \ref{incimg})
insilmaril@493
   843
\end{itemize}
insilmaril@493
   844
insilmaril@420
   845
\subsection{Changing the history: Undo and Redo}
insilmaril@493
   846
\vym keeps track of all changes done in a map. The default number of
insilmaril@493
   847
changes which can be undone is~75. The complete history can be seen in
insilmaril@493
   848
the {\em historywindow}:
insilmaril@509
   849
	\maximage{images/historywindow.png}
insilmaril@493
   850
	\label{historywindow}
insilmaril@493
   851
A single step back be undone or redone with \key{CTRL-Z} or \key{CTRL-Y},
insilmaril@493
   852
or by using the buttons in the toolbar or the {\em historywindow}.
insilmaril@493
   853
Inside the {\em historywindow}, you can click on a line to unwind all
insilmaril@493
   854
actions done until that point in time -- or redo all changes by clicking
insilmaril@493
   855
on the last line.
insilmaril@420
   856
insilmaril@509
   857
\hint{
insilmaril@509
   858
	You can "paste from the past": Go back in time by e.g. with
insilmaril@509
   859
	\key{CTRL-Z}, then copy to clipboard by pressing \key{CTRL-C}.
insilmaril@509
   860
insilmaril@509
   861
	Now do all actions again, e.g. by \key{CTRL-Y} or clicking on the
insilmaril@509
   862
	last action in {\em historywindow}. Now paste from the past with
insilmaril@509
   863
	\key{CTRL-V}.
insilmaril@509
   864
}
insilmaril@509
   865
insilmaril@450
   866
\subsection{Macros} \label{macros}
insilmaril@450
   867
Macros have been added to \vym in version~1.9.0. Each function key
insilmaril@450
   868
\key{F1} to \key{F12} holds a macro, which is executed on the current
insilmaril@486
   869
selection if the key is pressed. The default macros change the colour of
insilmaril@450
   870
a subtree or set the frame of a branch:
insilmaril@450
   871
\begin{center}
insilmaril@450
   872
	\includegraphics[width=8cm]{images/macros.png}
insilmaril@450
   873
\end{center}
insilmaril@450
   874
Each macro is a \vym script, which is executed when the associated key
insilmaril@450
   875
is pressed. The default location of the scripts can be changed in the
insilmaril@450
   876
Settings menu. More information on using scripts in \vym is found in
insilmaril@450
   877
appendix~\ref{scripts}.
insilmaril@450
   878
insilmaril@493
   879
\subsection{Bookmarks} \label{bookmarks}
insilmaril@340
   880
\subsubsection*{Open new tabs instead of new windows}
insilmaril@486
   881
If you use konqueror as your browser, \vym will remember the konqueror session which
insilmaril@340
   882
was opened first by \vym. You can also press \key{Ctrl} and click to
insilmaril@486
   883
open the link in a new tab.
insilmaril@340
   884
insilmaril@340
   885
\vym can also open a new tab in Mozilla or Firefox using the remote
insilmaril@340
   886
command\footnote{\href{http://www.mozilla.org/unix/remote.html}{http://www.mozilla.org/unix/remote.html}}
insilmaril@486
   887
of these browsers.
insilmaril@340
   888
insilmaril@340
   889
\subsubsection*{Drag and Drop}
insilmaril@340
   890
If you want to keep bookmarks in a map, select a branch where you want
insilmaril@340
   891
to add the bookmark, then simply drag the URL from your browser to the
insilmaril@340
   892
map. Also you could use an existing heading as URL: Right click onto the
insilmaril@340
   893
branch and select "Use heading for URL".
insilmaril@340
   894
insilmaril@340
   895
insilmaril@340
   896
\subsubsection*{Directly access bookmark lists of a browser}
insilmaril@340
   897
Please see the sections \ref{import} and \ref{export} about
insilmaril@340
   898
Import and Export filters.
insilmaril@340
   899
insilmaril@340
   900
\subsubsection*{Special URLs}
insilmaril@340
   901
\vym can turn an existing heading of a branch into an URL. Currently
insilmaril@340
   902
this works for Bugentries in the Novell Bugtracking system: Open the
insilmaril@340
   903
context menu of a branch (usually by right-clicking it) and select
insilmaril@340
   904
\begin{itemize}
insilmaril@340
   905
	\item Create URL to Bugzilla
insilmaril@340
   906
\end{itemize}
insilmaril@340
   907
The URL will be build from the number in the heading.
insilmaril@340
   908
insilmaril@493
   909
\subsection{Associating images with a branch} \label{incimg}
insilmaril@486
   910
The default setting for an image is for it to float "freely". Images can be
insilmaril@486
   911
positioned anywhere on the canvas, but may end up in the same place as other
insilmaril@486
   912
parts of the map obscuring that part of the map.
insilmaril@340
   913
insilmaril@486
   914
The solution is to insert or include them "into" a branch. This can be done via
insilmaril@493
   915
the property window (see \ref{propwindow}):
insilmaril@340
   916
\begin{itemize}
insilmaril@340
   917
	\item Include images horizontally
insilmaril@340
   918
	\item Include images vertically
insilmaril@340
   919
\end{itemize}
insilmaril@486
   920
The image is still positioned relative to its parent branch, but the
insilmaril@486
   921
heading and border of the branch frame adapt to the floating image, see below: 
insilmaril@509
   922
	\maximage{images/includeImages.png}
insilmaril@340
   923
insilmaril@125
   924
\subsection{Modifier Modes} 
insilmaril@486
   925
Modifiers are for example the \key{Shift}- the \key{Ctrl}- ot the \key{Alt}-keys. When
insilmaril@486
   926
pressed while applying mouse actions, they will cause \vym to use
insilmaril@493
   927
a "modified" version of the action which usually would be done. 
insilmaril@493
   928
insilmaril@493
   929
%\key{Ctrl} or \key{Alt}is pressed while releasing the branch, it will be
insilmaril@493
   930
%added above/below the target, not as child of the target.
insilmaril@125
   931
insilmaril@486
   932
Without a modifier key pressed, the first mouse click on a branch just selects
insilmaril@125
   933
it. For the behaviour of the \key{Ctrl} modifier there are several
insilmaril@125
   934
options, which can be set from the modifier toolbar:
insilmaril@125
   935
\begin{center}
insilmaril@450
   936
	\includegraphics[width=3cm]{images/modmodes.png}
insilmaril@125
   937
\end{center}
insilmaril@493
   938
The default mode is to copy the colour from the clicked branch to the already
insilmaril@493
   939
selected branch. The figure above shows the toolbar with the default modifier 
insilmaril@493
   940
selected. The second modifier
insilmaril@125
   941
let's you easily copy a whole branch with a single click. The third
insilmaril@493
   942
modifier lets you create links between branches called {\em xLinks}.
insilmaril@493
   943
They will be explained in the next section \ref{xlinks}.
insilmaril@125
   944
insilmaril@493
   945
\subsection{Hide links of unselected objects} \label{hidelink}
insilmaril@264
   946
Sometimes it would be useful to position a branch freely, just like a
insilmaril@486
   947
mainbranch or an image. This is possible for all
insilmaril@264
   948
branches, you can use a mainbranch and hide its connecting link to the
insilmaril@486
   949
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
insilmaril@264
   950
pointing to other maps:
insilmaril@264
   951
\begin{center}
insilmaril@450
   952
	\includegraphics[width=9cm]{images/hiddenlink.png}
insilmaril@264
   953
\end{center}
insilmaril@493
   954
To hide the link between a branch and its parent open the
insilmaril@493
   955
\ref{propwindow} and check "Hide link if object is not selected" on
insilmaril@493
   956
"Link" tab.
insilmaril@264
   957
insilmaril@264
   958
insilmaril@260
   959
\subsection{XLinks} \label{xlinks}
insilmaril@125
   960
So far all the data in the \vym map has been treelike. Using xLinks you
insilmaril@125
   961
can link one branch to any other, just like attaching a rope between two
insilmaril@125
   962
branches in a real tree. This is especially useful in complex maps,
insilmaril@486
   963
where you want to have crossreferences which can not be displayed on the same
insilmaril@486
   964
visible area of the {\em 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:
insilmaril@509
   965
	\maximage{images/xlink.png}
insilmaril@125
   966
Note that a xLink which points to a branch that is not visible (because
insilmaril@486
   967
it is scrolled), is just shown as a little horizontal arrow. In the
insilmaril@125
   968
screenshot above have a look at the \lq Tuesday\rq\ branch.
insilmaril@125
   969
insilmaril@233
   970
\subsubsection*{Create a xLink}
insilmaril@486
   971
Choose the link mode from the modifier toolbar (by clicking the toolbar icon or pressing
insilmaril@125
   972
\key{L}). Select the branch, where the xLink should start. Press the
insilmaril@486
   973
modifier key \key{Ctrl} and then click on the selected branch where the
insilmaril@486
   974
link should start and drag the mouse pointer to the branch where the link is to end. (The link is drawn to follow the mouse pointer). When you release the mouse over a branch the xLink becomes permanent.
insilmaril@125
   975
insilmaril@233
   976
\subsubsection*{Modify or delete a xLink}
insilmaril@493
   977
First select a branch at either end of the xLink. Then open the context
insilmaril@493
   978
menu and select \lq Edit xLink\rq. A submenu contains all the xLinks of
insilmaril@493
   979
the branch (if there are any). They are named like the branches, where
insilmaril@493
   980
they end. Choose one and the xLink dialogue opens, where you can set
insilmaril@493
   981
colour, width and also delete the xLink.
insilmaril@125
   982
insilmaril@233
   983
\subsubsection*{Follow a xLink}
insilmaril@486
   984
In a complex \vym map it sometimes comes in handy to be able to jump to the other end
insilmaril@493
   985
of a xLink. You can do this by opening the context menu of the branch
insilmaril@493
   986
and clicking on \lq Goto xLink\rq and selecting the xLink you want to
insilmaril@493
   987
follow.
insilmaril@125
   988
insilmaril@125
   989
insilmaril@125
   990
insilmaril@233
   991
\subsection{Adding and removing branches}
insilmaril@125
   992
The context menu of a branch shows some more ways to add and delete data
insilmaril@486
   993
e.g. you can delete a branch while keeping its children. The children become
insilmaril@125
   994
linked to the parent of the previously removed branch.
insilmaril@125
   995
Similar branches can be inserted into existing maps. For keyboard
insilmaril@125
   996
shortcuts also have a look at the context menu.
insilmaril@28
   997
insilmaril@233
   998
\subsection{Adding a whole map or a part of a map}
insilmaril@493
   999
Select a branch where you want to add a previously saved map ({\tt
insilmaril@493
  1000
.vym})or a part of a map ({\tt .vyp}) , then open the context menu and
insilmaril@493
  1001
choose {\em Add \ra Add Map (Insert)}. For the import you can choose
insilmaril@493
  1002
between {\em Add Map (Insert)} and {\em Add Map (Replace)}: The imported
insilmaril@493
  1003
data will be added after the selected branch.
insilmaril@105
  1004
insilmaril@105
  1005
\section{\vym on Mac OS X}
insilmaril@105
  1006
\subsection{Overview}
insilmaril@105
  1007
Basically there are two ways to run \vym on Macs:
insilmaril@233
  1008
\subsubsection*{QT Mac Edition:}
insilmaril@105
  1009
	\vym here provides the well known Mac look and feel.  \vym is
insilmaril@105
  1010
	available as zipped Mac OS X application. It has been compiled and
insilmaril@509
  1011
	tested in Mac~OS~10.4. It is using the Mac version of Trolltechs QT library.  
insilmaril@233
  1012
\subsubsection*{X11}
insilmaril@105
  1013
	\vym can also be run using the Linux version, but then menus and
insilmaril@105
  1014
	handling will also be those of the Linux version e.g. The menu bar
insilmaril@105
  1015
	will look different. 
insilmaril@105
  1016
insilmaril@125
  1017
\subsection	{Contextmenu and special keys}
insilmaril@125
  1018
Most Macs unfortunatly just have a single mouse button. In order to show
insilmaril@125
  1019
the context menu which usually would be opened with the right mouse
insilmaril@125
  1020
button, you can click while pressing the \key{kommand}-key.
insilmaril@125
  1021
insilmaril@125
  1022
Especially on Laptops some of the keys usually used on PC keyboards seem
insilmaril@125
  1023
to be missing. The QT-Mac Edition of \vym has its own keyboard
insilmaril@125
  1024
shortcuts. To find the shortcuts just have a look at all the menu
insilmaril@125
  1025
entries, the shortcut is visible next to an entry. Toolbar buttons also
insilmaril@125
  1026
may have shortcuts, just position the mouse pointer over a button and
insilmaril@125
  1027
wait for the little help window to appear. 
insilmaril@125
  1028
insilmaril@125
  1029
\subsection {Viewing external links}
insilmaril@125
  1030
\vym on Mac uses the system call {\tt /usr/bin/open} to view links.
insilmaril@125
  1031
Mac~OS determines automatically if the link is a pdf or www page and
insilmaril@125
  1032
opens the right browser.
insilmaril@125
  1033
insilmaril@233
  1034
insilmaril@233
  1035
\begin{appendix}
insilmaril@233
  1036
insilmaril@486
  1037
\section{\vym initialisation process and configuration}
insilmaril@420
  1038
\subsection{Configuration file}
insilmaril@420
  1039
On startup \vym will look for a configuration for user specific settings
insilmaril@420
  1040
like window positions, toolbars etc. If this file does not already
insilmaril@420
  1041
exist, it will be created. The file is located in the users home
insilmaril@420
  1042
directory. The exact position depends on the platform:
insilmaril@420
  1043
\begin{center}
insilmaril@420
  1044
\begin{tabular}{cl}
insilmaril@420
  1045
	{\bf Platform}	& {\bf Configuration file} \\ \hline
insilmaril@420
  1046
	Linux		& {\tt $\sim$/.config/InSilmaril/vym.conf  } \\
insilmaril@420
  1047
	Mac OS X	& {\tt /Users/NAME/Library/Preferences/com.insilmaril.vym.plist  } \\
insilmaril@420
  1048
\end{tabular}
insilmaril@420
  1049
\end{center}
insilmaril@420
  1050
The file can be edited manually, or on Mac~OS~X with Property List
insilmaril@420
  1051
Editor (installed with xtools).
insilmaril@420
  1052
insilmaril@291
  1053
\subsection{Path to ressources}
insilmaril@291
  1054
\vym will try to find its ressources (images, stylesheets, filters,
insilmaril@291
  1055
etc.) in the following places:
insilmaril@291
  1056
\begin{enumerate}
insilmaril@291
  1057
	\item Path given by the environment variable {\tt VYMHOME}.
insilmaril@291
  1058
	\item If called with the local option (see \ref{options} below),
insilmaril@291
  1059
	      \vym will look for its data in the current directory.
insilmaril@291
  1060
	\item {\tt /usr/share/vym}
insilmaril@291
  1061
	\item {\tt /usr/local/share/vym}
insilmaril@291
  1062
\end{enumerate}
insilmaril@291
  1063
insilmaril@291
  1064
\subsection{Command line options} \label{options}
insilmaril@264
  1065
\vym has the following options:
insilmaril@264
  1066
\begin{center}
insilmaril@450
  1067
\begin{tabular}{cccp{8cm}}\\ 
insilmaril@450
  1068
\bf Option	& \bf Comment & \bf Argument & \bf Description \\ \hline
insilmaril@493
  1069
v & version &			& Show version and codename of \vym\\
insilmaril@450
  1070
l & local	&			& Use local paths to stylesheets, translations, icons, 
insilmaril@450
  1071
                          etc. instead of system paths. Useful for testing\\
insilmaril@486
  1072
h & help	&			& Show help\\
insilmaril@486
  1073
r & run 	& filename	& Run script\\
insilmaril@479
  1074
q & quit	&			& Quit immediatly after startup. Useful for benchmarks.\\
insilmaril@264
  1075
\end{tabular}
insilmaril@264
  1076
\end{center}
insilmaril@264
  1077
You can also give several filenames at the commandline to let \vym open
insilmaril@264
  1078
several maps at once.
insilmaril@264
  1079
 
insilmaril@450
  1080
insilmaril@486
  1081
 \section{Scripts} \label{scripts}
insilmaril@486
  1082
 %FIXME
insilmaril@450
  1083
insilmaril@450
  1084
insilmaril@450
  1085
insilmaril@450
  1086
insilmaril@450
  1087
insilmaril@233
  1088
\section{Contributing to \vym}
insilmaril@260
  1089
So far I'd say I have written 98\% of the code on my own. No surprise,
insilmaril@260
  1090
that \vym exactly fits my own needs. Nevertheless I would like to
insilmaril@260
  1091
encourage all users of  \vym to contribute. Maybe not only with feature
insilmaril@260
  1092
requests, but also with code, new import/export filters, translations
insilmaril@260
  1093
etc. In this appendix I'll try to show how easy it is to expand the
insilmaril@260
  1094
things you can do already with \vym. I really look forward to hear from
insilmaril@260
  1095
you!
insilmaril@233
  1096
insilmaril@233
  1097
\subsection{Getting help}
insilmaril@233
  1098
insilmaril@233
  1099
\subsubsection*{Frequently asked questions}
insilmaril@233
  1100
Please refer to the FAQ available on the \vym website:
insilmaril@125
  1101
\begin{center}
insilmaril@125
  1102
\href{http://www.InSilmaril.de/vym/faq.html}{http://www.InSilmaril.de/vym/faq.html}
insilmaril@125
  1103
\end{center}
insilmaril@105
  1104
insilmaril@233
  1105
\subsubsection*{Mailinglists}
insilmaril@233
  1106
There are two mailinglists: {\tt vym-forum} is the \vym users forum to
insilmaril@233
  1107
discuss various questions, while {\tt vym-devel} is intended for people
insilmaril@233
  1108
interested in contributing to \vym. You can view the archives and
insilmaril@233
  1109
subscribe at
insilmaril@233
  1110
\begin{center}
insilmaril@233
  1111
\href{https://sourceforge.net/mail/?group_id=127802}{https://sourceforge.net/mail/?group\_id=127802}
insilmaril@233
  1112
\end{center}
insilmaril@233
  1113
insilmaril@264
  1114
\subsubsection*{Contacting the author}\label{author}
insilmaril@233
  1115
Especially for support questions please try the mailinglists first. If
insilmaril@486
  1116
everything else fails you can contact the author Uwe Drechsel at
insilmaril@233
  1117
\begin{center}
insilmaril@260
  1118
\href{mailto:vym@InSilmaril.de}{vym@InSilmaril.de}
insilmaril@233
  1119
\end{center}
insilmaril@233
  1120
insilmaril@233
  1121
insilmaril@264
  1122
insilmaril@264
  1123
\subsection{How to report bugs}
insilmaril@264
  1124
Though Sourceforge has its own bugreporting system, I'd rather prefer if
insilmaril@264
  1125
you contact me directly (see \ref{author}) or even better: You can file
insilmaril@264
  1126
a bugreport in Bugzilla, the bugtracking system of openSUSE:
insilmaril@264
  1127
\begin{center}
insilmaril@264
  1128
\href{http://en.opensuse.org/Submit_a_bug}{http://en.opensuse.org/Submit\_a\_bug}
insilmaril@264
  1129
\end{center}
insilmaril@264
  1130
I build \vym regulary for openSUSE, so you may report it against a
insilmaril@264
  1131
recent version there, even if you  use another Operating System.
insilmaril@486
  1132
Please don't forget to tell me what you are using:
insilmaril@264
  1133
\begin{itemize}
insilmaril@264
  1134
	\item the exact steps needed to reproduce the bug
insilmaril@264
  1135
	\item the version and build date of \vym (see the Help \ra About
insilmaril@264
  1136
	\vym)
insilmaril@264
  1137
	\item hardware and Operating System
insilmaril@264
  1138
\end{itemize}
insilmaril@264
  1139
insilmaril@233
  1140
\subsection{Compiling from the sources}
insilmaril@252
  1141
\subsubsection{Getting the sources} \label{getsources}
insilmaril@252
  1142
You find the latest version of \vym at the project site:
insilmaril@252
  1143
\begin{center}
insilmaril@252
  1144
\href{https://sourceforge.net/projects/vym/}{https://sourceforge.net/projects/vym/}
insilmaril@252
  1145
\end{center}
insilmaril@252
  1146
There you can check them out of the source repository (CVS):\\
insilmaril@233
  1147
insilmaril@252
  1148
\begin{verbatim}
insilmaril@252
  1149
cvs -d:pserver:anonymous@cvs.sf.net:/cvsroot/vym checkout code
insilmaril@252
  1150
\end{verbatim}
insilmaril@252
  1151
insilmaril@252
  1152
\subsubsection{The Qt toolkit}
insilmaril@233
  1153
Qt is C++ toolkit for multiplatform GUI and application development. It
insilmaril@233
  1154
provides single-source portability across MS~Windows, Mac~OS~X, Linux
insilmaril@486
  1155
and all major commercial Unix variants. Qt is also available for
insilmaril@252
  1156
embedded devices. Qt is a Trolltech product. For more information see 
insilmaril@252
  1157
\begin{center}
insilmaril@233
  1158
\href{http://www.trolltech.com/qt/}{www.trolltech.com/qt} 
insilmaril@252
  1159
\end{center}
insilmaril@233
  1160
insilmaril@233
  1161
insilmaril@252
  1162
\subsubsection{Compiling \vym }
insilmaril@233
  1163
Make sure you have installed your Qt environment properly, see the Qt
insilmaril@233
  1164
documentation for details. You need to have the Qt command {\tt qmake}
insilmaril@233
  1165
in your {\tt PATH}-environment, then run
insilmaril@233
  1166
\begin{verbatim}
insilmaril@233
  1167
qmake
insilmaril@233
  1168
make  
insilmaril@233
  1169
make install
insilmaril@233
  1170
\end{verbatim}
insilmaril@233
  1171
The last command {\tt make install} needs root-permissions. Of course it
insilmaril@233
  1172
may be omitted, if you just want to test \vym.
insilmaril@233
  1173
insilmaril@260
  1174
%\subsubsection*{Compiling \vym on Macs}
insilmaril@450
  1175
%FIXME
insilmaril@233
  1176
insilmaril@233
  1177
\subsection{\vym file format} \label{fileformat}
insilmaril@486
  1178
\vym maps usually have the suffix "{\tt .vym}" and represent a
insilmaril@233
  1179
compressed archive of data. If you want to have a
insilmaril@233
  1180
closer look into the data structure map called "mapname.vym", 
insilmaril@233
  1181
just uncompress the map manually using
insilmaril@233
  1182
\begin{verbatim}
insilmaril@233
  1183
	unzip mapname.vym
insilmaril@233
  1184
\end{verbatim}
insilmaril@233
  1185
This will create directories named {\tt images} and {\tt flags} in your
insilmaril@233
  1186
current directory and also the map itself, usually named {\tt
insilmaril@233
  1187
mapname.xml}.
insilmaril@233
  1188
The XML structure of \vym is pretty self explaining, just have a look at
insilmaril@233
  1189
{\tt mapname.xml}.
insilmaril@233
  1190
insilmaril@233
  1191
This XML file can be loaded directly into \vym, it does not have to be
insilmaril@233
  1192
compressed. If you want to compress all the data yourself, use
insilmaril@233
  1193
\begin{verbatim}
insilmaril@233
  1194
	zip -r mapname.vym .
insilmaril@233
  1195
\end{verbatim}
insilmaril@233
  1196
to compress all data in your current directory.
insilmaril@233
  1197
insilmaril@233
  1198
\subsection{New features}
insilmaril@28
  1199
There are lots of features which might find their way into \vym.
insilmaril@233
  1200
Together with \vym you should have received a directory with several
insilmaril@28
  1201
maps e.g. on SUSE~LINUX this is
insilmaril@28
  1202
\begin{center}
insilmaril@28
  1203
	{\tt /usr/share/doc/packages/vym/demos}
insilmaril@28
  1204
\end{center}
insilmaril@28
  1205
where you find the map {\tt todo.vym}. It lists quite a lot of things to
insilmaril@233
  1206
be done in future. If you have more ideas, contact the development team
insilmaril@233
  1207
at
insilmaril@233
  1208
{\tt vym-devel@lists.sourceforge.net}.
insilmaril@28
  1209
insilmaril@28
  1210
insilmaril@233
  1211
\subsection{New languages support}
insilmaril@252
  1212
In order to add a new language to \vym you need 
insilmaril@252
  1213
the sources (see \ref{getsources}) and
insilmaril@252
  1214
an installation of Trolltechs QT. A part of QT are the development
insilmaril@252
  1215
tools, from those tools especially the translation tool "Linguist" is
insilmaril@252
  1216
needed. 
insilmaril@252
  1217
insilmaril@252
  1218
In some Linux distributions the development tools are in an extra package, e.g. on SUSE LINUX you should have installed:
insilmaril@252
  1219
\begin{verbatim}
insilmaril@252
  1220
    qt3-devel.rpm
insilmaril@252
  1221
    qt3-devel-doc.rpm
insilmaril@252
  1222
    qt3-devel-tools.rpm
insilmaril@252
  1223
    qt3-man.rpm
insilmaril@252
  1224
\end{verbatim}
insilmaril@252
  1225
If you don't have QT in your system, you can get it from 
insilmaril@252
  1226
	\href{http://www.trolltech.com}{http://www.trolltech.com} Once you
insilmaril@252
  1227
	are able to compile vym yourself, you can translate the text in vym
insilmaril@252
  1228
	itself by performing the following steps:
insilmaril@252
  1229
\begin{itemize}
insilmaril@252
  1230
	\item Let's assume now your encoding is "NEW" instead of for example
insilmaril@252
  1231
	"de" for german or "en" for english
insilmaril@252
  1232
	
insilmaril@252
  1233
	\item Copy the file {\tt lang/vym\_en.ts} to l{\tt ang/vym\_NEW.ts} (The code
insilmaril@252
  1234
	itself contains the english version.)
insilmaril@252
  1235
		
insilmaril@252
  1236
	\item Add {\tt lang/vym\_NEW.ts} to the TRANSLATIONS section of vym.pro
insilmaril@252
  1237
insilmaril@252
  1238
	\item Run Linguist on {\tt vym\_NEW.ts} and do the translation
insilmaril@252
  1239
insilmaril@252
  1240
	\item Run {\tt lrelease} to create {\tt vym\_NEW.qm}
insilmaril@252
  1241
insilmaril@252
  1242
	\item Do a make install to install the new vym and check your translation
insilmaril@252
  1243
\end{itemize}
insilmaril@252
  1244
insilmaril@252
  1245
If you feel brave, you can also translate the manual. It is written in
insilmaril@252
  1246
LaTeX, you just have to change the file tex/vym.tex. (Linguist and QT
insilmaril@252
  1247
are not needed, but it is useful to know how to work with LaTeX and esp.
insilmaril@252
  1248
pdflatex to create the PDF.) 
insilmaril@252
  1249
insilmaril@252
  1250
Please mail me every translation you have done. I can also give you a
insilmaril@252
  1251
developer access to the project, if you want to provide translations
insilmaril@252
  1252
regulary.  
insilmaril@252
  1253
insilmaril@233
  1254
\subsection{New export/import filters}
insilmaril@252
  1255
\vym supports various kinds of filters. Data can be written directly,
insilmaril@252
  1256
inserted into templates or it can be written as XML data and then
insilmaril@252
  1257
processed by XSL transformations. 
insilmaril@252
  1258
insilmaril@252
  1259
Most of the import/export functionality is available in the classes
insilmaril@252
  1260
ImportBase and ExportBase and subclasses. All of them can be found in
insilmaril@252
  1261
{\tt imports.h} and {\tt exports.h}.
insilmaril@252
  1262
insilmaril@264
  1263
\subsubsection*{Direct import/export}
insilmaril@252
  1264
An example for a direct export is the XML export. This method touches
insilmaril@252
  1265
the implementation of nearly every object of \vym, so whenever possible
insilmaril@264
  1266
you should better use a XSL transformation instead.
insilmaril@252
  1267
insilmaril@252
  1268
If you still want to know how it is done, start looking at 
insilmaril@252
  1269
{\tt MapEditor::saveToDir} in {\tt mapeditor.cpp}.
insilmaril@252
  1270
insilmaril@264
  1271
\subsubsection*{Templates}
insilmaril@264
  1272
Templates have been introduced to export to opendoc format used e.g. by
insilmaril@264
  1273
Open~Office. While I read the spec ($>$ 500 pages) about the format\footnote{
insilmaril@264
  1274
\href{http://www.oasis-open.org/}{http://www.oasis-open.org/}}\ 
insilmaril@264
  1275
I had the feeling that I did not want to write the export from scratch. 
insilmaril@264
  1276
It would be too complex to adapt the styles to your own wishes, e.g. the
insilmaril@264
  1277
layout.
insilmaril@252
  1278
insilmaril@264
  1279
Instead I analyzed existing Open~Office documents. I found out that
insilmaril@264
  1280
there are lots of redundant bits of information in a standard
insilmaril@264
  1281
presentation, for example each list item is contained in its own list.
insilmaril@264
  1282
In the end I came up with the default presentation style, which still
insilmaril@264
  1283
could be simplified, just in case you have free time\ldots
insilmaril@252
  1284
insilmaril@486
  1285
The existing templates are still work in progress, before you spend too
insilmaril@264
  1286
much time developing your own style, please contact me.  Basically the
insilmaril@264
  1287
following steps are needed to build your own style:
insilmaril@264
  1288
\begin{enumerate}
insilmaril@264
  1289
	\item Create an example in Open Office. Use a title, authors name,
insilmaril@264
  1290
	page heading etc.\ which you can easily grep for in the output file.
insilmaril@264
  1291
	
insilmaril@264
  1292
	\item Unzip  the Open Office document into a directory.
insilmaril@264
  1293
insilmaril@264
  1294
	\item The main file is called {\tt content.xml}. All data is in one
insilmaril@264
  1295
	single line. You can split the XML tags using the script {\tt
insilmaril@264
  1296
	scripts/niceXML}, which is part of the \vym distribution.
insilmaril@264
  1297
insilmaril@264
  1298
	\item Copy the output of {\tt niceXML} to {\tt
insilmaril@264
  1299
	content-template.xml}.
insilmaril@264
  1300
insilmaril@264
  1301
	\item Looking closer you will find lots of unused definitions, for
insilmaril@264
  1302
	example of styles. You can delete or simply ignore them.
insilmaril@264
  1303
insilmaril@264
  1304
	\item Try to find your title, authors name. \vym will replace the
insilmaril@264
  1305
	following strings while exporting:
insilmaril@264
  1306
	\begin{center}
insilmaril@264
  1307
	\begin{tabular}{lp{4cm}}
insilmaril@264
  1308
		{\tt <!-- INSERT TITLE -->}		& title of map \\
insilmaril@264
  1309
		{\tt <!-- INSERT AUTHOR-->	}	& author \\
insilmaril@264
  1310
		{\tt <!-- INSERT COMMENT -->}	& comment \\
insilmaril@264
  1311
		{\tt <!-- INSERT PAGES-->}		& content of map \\
insilmaril@264
  1312
	\end{tabular}
insilmaril@264
  1313
	\end{center}
insilmaril@264
  1314
	The content itself is generated in a similar way by inserting lists
insilmaril@264
  1315
	into {\tt page-template}. Here the following substitutions are made:
insilmaril@264
  1316
	\begin{center}
insilmaril@264
  1317
	\begin{tabular}{lp{7cm}}
insilmaril@264
  1318
		{\tt <!-- INSERT PAGE HEADING-->}		& heading of a page
insilmaril@264
  1319
		(mainbranch or child of mainbranch, depending on the use of
insilmaril@264
  1320
		sections) \\
insilmaril@264
  1321
		{\tt <!-- INSERT LIST -->	}	& all childs of the branch above \\
insilmaril@264
  1322
	\end{tabular}
insilmaril@264
  1323
	\end{center}
insilmaril@264
  1324
\end{enumerate}
insilmaril@264
  1325
Currently images are exported and notes just will appear as text
insilmaril@486
  1326
without formatting and colours.
insilmaril@264
  1327
insilmaril@264
  1328
insilmaril@264
  1329
insilmaril@264
  1330
insilmaril@264
  1331
\subsubsection*{XSL Transformation}
insilmaril@264
  1332
\vym uses XSL transformations while exporting (e.g. XHTML) and importing
insilmaril@264
  1333
data (e.g. KDE bookmarks). There is a little code needed to provide the
insilmaril@264
  1334
GUI, the rest is done using the {\tt .xsl} stylesheet and calling the
insilmaril@264
  1335
{\tt xsltproc} processor, which is part of libxslt, the XSLT
insilmaril@264
  1336
C  library  for  GNOME. 
insilmaril@233
  1337
insilmaril@233
  1338
\end{appendix}
insilmaril@233
  1339
\end{document}
insilmaril@28
  1340
insilmaril@125
  1341
%TODO
insilmaril@125
  1342
%\subsubsection{Menus}
insilmaril@125
  1343
%\subsubsection{Keyboard shortcuts}
insilmaril@125
  1344
%Where does vym save its settings? -> ~/.qt/vymrc
insilmaril@125
  1345
insilmaril@28
  1346
insilmaril@28
  1347
% INDEX
insilmaril@28
  1348
% mapeditor
insilmaril@28
  1349
% noteditor
insilmaril@28
  1350
% branch
insilmaril@28
  1351
% mapcenter
insilmaril@28
  1352
% heading
insilmaril@28
  1353
% flag
insilmaril@28
  1354
% orientation 
insilmaril@28
  1355
% zoom
insilmaril@28
  1356
% orientation
insilmaril@28
  1357
% Toolbar
insilmaril@28
  1358
% Zoom
insilmaril@28
  1359
% Find
insilmaril@28
  1360
% statusbar
insilmaril@28
  1361
% link
insilmaril@28
  1362
% mainbranch
insilmaril@28
  1363
% subtree
insilmaril@28
  1364
% reorder
insilmaril@28
  1365
% scroll
insilmaril@28
  1366
% fold
insilmaril@104
  1367
% vymlink
insilmaril@104
  1368
% xlink
insilmaril@125
  1369
% modMode
insilmaril@104
  1370
% context menu
insilmaril@104
  1371
% Mac OS X
insilmaril@28
  1372
insilmaril@28
  1373
insilmaril@28
  1374
insilmaril@125
  1375
\end{document}