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