]> git.donarmstrong.com Git - xournal.git/blobdiff - html-doc/manual.html
Release 0.4.5
[xournal.git] / html-doc / manual.html
index e1036cb86e2378594d171e24543fd3ac894a981b..ab24d511c3c31d770a688fbd1013f0eaad46815a 100644 (file)
@@ -24,7 +24,7 @@
   Xournal User's Manual
 </h2>
 <p style="font-size: 0.95em; text-align: center; color: rgb(0,0,0)">
- Version 0.2.1
+ Version 0.4.5
 </p>
 <hr />
 <p>
 </p>
 <p>
 Xournal can be downloaded at
-<a href="http://math.mit.edu/~auroux/software/xournal/">http://math.mit.edu/~auroux/software/xournal/</a>
+<a href="http://xournal.sourceforge.net/">http://xournal.sourceforge.net/</a> or 
+<a href="http://math.berkeley.edu/~auroux/software/xournal/">http://math.berkeley.edu/~auroux/software/xournal/</a>
 </p>
 <p>
  Xournal aims to provide superior graphical quality (subpixel resolution) and overall
- functionality; however it lacks the collaborative features of Jarnal.
- Since Xournal is still in its early development stages, it may not
- be fully stable, and some features have not been implemented yet.
+ functionality; however various advanced features have not been implemented
+ yet.
 </p>
 <h2 class="subtitle">Table of contents</h2>
 <p>
@@ -53,6 +53,7 @@ Xournal can be downloaded at
   <li> <a href="manual.html#tools">The drawing and selection tools</a> </li>
   <li> <a href="manual.html#pages-layers">Pages, layers, and backgrounds</a> </li>
   <li> <a href="manual.html#printing">Printing</a> </li>
+  <li> <a href="manual.html#configuration">Configuration file</a> </li>
   <li> <a href="manual.html#author">Author information, license, bug-reports</a> </li>
   <li> <a href="manual.html#changelog">Version history</a> </li>
   <li> <a href="manual.html#file-format">The file format</a> </li>
@@ -77,7 +78,7 @@ Xournal can be downloaded at
  </a>
 </p>
 <p>
-Refer the next few sections of this manual for more information about
+Refer to the next few sections of this manual for more information about
 the various functionalities.
 </p>
 <hr />
@@ -93,12 +94,10 @@ the Pen Options submenu of the Tools menu).
 </p>
 <h3 class="subsub"><img src="pixmaps/eraser.png"> The eraser</h3>
 <p>
-The eraser lets you erase what you have drawn. If your tablet's stylus
-has an eraser tip, and if the XInput extensions are enabled, the eraser
-will be automatically selected when drawing with the eraser tip.
-Another possibility is to enable the "Emulate Eraser" option in the Options
-menu, which lets you use button 2 or 3 on the stylus (mouse middle or right button)
-as an eraser.<br />
+The eraser lets you erase what you have drawn. 
+By default, stylus buttons 2 and 3 (mouse middle or right buttons) are
+mapped to the eraser tool.
+<br />
 The eraser comes in three different thicknesses (selected using the
 <a href="manual.html#thicknesses">thickness</a> toolbar buttons),
 and can operate in three different modes (Eraser Options submenu of
@@ -127,6 +126,28 @@ the Tools menu):
   is yellow) and thicknesses. Use the color and thickness toolbar buttons
   to change these settings.
 </p>
+<h3 class="subsub"><img src="pixmaps/text-tool.png"> The text tool</h3>
+<p>
+  To insert a new text item, click at the location where the text is to be
+  inserted on the page, then type it in or paste it using the contextual
+  menu (note: no wrapping is performed). To modify a text item, click inside
+  it. The font and point size can be modified using the "Text Font" command
+  in the Tools menu (or the toolbar button). The color is the same as that
+  currently selected for the pen (and can be modified using the toolbar
+  buttons).
+</p>
+<p>
+  Text items can contain arbitrary Unicode characters, provided that a
+  suitable font is installed on your system. However, languages written
+  in a direction other than left-to-right might not be handled properly.
+  If a journal contains some items in a font that is unavailable on your
+  system, another one will be substituted. (Also, text items will be
+  lost if the document is opened in a version of Xournal prior to 0.4).
+  Finally, note that the printing and PDF export features only accept
+  TrueType and Type 1 scalable fonts (do not use any bitmap fonts), and
+  that the typesetting of the text may be slightly different in the
+  printout.
+</p>
 <h3 class="subsub"><img src="pixmaps/ruler.png"> The ruler</h3>
 <p>
   The ruler is not a tool by itself, but rather a special operating mode
@@ -134,17 +155,44 @@ the Tools menu):
   line segments instead of curvy strokes. For simplicity, selecting the
   ruler when not in pen or highlighter mode automatically selects the pen.
 </p>
+<a name="recognizer"></a>
+<h3 class="subsub"><img src="pixmaps/shapes.png"> The shape recognizer</h3>
+<p>
+  The shape recognizer is also a special 
+  operating mode of the pen and highlighter tools. When it is enabled,
+  Xournal attempts to recognize geometric shapes as they are drawn, and
+  if successful will replace the drawn strokes accordingly. The shapes
+  that can be recognized are: line segments, circles, rectangles, arrows,
+  triangles and quadrilaterals. Polygonal shapes can be drawn in a single
+  stroke or in a sequence of consecutive strokes.
+</p>
+<p>
+  The recognizer is set to be as unobtrusive as possible, and should not
+  interfere too much with handwriting. (It differs in this and other ways
+  from another shape recognizer written for Xournal by Lukasz Kaiser).
+  As a result, it may only recognize shapes if you draw them carefully and
+  deliberately. Specific tips for better recognition: (1) for circles,
+  a closed curve that isn't quite round works better
+  than a rounder curve that doesn't close; (2) for arrows, it is better
+  to lift the pen before drawing the tip of the arrow, and make sure
+  the tip consists of two straight line segments;
+  (3) for very elongated rectangles,
+  recognition tends to be better if you lift the pen between consecutive
+  sides.
+</p>
 <h3 class="subsub"><img src="pixmaps/recycled.png"> Default tools</h3>
 <p>
-  Each drawing tool (pen, eraser, highlighter) has a default setting
-  (color, thickness, ...) associated to it.
-  The "Default Pen", "Default Eraser", and "Default Highlighter" entries of
+  Each tool (pen, eraser, highlighter, text) has a default setting
+  (color, thickness, ... for the drawing tools, font and size for the
+  text tool) associated to it.
+  The "Default Pen", "Default Eraser", "Default Highlighter", and
+  "Default Text" entries of
   the Tools menu select the appropriate tool and reset its settings to
   the defaults. The toolbar also includes a "Default" button which
-  resets the currently selected drawing tool to its default settings,
+  resets the currently selected tool to its default settings,
   and a "Default Pen" button. <br />
   The "Set As Default" entry of the Tools menu takes the current settings
-  of the currently selected drawing tool and makes them the new default.
+  of the currently selected tool and makes them the new default.
 </p>
 <a name="thicknesses"></a>
 <h3 class="subsub"><img src="pixmaps/thin.png"> <img src="pixmaps/medium.png">
@@ -160,7 +208,9 @@ the Tools menu):
   All the strokes which are entirely contained within the rectangular region
   are selected.
   The selection can be moved within its page by clicking inside the
-  selection rectangle and dragging the cursor.
+  selection rectangle and dragging the cursor. If the cursor is dragged
+  to a different page, the selection will be moved to the topmost layer of
+  that page.
 </p>
 <p>
   The selection can be cut, duplicated, etc. (including to a different page
@@ -182,6 +232,19 @@ the Tools menu):
   space, or change the page height to an appropriate value (using the
   "Paper Size" entry in the Journal menu).
 </p>
+<p>
+  If you drag the cursor below the bottom of the page (so that the
+  entire block being moved has become invisible), the items will be moved
+  to the next page (topmost layer); however, any items that were already
+  present on the next page are left unchanged. Similarly, dragging the
+  cursor above the top of the page so that the entire block being moved
+  becomes invisible results in the items being moved to the previous page.
+</p>
+<h3 class="subsub"><img src="pixmaps/hand.png"> Hand tool</h3>
+<p>
+  This tool lets you browse the journal; dragging the cursor scrolls the
+  view.
+</p>
 <h3 class="subsub">Undo and redo</h3>
 <p>
   All operations performed on the currently open journal (drawing, erasing,
@@ -190,6 +253,41 @@ the Tools menu):
   the corresponding entries in the Edit menu.<br />
   There is no limit to the depth of the undo/redo stack. It is cleared only
   when you quit the application or open a new journal.
+</p>
+<a name="mappings"></a>
+<h3 class="subsub">Button mappings</h3>
+<p>
+  Stylus buttons 2 and 3 (mouse middle and right buttons) can be mapped
+  to different tools using the appropriate submenus in the Options menu
+  (whereas the Tools menu and the toolbar buttons affect the primary tool
+  assigned to button 1). The default mapping is the eraser.
+</p>
+<p><b>Advanced configuration:</b>
+  if a secondary button is mapped to a drawing tool (pen, eraser, or
+  highlighter), the default is to "dynamically link" its settings to those
+  of the primary tool, which means that each drawing tool has common
+  settings (color, thickness, etc.) for all buttons.
+  Dynamic linking of brush settings
+  can be disabled by selecting the "Copy of current brush" option in the
+  "Button mapping" submenu. The settings of the tool for button 2 or 3 are
+  copied from the button 1 settings at the time when you select the option,
+  and afterwards they are no longer updated when the button 1 settings are
+  modified, thus making it possible to assign pens of different colors or
+  thicknesses to different buttons.
+</p>
+<p>
+  Another option that affects button mappings is the "Eraser tip" option.
+  If this option is turned on and the XInput extensions are enabled, then
+  the eraser tip of your tablet's stylus will automatically be remapped to
+  the eraser tool. This behavior, which overrides all other button mappings,
+  is most useful if your X server is configured to map the eraser tip of
+  your tablet's stylus to button 1.
+</p>
+<p>
+  Also note the "Buttons switch mappings" option, which may be useful to
+  users of external tablets: when this option is turned on, buttons 2 and 3
+  only switch the tool mapping, and drawing is still done with button 1.
+</p>
 <hr />
 <a name="pages-layers"></a>
 <h2 class="subtitle">Pages, layers, and backgrounds</h2>
@@ -295,8 +393,9 @@ resizes the current page according to the size of the bitmap image, and
 resets the zoom level to 100%. If <i>ghostscript</i> is installed on your
 system, you can also use this method to import a fixed-resolution bitmap
 version of a Postscript or PDF file; in that case, all pages will be
-imported sequentially as backgrounds into consecutive pages (this is not the
-recommended method; PDF annotation is better in many respects).
+imported sequentially as backgrounds into consecutive pages (this is
+<i>not</i> the
+recommended method; PDF annotation is better in every respect).
 </p>
 <p>
 To capture a <b>screenshot</b> of a window or the entire screen and make it
@@ -317,29 +416,15 @@ ghostscript) are automatically "attached" to the journal file: when the
 journal is saved, they will be saved (in PNG format) along with it
 (using file names of the form *.xoj.bg_*.png).
 </p>
-<p>
-<b>Rescaling and anti-aliasing:</b> by default,
-bitmap backgrounds are rescaled and anti-aliased as needed when the zoom
-level is changed, to ensure their appearance always remains acceptable.
-Because this consumes a lot of memory and CPU resources, by default this
-rescaling is performed on-demand as each page becomes visible. This means
-that you will occasionally notice bitmap backgrounds being smoothed while
-you are scrolling inside the document (at large zoom levels, this can slow
-down the screen refresh rate noticeably). If you'd prefer all backgrounds to
-be rescaled immediately upon changing the zoom level (slower but maybe more
-intuitive), disable the "Progressive Backgrounds" option in the Options
-menu.<br />
-If you are handling large bitmaps, you can save memory and CPU resources (at the
-expense of quality) by disabling the "Antialiased Bitmaps" option in the Options menu.
-</p>
 
 <a name="pdfannotate"></a>
 <h3 class="subsub">PDF annotation</h3>
 <p>
 Xournal can be used to annotate PDF files, by loading the pages of a PDF
-file as backgrounds for a journal. This feature requires the
-<i>pdftoppm</i> converter to be installed (this is part of the <i>xpdf</i>
-&nbsp;PDF file viewer).
+file as backgrounds for a journal. As of version 0.4.5 this is done using
+the <i>poppler</i> library (previous versions used the
+<i>pdftoppm</i> converter, which is part of the <i>xpdf</i> utilities or
+the <i>poppler</i> utilities depending on distributions).
 </p>
 <p>
 The "Annotate PDF" command in the File menu can be used to load a PDF file
@@ -366,9 +451,10 @@ become visible on the screen (unless you disable the "Progressive
 Backgrounds" option in the Options menu). This means that you will
 occasionally notice the page backgrounds being updated while you are
 scrolling inside the document (at large zoom levels, it can take a while
-for the updated background to appear). However, since the backgrounds are
-generated asynchronously by a separate Unix process, you can keep drawing in the journal
-while the update process is still in progress.
+for the updated background to appear). 
+<!-- However, since the backgrounds are generated asynchronously by a 
+separate Unix process, you can keep drawing in the journal
+while the update process is still in progress. -->
 </p>
 <p>
 It is strongly recommended that you do not resize PDF pages (using the
@@ -384,72 +470,394 @@ possible to include pages from more than one PDF file into a single journal
 document. If you need to annotate two or more PDF files inside a same
 journal document, please consider using an external utility for merging
 PDF files (for example <i>pdfmerge</i>).
+</p>
+<p>
+<b>Note:</b> the PDF backgrounds are
+rescaled and/or regenerated as needed when the zoom level is changed.
+Because this consumes a lot of memory and CPU resources, by default this
+rescaling is performed on-demand as each page becomes visible. This means
+that you will occasionally notice backgrounds being generated while
+you are scrolling inside the document (at large zoom levels, this can slow
+down the screen refresh rate noticeably). If you'd prefer all backgrounds to
+be loaded in advance and rescaled immediately upon changing the zoom level,
+disable the "Progressive Backgrounds" option in the Options menu. Be aware
+that this increases the memory consumption and will cause out-of-memory
+crashes when viewing long documents.
+</p>
+
 <hr />
 <a name="printing"></a>
 <h2 class="subtitle">Printing</h2>
 <p>
-Xournal uses the gnome-print architecture for printing. While it is very
-powerful, some aspects of the API leave to be desired,
-and future versions of Xournal will probably also include a native
-Postscript/PDF printing feature.
+As of version 0.4.5, Xournal uses the gtk-print architecture for printing
+(previous versions used gnome-print). Xournal also includes a native PDF 
+printing feature.
 </p>
+<h3 class="subsub">Printing via gtk-print</h3>
 <p>
-The "Printer" tab of the print dialog box lets you select a printer
-(either one of the printers installed on your system, or the generic
-Postscript printer, or the PDF virtual printer). The "Job" tab lets you
-select a range of pages to print (the default is to print the entire
-journal). The "Paper" tab lets you select the paper size. Each page
+The print dialog box lets you select a printer
+(either one of the printers installed on your system, or the "Print to File"
+virtual printer), and a range of pages to print (the default is to print 
+the entire journal). Each page
 of the journal is automatically rescaled so as to fit the paper size.
-(minus a 5% margin all around).
+</p>
+<p>
+Unlike the older gnome-print architecture, gtk-print and poppler make it
+possible to efficiently print files that annotate PDF backgrounds. (Prior to
+version 0.4.5, PDF backgrounds had to be converted to bitmaps upon printing,
+resulting in huge print jobs and low printout quality).
 </p>
 <p>
 The settings are currently not saved properly from one print job to
-the next, so make sure to select the appropriate printer and verify
-the paper size. When printing to a file (Postscript or PDF), Xournal
-attempts to pre-fill the output file name (for the Postscript driver
-this often fails due to gnome-print API issues).
+the next, so make sure to verify the settings.
 </p>
+<h3 class="subsub">Exporting to PDF</h3>
 <p>
-The "Print to PDF" entry of the File menu directly generates a PDF file
-using the PDF virtual printer, without bringing up the dialog box
-(the page size is the default one for that printer, usually A4). 
-Note that the PDF virtual printer produces files that are very large
-and far from optimal, so in the current state of things it is better
-to generate a Postscript file and use a converter such as ps2pdf.
+Xournal also provides its own PDF rendering
+engine. The "Export to PDF" command (in the File menu) produces a
+PDF-1.4 file from the currently loaded document. The pages of the
+resulting PDF file have the same size as in Xournal. Highlighter strokes
+are rendered in a partially transparent manner (note however that
+applications such as xpdf and ghostview do not always handle
+PDF transparency properly). Text items are rendered by embedding
+TrueType subsets or Type 1 fonts into the PDF document as appropriate.
 </p>
 <p>
-The gnome-print architecture also forces page backgrounds (bitmaps
-and PDF) to be generated as uncompressed bitmaps, which leads to gigantic
-print job files. An alternative to gnome-print will be
-implemented in a future release of Xournal.
+Xournal includes a PDF file parser compatible with PDF format
+version 1.4; the compression features of PDF 1.5 are
+not supported. When exporting a document that uses PDF
+backgrounds, Xournal attempts to preserve most of the structure of
+the original PDF file (however, auxiliary data such as thumbnails, hyperlinks,
+and annotations are lost). If Xournal is unable to parse the PDF
+file, the backgrounds are converted to (compressed) bitmaps and a new
+PDF file is generated from scratch.
+</p>
+<hr />
+<a name="configuration"></a>
+<h2 class="subtitle">Configuration file</h2>
+<p>
+Xournal's configuration settings are saved to the file
+<tt>~user/.xournal/config</tt> by using the "Save
+Preferences" command in the Options menu. The settings saved in the
+configuration file include in particular:
+<ul>
+<li>general display preferences: zoom level, window size, ...</li>
+<li>default paper settings (as set by the "Set As Default" command in
+the Journal menu)</li>
+<li>default settings for the pen, eraser, highlighter, and text tools
+(as set by the "Set As Default" command in the Tools menu)</li>
+<li>mappings for buttons 2 and 3</li>
+<li>the various preferences set in the Options menu</li>
+</ul>
+The configuration file also gives access to additional customization
+options which cannot be set from the user interface, such as: the
+display resolution in pixels per inch, the step increment in zoom factors,
+the tool selected at startup, the thickness of the various drawing tools,
+the default directory for opening and saving files, the visibility and
+position of the menu and toolbars, ...
+</p>
+<p>Here is a partial list of configuration file settings:
+<ul> 
+<li> <p><b>Display settings</b> (in the <tt><b>[general]</b></tt> section): <ul>
+<li><tt><b>display_dpi:</b></tt> 
+the display resolution in pixels per inch</li>
+<li><tt><b>initial_zoom:</b></tt> 
+the initial zoom level, in percent</li>
+<li><tt><b>window_maximize:</b></tt> 
+whether to start with a maximized window</li>
+<li><tt><b>window_fullscreen:</b></tt> 
+whether to start in fullscreen mode</li>
+<li><tt><b>window_width, window_height:</b></tt> 
+the preferred window size (if not maximized)</li>
+<li><tt><b>zoom_step_factor:</b></tt> 
+the (multiplicative) factor by which the zoom in/zoom out buttons change the zoom
+level</li>
+<li><tt><b>view_continuous:</b></tt> 
+whether to start in continuous or single-page view mode (see also View menu)</li>
+<li><tt><b>highlighter_opacity:</b></tt> 
+the opacity level of highlighter strokes (from 0 to 1; 1 is fully opaque).
+Note that .xoj files do not store the opacity level of strokes, so if you
+change from the default value of 0.5 your files will look different when
+opened on another machine.</li>
+</ul></p></li>
+<li> <p><b>User interface settings</b> (in the <tt><b>[general]</b></tt> section): <ul>
+<li><tt><b>autosave_prefs:</b></tt> 
+whether to automatically save preferences upon exiting Xournal.</li>
+<li><tt><b>interface_order:</b></tt> 
+the position of the various toolbars relative to the drawing area, 
+from top to bottom. The default order is: <tt>menu main_toolbar pen_toolbar
+drawarea statusbar</tt>. Switching elements around rearranges the
+interface. Removing elements from the list hides them.</li>
+<li><tt><b>interface_fullscreen:</b></tt> 
+the same thing, but in fullscreen mode. For example, <tt>drawarea main_toolbar
+pen_toolbar</tt> would position the toolbars below the drawing area, and hide
+the menu and status bar.
+interface.</li>
+<li><tt><b>shorten_menus:</b></tt> 
+whether to hide some little-used menu or toolbar items (see also "Shorten
+Menus" in Options menu)</li>
+<li><tt><b>shorten_menu_items:</b></tt> 
+the list of interface items to hide when shorten_menus is enabled. Virtually
+everything in the interface can be hidden. A complete list of interface item ID names
+can be obtained by running the command <tt>grep id= xournal.glade</tt> in
+the base directory of the source code distribution.</li>
+<li><tt><b>default_path:</b></tt> 
+the default path for the open/save dialog boxes (leave blank to use the
+current directory)</li>
+<li><tt><b>autoload_pdf_xoj:</b></tt> 
+whether to load filename.pdf.xoj (if it exists) when the user opens
+filename.pdf (see also "Autoload .pdf.xoj" in Options menu)</li>
+</ul></p></li>
+<li> <p><b>Input device settings</b> (in the <tt><b>[general]</b></tt> section): <ul>
+<li><tt><b>use_xinput:</b></tt> 
+whether to enable XInput extensions for high-resolution tablet input
+(see also "Use XInput" in Options menu)</li>
+<li><tt><b>discard_corepointer:</b></tt> 
+whether to discard Core events when XInput extensions are enabled. Setting
+this to "false" should be safe.</li>
+<li><tt><b>use_erasertip:</b></tt> 
+whether to always map the eraser tip of a stylus to the eraser
+(see also "Eraser Tip" in Options menu)</li>
+<li><tt><b>buttons_switch_mappings:</b></tt> 
+whether to have buttons 2 and 3 switch the tool mapping instead of actually
+drawing (useful with some external tablets; see also "Buttons Switch
+Mappings" in Options menu)</li>
+<li><tt><b>pressure_sensitivity:</b></tt> 
+whether to use stylus pressure to control stroke width (see also "Pressure
+Sensitivity" in Options menu)</li>
+<li><tt><b>width_minimum_multiplier, width_maximum_multiplier:</b></tt> 
+the minimum and maximum width multipliers for pressure-sensitive strokes</li>
+</ul></p></li>
+<li> <p><b>Paper settings</b> (in the <tt><b>[paper]</b></tt> section): <ul>
+<li><tt><b>width, height:</b></tt> 
+the default paper size, in points (1 point = 1/72 in = 0.353 mm)</li>
+<li><tt><b>color:</b></tt> 
+the default paper color (named color or #rrggbbaa)</li>
+<li><tt><b>style:</b></tt> 
+the default paper style (plain, lined, ruled, or graph)</li>
+<li><tt><b>apply_all:</b></tt> 
+whether paper style changes get applied to all pages (see also "Apply to all
+pages" in Journal menu)</li>
+<li><tt><b>print_ruling:</b></tt> 
+whether to include the paper ruling lines when printing
+(see also "Print Paper Ruling" in Options menu)</li>
+<li><tt><b>progressive_bg:</b></tt> 
+whether to generate PDF backgrounds just-in-time as pages become visible
+(rather than immediately upon opening the document or changing the zoom 
+level, which is more memory-intensive); see also "Progressive Backgrounds"
+in Options menu</li>
+<li><tt><b>gs_bitmap_dpi:</b></tt> 
+resolution (in dpi) of bitmap backgrounds generated from PS/PDF files
+when using "Load Background" in Journal menu; higher values mean higher
+quality but larger memory usage</li>
+<li><tt><b>pdftoppm_printing_dpi:</b></tt> 
+resolution (in dpi) of bitmaps generated from PDF backgrounds when exporting
+to PDF (only used if the PDF parser is unable to process the background PDF
+file); higher values mean higher quality but larger output files</li>
+</ul></p></li>
+<li> <p><b>Tool settings</b> (in the <tt><b>[tools]</b></tt> section): <ul>
+<li><tt><b>startup_tool:</b></tt> 
+the tool selected at startup (one of: pen, eraser, highlighter, selectrect,
+vertspace, hand)</li>
+<li><tt><b>pen_color, pen_thickness, pen_ruler, pen_recognizer:</b></tt> 
+the default pen settings: color (a named color or #rrggbbaa), thickness
+(fine = 1, medium = 2, thick = 3), ruler mode, recognizer mode</li>
+<li><tt><b>highlighter_color, highlighter_thickness, highlighter_ruler,
+highlighter_recognizer:</b></tt> 
+the default highlighter settings</li>
+<li><tt><b>eraser_thickness, eraser_mode:</b></tt> 
+the default eraser settings: thickness (fine = 1, medium = 2, thick = 3)
+and operating mode (standard = 0, whiteout = 1, delete strokes = 2)</li>
+<li><tt><b>btn2_tool, btn3_tool:</b></tt> 
+the tools mapped to buttons 2 and 3 (can be: pen, eraser, highlighter, selectrect,
+vertspace, hand)</li>
+<li><tt><b>btn2_linked, btn3_linked:</b></tt> 
+whether the settings of the tools for buttons 2 and 3 are linked to those of
+the corresponding primary tools</li>
+<li><tt><b>btn2_color, btn2_thickness, btn2_ruler, btn2_recognizer,
+btn2_erasermode:</b></tt> 
+if the settings are not linked to the primary tool (<tt>btn2_linked</tt> is
+false), the settings of the tool mapped to button 2. Not all entries are 
+applicable, depending on the value of <tt>btn2_tool</tt>.</li>
+<li><tt><b>btn3_color, btn3_thickness, btn3_ruler, btn3_recognizer,
+btn3_erasermode:</b></tt> 
+similarly for the button 3 tool.</li> 
+<li><tt><b>pen_thicknesses, eraser_thicknesses, highlighter_thicknesses:</b></tt> 
+the widths in points (1 pt = 1/72 in = 0.353 mm) of the various pens
+(5 values from 'very fine' to 'very thick'), erasers (3 values from 'fine'
+to 'thick') and highlighters (3 values from 'fine' to 'thick') </li> 
+<li><tt><b>default_font, default_font_size:</b></tt> 
+the name and point size of the default text font.</li>
+</ul></p></li>
+</ul>
+</p>
 <hr />
 <a name="author"></a>
 <h2 class="subtitle">Author information, license, bug-reports</h2>
 <p>
 Xournal is written by Denis Auroux
-(aur<!--despam-->oux<span>&#x40;</span><span>math</span>&#x2e;<span>mit&#x2e;edu).
-<br />It is distributed under the GNU General Public License.
+(aur<!--despam-->oux<span>&#x40;</span><span>math</span>&#x2e;<span>mit&#x2e;edu,
+aur<!--despam-->oux<span>&#x40;</span><span>math</span>&#x2e;<span>berkeley&#x2e;edu).
+</p>
+<p>
+The source code includes contributions by the following people: 
+Eduardo de Barros Lima, Mathieu Bouchard, Ole J&oslash;rgen Br&oslash;nner,
+Vincenzo Ciancia, Luca de Cicco, Michele Codutti, 
+Robert Gerlach, Lukasz Kaiser, Danny Kukawka, Bob McElrath, 
+Andy Neitzke, David Planella, Alex Ray, Jean-Baptiste Rouquier, 
+Mike Ter Louw, Uwe Winter, Lu Zhihe.
+</p>
+<p style="font-size:0.9em">(Let me know if you are missing from this list or
+if your name is mis-spelled)</p>
+<p>
+Xournal is distributed under the GNU General Public License.
+</p>
+<p style="font-size: 0.9em; font-style: italic">
+ <b>Note:</b> most of the code of version 0.4.2.1 
+ (excluding graphics and a few portions of the code) has also been released
+ under the MIT License. Please contact the main developer if 
+ you need an MIT License version of the 0.4.2.1 code. Later versions are
+ not available under MIT License.
 </p>
 <p>Feel free to contact me with bug reports and suggestions; I apologize
 in advance if I am unable to respond properly to some requests.
-List of known bugs/misfeatures (no need to report them again):
-<ul>
- <li> highlighter strokes become opaque on printouts (apparently a bug in
-      libgnomeprint).</li>
- <li> print settings are not saved from one print command to the next.</li>
- <li> printing to PDF and/or printing page backgrounds generates large files.</li>
- <li> preferences are not saved on disk.</li>
- <li> selection cannot be dragged across page boundaries.</li>
-</ul>
 If you find a sequence of operations which crashes Xournal in a reproducible
 manner, please send detailed instructions on how to reproduce the crash. 
 A core file may also be helpful.
 </p>
+<p>
+Bug reports and suggestions can also be submitted on Xournal's
+<a href="http://www.sourceforge.net/projects/xournal/">SourceForge page.</a>
+</p>
 <hr />
 <a name="changelog"></a>
 <h2 class="subtitle">Version history</h2>
 <p>
-Version 0.2.1 (Jun 3, 2006):
+Version 0.4.5 (Oct 2, 2009):
+<ul>
+     <li>bugfixes for GTK+ 2.16/2.17 issues with xinput events
+</li><li>various minor UI bugfixes
+</li><li>gettext internationalization (contributed by David Planella)
+</li><li>Catalan translation (by David Planella), French translation
+</li><li>use poppler instead of pdftoppm to render PDF backgrounds 
+    (after patches by Mike Ter Louw and Bob McElrath)
+</li><li>various improvements to UI and to key bindings (including
+    patches by Bob McElrath and Lu Zhihe)
+</li><li>use gtk-print instead of libgnomeprint for printing
+</li><li>custom color chooser (patch contributed by Alex Ray)
+</li><li>option to have tablet buttons toggle the mapping rather than draw
+</li><li>paper color chooser (after a patch by Ole Joergen Broenner)
+</li><li>remove binary installer (due to binary incompatibilities)
+</li><li>UPDATED DEPENDENCIES: need gtk+ 2.10, poppler-glib 0.5.4
+</li>
+</ul>
+</p>                             
+<p>
+Version 0.4.2.1 (Mar 27, 2008):
+<ul>
+ <li>bugfix for #1926757 (crash upon pasting variable-width stroke)</li>
+ <li>bugfix: set ruler/recognizer setting to default upon switching tools</li>
+</ul>
+</p>
+<p>
+Version 0.4.2 (Mar 25, 2008):
+<ul>
+ <li>bugfixes for X.org 7.3; allow XInput and core events in reverse order</li>
+ <li>resize selection (patch contributed by Andy Neitzke)</li>
+ <li>pressure sensitive pen (variable stroke width) (patch by Andy Neitzke)</li>
+ <li>geometric shape recognizer (after an idea by Lukasz Kaiser) 
+     (see <a href="manual.html#recognizer">here</a>)</li>
+ <li>clean up compiler warnings (patch contributed by Danny Kukawka)</li>
+</ul>
+</p>
+<p>
+Version 0.4.1 (Sep 15, 2007):
+<ul>
+ <li> bugfix: compatibility with new versions of pdftoppm (thanks to
+      Vincenzo Ciancia)</li>
+ <li>GTK+ 2.11 event processing bugfix</li>
+ <li>minor bugfixes: hand tool, handling of filenames containing '&amp;'</li>
+ <li>desktop and MIME files (thanks to Mathieu Bouchard) + updated installer</li>
+ <li>config options: left-handed scrollbar (contributed by Uwe Winter),
+     hide some menu items (customizable in config file), auto-save
+     preferences</li>
+</ul>
+</p>
+<p>
+Version 0.4.0.1 (September 3, 2007):
+<ul>
+ <li>bugfixes for GTK+ 2.11 behavior (thanks to everyone who reported bugs)</li>
+</ul>
+</p>
+<p>
+Version 0.4 (August 15, 2007):
+<ul>
+ <li>text tool (handles most TrueType and Type1 fonts)</li>
+ <li>font selection dialog and button</li>
+ <li>keyboard mappings (arrow keys)</li>
+ <li>menu mnemonics and shortcuts (suggestions by Jean-Baptiste Rouquier)</li>
+ <li>more responsive hand tool</li>
+ <li>bugfix for GTK+ 2.11 XInput behavior (thanks to Robert Gerlach)</li>
+ <li>various minor bugfixes and enhancements</li>
+</ul>
+</p>
+<p>
+Version 0.3.3 (January 31, 2007):
+<ul>
+ <li>bugfix: upon loading a new file, zoom is set to default startup zoom</li>
+ <li>config option to allow input from a mouse or other core pointer device</li>
+ <li>config file entry to specify a default location for open/save
+     (patch contributed by Andy Neitzke)</li>
+ <li>config file entries to customize visibility and position of toolbars</li>
+ <li>icon (thanks to Michele Codutti)</li>
+</ul>
+</p>
+<p>
+Version 0.3.2 (November 25, 2006):
+<ul>
+ <li>preferences file and Save Preferences command</li>
+ <li>extra customization (via preferences file)</li>
+ <li>minor UI changes (patch contributed by Eduardo de Barros Lima)</li>
+ <li>hand tool (partially contributed by Vincenzo Ciancia)</li>
+ <li>a few bugfixes in rendering of bitmap backgrounds</li>
+</ul>
+<p>
+Version 0.3.1 (August 3, 2006):
+<ul>
+ <li>fixed a file format bug on systems with non-standard numeric locale
+     (bug reported by Gert Renckens)</li>
+</ul>
+</p>
+<p>
+Version 0.3 (July 23, 2006):
+<ul>
+ <li>new PDF rendering engine: export to PDF generates optimized files
+   (smaller and more accurate)</li>
+ <li>export to PDF handles PDF backgrounds (up to PDF-1.4) natively
+    (without conversion to bitmap)</li>
+ <li>default thickness of erasers and highlighters slightly increased</li>
+ <li>zoom dialog box with input box and "fit to page height" option</li>
+ <li>file format documentation added to the user's manual</li>
+</ul>
+</p>
+<p>
+Version 0.2.2 (June 5, 2006):
+<ul>
+ <li>mapping of tools to stylus buttons (the options menu has new entries
+    to allow the mapping of buttons 2 and 3 to arbitrary tools; the tools
+    menu and toolbar affect the settings for button 1)
+    (see <a href="manual.html#mappings">here</a>)</li>
+ <li>moving selection by drag-and-drop works across page boundaries</li>
+ <li>vertical space tool can move items to next page (only when the entire
+    block being moved has crossed the page boundary; items on the new page
+    are not moved)</li>
+ <li>"apply to all pages" is now a toggle button affecting the behavior of
+    paper size, color, and style commands</li>
+ <li>change in the behavior of the selection upon switching between tools</li>
+</ul>
+</p>
+<p>
+Version 0.2.1 (June 3, 2006):
 <ul>
  <li>recently used files listed in file menu</li>
  <li>can change color or thickness of pen strokes in selection</li>
@@ -484,23 +892,171 @@ Version 0.1.1 (January 5, 2006):
 <p>
 Version 0.1 (January 2, 2006): initial release.
 </p>
+<hr />
+<a name="file-format"></a>
+<h2 class="subtitle">The file format</h2>
+<h3 class="subsub">Overall structure</h3>
+<p>
+Xournal stores its data in gzipped XML-like files. The gzipped data consists
+of a succession of XML tags describing the document. By convention, the
+file header and trailer look like this:
+<pre>
+&lt;?xml version="1.0" standalone="no"?&gt;
+&lt;xournal version="..."&gt;
+&lt;title&gt;Xournal document - see http://math.mit.edu/~auroux/software/xournal/&lt;/title&gt;
+... sequence of pages ...
+&lt;/xournal&gt;
+</pre>
+The &lt;title&gt; and &lt;xournal&gt; tags may only appear within the file
+header (not within the pages of the document). The <i>version</i> attribute of
+the &lt;xournal&gt; tag indicates which version of Xournal was used to
+create the document; it is currently ignored, but may be used in a later
+release if the file format changes in an incompatible manner.
+(Following a suggestion of Matteo Abrate, starting with version 0.4 the
+&lt;xournal&gt; tag is the document's root tag, and encloses all other tags).
+</p>
+<p>
+The rest of the file is a sequence of pages, specified by a
+&lt;page&gt; tag, whose attributes <i>width</i> and <i>height</i> specify the
+physical size of the page in points (1/72 in). The width and height
+parameters are floating point values. The format of a page is therefore:
+<pre>
+&lt;page width="..." height="..."&gt;
+... page contents ...
+&lt;/page&gt;
+</pre>
+</p>
+<h3 class="subsub">Page background</h3>
 <p>
-Features yet to be implemented:
+The first entry within a page describes the page background.
+It consists of a &lt;background&gt; tag followed by several mandatory
+XML attributes. The first attribute is always <i>type</i>, which
+can take three possible values: "solid" for a solid background, "pixmap"
+for a bitmap background, and "pdf" if the background is a page of a PDF
+document. The rest of the attributes depends on the type of background.
 <ul>
- <li>freeform selection tool</li>
- <li>preferences file; persistent printer settings; recent files list</li>
- <li>native PDF print feature</li>
- <li>various functionalities (flatten layers, drag-and-drop across pages, ...)</li>
+<li><p> Solid background: <tt>&lt;background type="solid" color="..."
+style="..." /&gt;</tt> <br />The <i>color</i> attribute takes one of
+the standard values "white", "yellow", "pink", "orange", "blue", "green",
+or can specify a hexadecimal RGBA value in the format "#rrggbbaa". The
+<i>style</i> attribute takes one of the standard values "plain", "lined",
+"ruled", or "graph".</p>
+</li>
+<li><p> Bitmap background: <tt>&lt;background type="pixmap" domain="..."
+filename="..." /&gt;</tt> <br />
+The <i>domain</i> attribute takes one of the standard values "absolute",
+"attach", or "clone". A value of "absolute" indicates that the bitmap is
+found in the file specified by <i>filename</i>. The bitmap can be in any
+format recognized by the gdk-pixbuf library; this includes most of the
+common bitmap formats (JPEG, PNG, BMP, GIF, PCX, PNM, TIFF, ...).
+<br />A value
+of "attach" indicates that the bitmap is an attachment to the Xournal file.
+The bitmap is in PNG format, and resides in a file whose name is derived
+from that of the main Xournal file by appending to it a dot and the contents
+of the <i>filename</i> attribute. For example, if the Xournal file is in
+<tt>file.xoj</tt> and the <i>filename</i> attribute is <tt>"bg_1.png"</tt>
+then the bitmap file is <tt>file.xoj.bg_1.png</tt> (Xournal saves attached
+bitmaps sequentially in files ...bg_1.png, ...bg_2.png, etc.)
+<br />A value of "clone" indicates that the bitmap is identical to the
+background of a previous page of the journal; the <i>filename</i> attribute
+then specifies the page number, starting with 0 for the first page. For
+example, if a <i>filename</i> value of <tt>"1"</tt> indicates that the
+background bitmap is identical to that of the second page.
+</p>
+</li>
+<li><p> PDF background: <tt>&lt;background type="pdf" domain="..."
+filename="..." pageno="..." /&gt;</tt> or
+<tt>&lt;background type="pdf" pageno="..." /&gt;</tt>
+<br />The <i>domain</i> and <i>filename</i> attributes must be specified
+for the first page of the journal that uses a PDF background, and must
+be omitted subsequently for every other page that uses a PDF background.
+The <i>domain</i> attribute takes one of the standard values
+"absolute" and "attach"; the PDF document is to be found in the file
+specified by <i>filename</i> (if <i>domain</i> is "absolute"), or in the
+file whose name is obtained by appending a dot and the contents of the
+<i>filename</i> attribute to the name of the main Xournal file (if
+<i>domain</i> is "attach"). The <i>pageno</i> attribute specifies which
+page of the PDF file is used as background, starting with 1 for the first
+page of the PDF file.
+</p>
+</li>
 </ul>
 </p>
-<hr />
-<a name="file-format"></a>
-<h2 class="subtitle">The file format</h2>
+<h3 class="subsub">Layers and strokes</h3>
 <p>
-XOJ files are gzipped XML-like files. A more precise documentation of
-the file format will be added at a later date. Meanwhile, most of the
-format should be easy to figure out by trial-and-error or by looking
-at the source; if some details are unclear, feel free to ask.
+After the line specifying the background, the remainder of a &lt;page&gt;
+section is occupied by one or more layer sections
+<pre>&lt;layer&gt; ... &lt;/layer&gt;</pre>
+describing the various items within a layer. Every page must
+contain at least one layer; a layer may be empty. The successive layers
+are listed in their stacking order, from bottom to top.
+</p>
+<p>
+A layer consists of a collection of items, listed in the order in which
+they should be drawn
+(from bottom-most to top-most).
+Up to version 0.3.3, the only legal contents within a layer are 
+strokes. The format of a stroke is:
+<pre>&lt;stroke tool="..." color="..." width="..."&gt;
+... list of coordinates ...
+&lt;/stroke&gt;
+</pre>
+The <i>tool</i> attribute can take the values "pen", "highlighter", or
+"eraser" depending on the tool used to create the stroke (pen, highlighter,
+or whiteout eraser); a value of "highlighter" indicates that the stroke
+should be painted in a partially transparent manner (Xournal uses an alpha
+coefficient of 0.5).
+</p>
+<p>
+The <i>color</i> attribute can take one of the standard values "black",
+"blue", "red", "green", "gray", "lightblue", "lightgreen", "magenta",
+"orange", "yellow", "white", or can specify a hexadecimal RGBA value in
+the format "#rrggbbaa". 
+</p>
+<p>
+The <i>width</i> attribute is a floating-point
+number (or a sequence of floating-point numbers starting with version 0.4.2),
+and specifies the width of the stroke in points (1/72 in). (For a
+variable-width stroke, the <i>width</i> attribute contains a
+whitespace-separated succession of floating-point values: first the
+nominal brush width, and then the width of each successive segment forming
+the stroke.)
+</p>
+<p>
+The list of coordinates is simply a succession of floating-point values,
+separated by whitespace.
+The number of given values must be even; consecutive pairs of values give
+the <i>x</i> and <i>y</i> coordinates of each point along the stroke.
+These values are expressed in points (1/72 in). The coordinates (0,0)
+represent the top-left corner of the page: hence x is measured from the left
+of the page, and y is measured from the top of the page.
+</p>
+<p>
+Every stroke must contain at least two points (four floating point values).
+Moreover, two consecutive points on the stroke should be spaced no more
+than 5 units apart or so; longer line segments should be subdivided as
+appropriate (otherwise the eraser tool will not interact properly with the
+stroke). The default precision used by Xournal for the x,y coordinates is
+0.01 unit (1/7200 in).
+</p>
+<p>Starting with version 0.4, layers also contain text items.
+The format of a text item is:
+<pre>&lt;text font="..." size="..." x="..." y="..." color="..."&gt;... text ...&lt;/text&gt;
+</pre>
+The <i>font</i> attribute contains the font name, for example "Serif Bold
+Italic"; if the font is not available, another font will be substituted.
+The <i>size</i> attribute specifies the font size in points. The <i>x</i>
+and <i>y</i> attributes specify the coordinates of the top-left corner
+of the text box in page coordinates (measured in points from the top-left
+corner of the page). Finally, the <i>color</i> attribute contains either
+the name of a standard color or a hexadecimal RGBA value (see above).
+</p>
+<p>
+The contents of the text are encoded in UTF-8, with the characters
+<tt>'&amp;', '&lt;', '&gt;'</tt> replaced by <tt>&amp;amp;, &amp;lt;,
+&amp;gt;</tt>. Whitespace and linefeeds are preserved (in particular,
+no extraneous whitespace should be inserted between the enclosing tags
+and the text itself).
 </p>
 <hr />
 <a name="installation"></a>
@@ -508,29 +1064,27 @@ at the source; if some details are unclear, feel free to ask.
 <h3 class="subsub">Dependencies</h3>
 <p>
 The following libraries are required to run Xournal (they are standard on
-modern Linux distributions such as Fedora Core 3 or later, or RHEL 4 or
-later):
+modern Linux distributions such as Fedora 6 or later, RHEL 5 or
+later, Ubuntu 6.10 or later, etc.):
 <ul>
- <li> the <b>gtk+</b> libraries, version <b>2.4</b> or later 
      (2.6 recommended) &nbsp; (package gtk2 and dependencies)</li>
+ <li> the <b>gtk+</b> libraries, version <b>2.10</b> or later 
+ (package gtk2 and dependencies)</li>
  <li> <b>libgnomecanvas</b> version <b>2.4</b> or later &nbsp;
      (package libgnomecanvas and dependencies)</li>
- <li> <b>libgnomeprint</b> and <b>libgnomeprintui</b> version <b>2.2</b> or later &nbsp;
      (packages libgnomeprint22, libgnomeprintui22, and dependencies) </li>
+ (package libgnomecanvas and dependencies)</li>
+ <li> <b>poppler-glib</b> version <b>0.5.4</b> or later &nbsp;
(package poppler-glib and dependencies)</li>
 </ul>
 </p>
 <p>
Additionally:
Optional:
 <ul>
- <li> <b>xpdf</b> (more precisely, <b>pdftoppm</b>) is required for PDF file
-annotation</li>
- <li> <b>ghostscript</b> (optional: used to import PS/PDF files as bitmap 
+ <li> ghostscript (optional: used to import PS/PDF files as bitmap 
  backgrounds)</li>
 </ul>
 <p>
 To compile Xournal, you also need the <b>development packages</b> for the above
-libraries (packages gtk2-devel, libgnomecanvas-devel, libgnomeprint22-devel,
-libgnomeprintui22-devel, and dependencies), as well as <b>autoconf</b> and
+libraries (packages gtk2-devel, libgnomecanvas-devel, poppler-glib-devel,
+and dependencies), as well as <b>autoconf</b> and
 <b>automake</b>.
 </p>
 <h3 class="subsub">Compilation and installation procedure</h3>
@@ -538,37 +1092,28 @@ libgnomeprintui22-devel, and dependencies), as well as <b>autoconf</b> and
 Download the Xournal distribution tar.gz file, and any needed dependencies.
 </p>
 <p>
-<b>Binary installation in /usr/local:</b><br />
-Run (as root) the installer script
-<pre>./install-binary</pre> (and upgrade GTK+ and the other libraries if needed).
-</p>
-<p>
-<b>Binary installation in home directory:</b><br />
-Run (as any user) the installer script
-<pre>./install-binary</pre> (and hope that the required libraries are
-installed on your system).
-</p>
-<p>
 <b>Compilation and installation in /usr/local:</b>
 <pre>
-./autogen.sh
+./configure
 make
 (as root) make install
+(as root) make desktop-install
 </pre>
 </p>
 <p>
 <b>Compilation and installation in $HOME:</b>
 <pre>
-./autogen.sh
 ./configure --prefix=$HOME
 make
 make install
+make home-desktop-install
 </pre>
 </p>
 <p><b>Configure error message:</b> <br />
-If autogen.sh generates the error message
+If configure generates the error message
 &nbsp; &nbsp; <tt><i>
-configure: error: Library requirements (gtk+-2.0 >= 2.4.0 libgnomecanvas-2.0 >= 2.4.0 libgnomeprintui-2.2 >= 2.0.0) not met
+configure: error: Package requirements (gtk+-2.0 >= 2.10.0
+libgnomecanvas-2.0 >= 2.4.0 poppler-glib >= 0.5.4)  not met
 </i></tt> &nbsp; &nbsp; 
 even though you have sufficiently recent versions of these libraries on your
 system, then you need to install some missing development packages.
@@ -593,8 +1138,15 @@ be higher by several orders of magnitude).
 </p>
 <p>
 The configuration of tablet devices is controlled in the X server's
-configuration file (usually <b>XF86Config</b> or <b>xorg.conf</b> depending on your
-distribution). The ServerLayout section should contain lines like:
+configuration file (usually <b>/etc/X11/xorg.conf</b> depending on your
+distribution). The latest X servers can detect a tablet automatically and
+do not require the presence of xorg.conf to work properly; so recent
+distributions typically no longer includde such a file. However, if
+auto-configuration fails, you can always create a xorg.conf that explicitly
+specifies tablet devices.
+</p>
+<p>
+Assuming you do have a xorg.conf, the ServerLayout section should contain lines like:
 <pre>
 Section "ServerLayout"
         ...
@@ -645,6 +1197,27 @@ installation instructions specific to your model: for example, the
 use USB instead; the BottomX and BottomY values correspond to the physical
 resolution of the tablet and will vary from one model to another.
 </p>
+<p>
+For historical reasons, most X servers do not allow the input device
+designated as the "core pointer" in the X server's configuration file
+to be used as an XInput extension device. Thus, your tablet input devices
+should <b>not</b> be designated as the core pointer device. Instead, they
+should be configured with the "SendCoreEvents" option, which enables them
+to simultaneously generate XInput extension events and move the cursor on
+the screen. 
+</p>
+<p>
+<b>If you have a newer X server</b> and no xorg.conf file, the input devices can be
+configured using the <i>xinput</i> command.
+</p>
+<p>
+<b>Note:</b> with older X servers, only tablet devices are XInput devices, while
+a built-in pointing device or an external mouse would only act as the core
+pointer. In newer X servers, all devices are handled through XInput (even
+though without advanced capabilities), though mice and touchpads typically
+send invalid event data. Xournal tries to work around the most common bugs
+in input device drivers and GTK+ input event processing.
+</p>
 <h3 class="subsub">The cursor doesn't appear in the right place...</h3>
 <p>
 If the mouse pointer does not follow accurately the position of the stylus,
@@ -665,55 +1238,61 @@ appears right under the tip of the stylus).
 </p>
 <p>
 Once you have found the perfect settings for your tablet, update your X
-server's configuration file (due to issues with some versions of the
-linuxwacom driver, the tablet calibration information is often not updated
-properly when using xsetwacom).
+server's configuration file or startup scripts.
 </p>
 <p>
-<b>Important:</b> due to issues with the linuxwacom driver, it is important
-to either upgrade your driver to a <a href="manual.html#wacompatch">patched
-version</a>, or restrict your choice of settings as follows:
-<ul>
-<li> your calibration settings should not be changed at runtime (i.e.,
-insert your settings directly into your X server configuration file.
-Do not add a list of xsetwacom commands to your startup files).
-</li>
-<li> TopX and TopY values should always be 0.
-</li>
-</ul>
+<b>Important:</b> on older systems, the TopX and TopY values should always
+be kept at 0 to avoid calibration bugs.
 </p>
-<h3 class="subsub">Strokes aren't drawn under the cursor...</h3>
+<h3 class="subsub">The cursor is in the right place, but strokes aren't 
+drawn under the cursor...</h3>
 <p>
-This is due to misfeatures in the linuxwacom driver. Typically, this
-will happen in all of the following cases:
+If you experience this while trying to draw with a mouse, touchpad, or other
+non-tablet device:
+<ul>
+<li> If you don't have a tablet, simply disable "Use XInput" in the Options
+menu, this is the fastest way of fixing the problem.</li>
+<li> Upgrade to a recent version of Xournal (0.4.5 or later). Older versions
+of Xournal are not compatible with the event handling code of recent X server
+and GTK+ library versions.</li>
+<li> Check that the "Discard Core Events" option is disabled
+(<tt>discard_corepointer</tt> should be set to <tt>false</tt> in
+~/.xournal/config).</li>
+</ul>
+If you experience this while trying to draw with a tablet pen:
 <ul>
-<li> the calibration settings have been changed after the X server was
-started (using xsetwacom) </li>
-<li> the calibration TopX or TopY values are not 0 </li>
-<li> the display has been rotated </li>
+<li> If you are using an obsolete version of the linuxwacom driver (before
+0.7.6) or of GTK+, please upgrade your system.</li>
+<li>If you are using GTK+ 2.17 or newer, please upgrade to Xournal 0.4.5 or
+later. The input event processing behavior of GTK+ has changed and is no
+longer compatible with older versions of Xournal.</li>
+<li> The display geometry might have changed since the beginning of your
+session in Xournal
+(resolution changed, external monitor connected, display rotated, etc.).
+You need to exit Xournal and re-start it each time your display
+configuration changes.</li>
+<li> Your tablet devices might be incorrectly calibrated or configured.</li>
 </ul>
-Future versions of the driver may fix these issues. Meanwhile, you can
-either disable XInput support in Xournal (in the Options menu), at a
-price of a severe loss of resolution (and the eraser tip won't be detected
-anymore), or apply this <a href="manual.html#wacompatch">patch</a>
-to the wacom driver.
+If all else fails, you can disable XInput support in Xournal (in the
+Options menu), at a price of a severe loss of resolution (and the eraser tip
+won't be detected anymore).
 </p>
 <p>
 I have also had a report that one of the workarounds used by Xournal to
 bypass a calibration bug in GTK+ can actually entirely prevent strokes
 from being drawn. If you are being unsuccessful at drawing in Xournal
-with XInput enabled, try recompiling after changing the first line of
-<tt>src/main.c</tt> to
-<pre>#define ENABLE_XINPUT_BUGFIX 0</pre>
+with XInput enabled, try recompiling after commenting out the line
+<pre>#define ENABLE_XINPUT_BUGFIX</pre>
+near the beginning of <tt>src/xournal.h</tt>.
 If this modification does improve things for you, and if you have a bit
 of spare time to help investigate the causes of this problem, please
 contact me.
 </p>
 <h3 class="subsub">On-the-fly display rotation</h3>
 <p> 
-You need an X server that supports the RANDR extension, and a
-<a href="manual.html#wacompatch">patched</a> version of the linuxwacom
-driver to support on-the-fly rotation.
+You need an X server that supports the RANDR extension, and a sufficiently
+recent (0.7.6 or later) 
+version of the linuxwacom driver to support on-the-fly rotation.
 </p>
 <p>
 To set the tablet in portrait mode:
@@ -726,23 +1305,13 @@ To return to landscape mode:
   xrandr -o 0
   xsetwacom set stylus Rotate none
 </pre>
-<b>Note:</b> you should not rotate the display while Xournal is running,
+<b>Note #1:</b> you should not rotate the display while Xournal is running,
 otherwise the tablet calibration in Xournal may (and most likely will)
 become incorrect.
 Exit Xournal and restart it after the display has been rotated.
 </p>
-<a name="wacompatch"></a>
-<h3 class="subsub">Linuxwacom patch for calibration and rotation</h3>
 <p>
-This patch fixes rotation and calibration issues with the linuxwacom driver
-version 0.7.0.
-<ul>
-<li>The <a href="http://math.mit.edu/~auroux/software/xournal/linuxwacom-0.7.0-rotate-patch">patch
-file</a> for the linuxwacom source code (also included with the Xournal
-distribution).</li>
-<li>The <a href="http://math.mit.edu/~auroux/software/xournal/linuxwacom-rotate-patch.tar.gz">patched
-binaries</a> for the X.org X server.</li>
-</ul>
-</p>
+<b>Note #2:</b> the syntax of xrandr commands has changed in newer X servers.
+Consult the xrandr manual page for the new syntax.
 </body>
 </html>