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