|
很多人问起现在的CHM帮助文档如何作为软件的热点敏感帮助,网上搜索的资料也不多,可能是太简单了吧,呵呵!今天整理了一下,详细的介绍在VC开发的软件中对CHM帮助文档的调用方法以及CHM帮助文档的制作要求。
; M: L) N2 F H0 B+ N( o& D- N( d0 {0 [2 J( ?( r3 h; w7 y
一、软件中对CHM帮助文档的调用方法
/ a$ C2 c( L& s d7 }+ k/ u& n; L2 {7 v7 G! h& h( j
VC中调用CHM帮助必须用API函数HtmlHelp(),此函数在LIB库函数内,为方便调用,我把它整体打包了,您要做的就是把它放到VC工程所在的目录,然后包含CHMHelp.h头文件即可。! U2 _4 n/ v1 G! O
系统包含文件如下: * T' p" S* {( G1 w) K# q" l" W
- K0 M# _7 f* W* F0 P2 I/ m
- #include "CHMHelp.h"
* L1 A# j: L% y1 i4 z2 P. z
. c( x8 A: I/ Z! j0 ^' w% m- BOOL CDataDlg::OnInitDialog() ) u7 O: `, ~9 p0 [
- {
/ s& j( @- z2 n5 A5 z8 \# T! Q - CDialog::OnInitDialog();
4 v- J$ K$ B# U% E - SetWindowContextHelpId(IDH_WJH_0300702025);0 z8 F- e/ |7 j `! i
- return TRUE;! u1 r- U7 l6 R+ P$ q% D6 N
- }
复制代码 # T* [/ ?+ t- q% _. f
上述代码中IDH_WJH_0300702025为在CHMHelpID.h中定义的敏感帮助的页面ID,设置了ID后在需要显示帮助的过程中(一般是用户按F1)增加如下代码:- BOOL CMainFrame::OnHelpInfo(HELPINFO* pHelpInfo) Q0 _( ^: Z) o5 e0 h
- {
0 O% l/ L/ w5 t6 | - HWND hWnd;
& H- G( p) ~% |! j! J - if(pHelpInfo->dwContextId > 0) # z. Y: T: h& g1 e
- hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle, # o( P \ ?' k* v
- theApp.m_szHelpFile,
1 O1 A! }/ H' p6 l0 ~8 l# g H - HH_HELP_CONTEXT,
2 V7 R, I. r' `9 w - pHelpInfo->dwContextId); i# ?5 d: l- u& F1 K1 d1 \6 _
- else ; w! U. L8 m4 ]7 e8 h. ^2 |
- hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle, . \" N8 n: c) E# R* V5 l
- theApp.m_szHelpFile, . n2 E( r6 E0 m& m0 y7 c
- HH_HELP_CONTEXT,
) ]* D. s3 }1 T2 @! A - IDH_WJH_0100000000);
: F2 \. o0 v2 X6 ?0 Q1 j
% s2 q( M1 Y; O- p* O- t5 `2 r- return (hWnd != NULL);' R" z* L' Q. v. _* D" j8 ]0 J
- return CMDIFrameWnd::OnHelpInfo(pHelpInfo);8 i# T- f" n z& I* e1 L
- }
复制代码 $ A. \; y! e% W, T, s
上述代码即响应用户F1按键,若当前显示界面设置了热点敏感帮助的页面ID时,程序将打开CHM帮助文档并跳转到ID对应的页面;若当前显示界面没有设置热点敏感帮助的页面ID,则显示软件帮助缺省的页面。IDH_WJH_0100000000为软件的缺省显示页面ID。 / ], x0 [5 n) }; D3 T; `) ]& D
二、CHM帮助文档的制作要求
0 P: x7 A5 A5 m9 L1 f% g. }4 n1 q' e
CHM帮助文档必须包含API文档信息,包含页面ID文件和ID对应页面名称申明二个文件,格式如下: / ?( x( L5 o0 V5 N6 P+ |/ [6 k
- r( c6 y# V- {7 U0 I
CHMHelpID.h 页面ID文件格式:
- ]6 {' N; _1 z# n#define IDH_WJH_0000000000 0
4 R4 n/ ?: \ W" {" w' L#define IDH_WJH_0100000000 1000000005 k: V2 K- V* f
#define IDH_WJH_0100100000 100100000
8 ]: b/ O, ]' f: T' Y* t#define IDH_WJH_0100101000 100101000
1 j: }. }4 ^0 Q9 k
. u# n* E+ w/ ?5 K5 }AliasID.hID对应页面名称申明文件格式: IDH_WJH_0000000000 = 用户操作手册.Content\0000000000_操 作 手 册.Htm
1 o& F: l |5 ~# P/ {7 tIDH_WJH_0100000000 = 用户操作手册.Content\0100000000_第一部分 系统介绍.Htm
" Z( X/ x2 G! J- j Y( r' [ J6 `IDH_WJH_0100100000 = 用户操作手册.Content\0100100000_第一章 主要功能.Htm4 k7 N) k/ l( [1 u. L. H9 k
IDH_WJH_0100101000 = 用户操作手册.Content\0100101000_1、基本功能.Htm4 [0 W! U% b* X
IDH_WJH_0100102000 = 用户操作手册.Content\0100102000_2、高级应用功能.Htm
9 a% G3 K) }3 _3 x5 ]3 g% t6 w0 g" n
编制好这两文件后,包含在HHP工程文件中,用HTML WORK SHOP进行编译就可以了。 现在网上也有很多软件可以按照WORD文档的章节自动生成上述文件,极大的方便了用户制作软件热点敏感帮助。现推荐一款制作CHM的软件:Word2CHM帮助文档制作工具,此软件自动将WORD文档按照章节转换成CHM文档,并自动生成上述两个文件。您需要做的就是按照第一节介绍的方法在VC下加入代码编译软件即可实现热点敏感帮助。 |
|