KchmViewer is a chm (MS HTML help file format) viewer, written in C++. Unlike most existing CHM viewers for Unix, it uses Trolltech Qt widget library, and does not depend on KDE or GNOME. It has full KDE4 support.
The main advantage of KchmViewer is extended support for non-English languages. Unlike others, KchmViewer in most cases correctly detects chm file encoding, correctly shows tables of context of Russian, Korean, Chinese and Japanese help files. It also correctly searches text in non-English help files, including Korean, Chinese and Japanese.
KchmViewer is written by Georgy Yunaev (firstname.lastname@example.org), and is licensed under GNU GPL license. Please do NOT use this email for bug reporting; see below.
- Standalone viewer, depends on Qt4 only. Does not require KDE, GNOME or wxWidgets toolkit.
- Could be optionally built with KDE4 support, using KHTML and KDE dialogs.
- Correctly detects and shows encoding of any valid chm file.
- Correctly shows non-English chm files, including Cyrillic, Chinese, Japanese and others.
- Correctly searches in non-English chm files using chm built-in search index.
- Shows an appropriate image for every TOC entry.
- Has complete chm index support, including multiple index entries, cross-links and parent/child entries in index.
- Persistent bookmarks support. Allows to store bookmarks even if "Favorites" window was not enabled for this chm file. Also stores the screen position for every bookmark. You can also edit/delete bookmarks.
- For any opened chm file, stores the last opened window, search history, bookmark history, font size and so on, so when you open this file again, everything is always on the place.
- Has easy and powerful search-in-page support.
- Allows to increase or decrease the font size, so physically handicapped people can read texts easily.
- Has standard Back/Forward/Home navigation.
- Can print the opened pages on a standard printer (usually via CUPS).
- Has complex search query support. You can use search queries like "lazy people" +learn -not.
Usually kchmviewer is distributed in source code archive, so you need to compile it first. It requires Qt version 4.4 or higher. Note that you need to install qt4-devel and qt4-tools packages (the last one might be included in qt4-devel in your distribution), not just qt package.
Also make sure you have chmlib-devel (some distros have it as libchm-devel) package installed. KDE build will check for its presence, but qmake does not have necessary functionality to do so. If you are getting errors regarding missing chm_lib.h file this means chmlib-devel is not installed.
3.1. Qt-only version
To compile Qt-only version of kchmviewer, follow the procedure:
> tar zxf kchmviewer-<version>.tar.gz
> cd kchmviewer-<version>
The compiled binary is in bin/kchmviewer. You could copy it somewhere, or use it as-is. It does not require installation.
If QtWebKit module is not found, you will get the following error:
> kchmviewwindow_qtwebkit.h:25:21: error: QWebView: No such file or directory
then you need to install the QtWebKit module.
3.2 KDE4 version
To compile the version of kchmviewer with KDE4 support, follow the procedure:
> tar zxf kchmviewer-<version>.tar.gz
> mkdir build
> cd build
> cmake ..
> sudo make install
For KDE version the installation is required, since the KHTML KIO slave cannot be used in place.
Usage of kchmviewer is simple:
for the rest of command-line options, see kchmviewer --help
5. BUG REPORTING
Please use email@example.com for bug reporting.
- Jed Wing, the author of chmlib. This library is used by kchmviewer to access chm content.
- Razvan Cojocaru, the author of xchm. I used some ideas and chm processing code from xchm.
- Peter Volkov for various bug reports and improvement suggestions.
- All the users, who report bugs, and suggest features. You help making kchmviewer better.
kchmviewer is distributed under GNU GPL license version 3.