|
|
很多人问起现在的CHM帮助文档如何作为软件的热点敏感帮助,网上搜索的资料也不多,可能是太简单了吧,呵呵!今天整理了一下,详细的介绍在VC开发的软件中对CHM帮助文档的调用方法以及CHM帮助文档的制作要求。9 W5 Z7 i+ ?* A3 N, Q
$ z- g, ]& ]. U* K( @一、软件中对CHM帮助文档的调用方法
) }: k/ z$ P/ I/ |
) j, H( D$ h C y VC中调用CHM帮助必须用API函数HtmlHelp(),此函数在LIB库函数内,为方便调用,我把它整体打包了,您要做的就是把它放到VC工程所在的目录,然后包含CHMHelp.h头文件即可。3 t( W* r4 H. U8 z
系统包含文件如下: : b3 D! }8 \/ K6 V
/ Y U4 ?8 V. L4 R" Y/ {: F9 M- \
- #include "CHMHelp.h"! i7 K+ j4 X1 X- v0 O. s- y5 u. C6 W
, x5 d5 Q+ Q7 B0 g! [) y- BOOL CDataDlg::OnInitDialog() * g3 ~; s4 X1 a
- {
$ U" o v2 W @8 Z - CDialog::OnInitDialog();8 o9 f0 ^3 k$ Y2 m" I
- SetWindowContextHelpId(IDH_WJH_0300702025);
5 ?( P- ]( d+ \! N - return TRUE;5 Q& h! o3 F$ q. i
- }
复制代码 2 Y/ j- O* o( v" T: q1 w9 `) I
上述代码中IDH_WJH_0300702025为在CHMHelpID.h中定义的敏感帮助的页面ID,设置了ID后在需要显示帮助的过程中(一般是用户按F1)增加如下代码:- BOOL CMainFrame::OnHelpInfo(HELPINFO* pHelpInfo) * B1 |* j! c) \
- {
5 r5 W" W9 X U3 o7 k; }& L: u - HWND hWnd;
9 p P9 f" P5 s+ Q - if(pHelpInfo->dwContextId > 0) 2 P) A/ [9 L0 |* t; ]6 v% o
- hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
0 V. l: R4 Y8 Q5 X- \ - theApp.m_szHelpFile,
! z5 j: w6 k& [" |- j3 [ - HH_HELP_CONTEXT,
) J. S) \+ f$ W - pHelpInfo->dwContextId);
, r# L) r9 \/ N9 S1 ]( }5 d - else 1 A4 I' V. V6 s$ W4 p
- hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle, * Q+ w9 l% S( u* A3 V: \0 x# H
- theApp.m_szHelpFile, ( N% `: Q) i; F
- HH_HELP_CONTEXT,
: B7 t+ a* [. H - IDH_WJH_0100000000);5 M; X! i# }' O/ m+ _! R7 i% D
- 8 i% d" Q5 H% j6 X$ W+ _
- return (hWnd != NULL);& B9 ^1 _( Y" q5 P% l |% L' b5 q
- return CMDIFrameWnd::OnHelpInfo(pHelpInfo);" ]; \& v5 M- k" d
- }
复制代码
7 m4 a+ K2 q- C' D! y 上述代码即响应用户F1按键,若当前显示界面设置了热点敏感帮助的页面ID时,程序将打开CHM帮助文档并跳转到ID对应的页面;若当前显示界面没有设置热点敏感帮助的页面ID,则显示软件帮助缺省的页面。IDH_WJH_0100000000为软件的缺省显示页面ID。
$ X* s9 X3 z- \6 L二、CHM帮助文档的制作要求
4 E! S2 t, ?6 g( E7 _. S9 s6 b
: ?3 [9 f' y* w9 a/ ?CHM帮助文档必须包含API文档信息,包含页面ID文件和ID对应页面名称申明二个文件,格式如下:
( A; v6 S' n- w7 `) m. S8 @$ [+ p8 I _ P# c0 p$ {$ G
CHMHelpID.h 页面ID文件格式:
0 C! r6 O! @8 H1 A$ j' N#define IDH_WJH_0000000000 0* m" g$ ~0 i# T3 N1 j7 d5 N
#define IDH_WJH_0100000000 100000000
8 Z7 |* k! y! l. @. H" o#define IDH_WJH_0100100000 100100000; }% a3 o8 h, k% C
#define IDH_WJH_0100101000 100101000) y% L6 d6 s0 ?7 v. O
5 A* l2 B4 ~2 _' T
AliasID.hID对应页面名称申明文件格式: IDH_WJH_0000000000 = 用户操作手册.Content\0000000000_操 作 手 册.Htm; a4 R, `7 i& L
IDH_WJH_0100000000 = 用户操作手册.Content\0100000000_第一部分 系统介绍.Htm
6 }) f; ]: L$ {# \/ g5 [: RIDH_WJH_0100100000 = 用户操作手册.Content\0100100000_第一章 主要功能.Htm! f7 P5 v5 I1 Q! M1 W3 R
IDH_WJH_0100101000 = 用户操作手册.Content\0100101000_1、基本功能.Htm+ m0 T3 V3 r, H7 a! g
IDH_WJH_0100102000 = 用户操作手册.Content\0100102000_2、高级应用功能.Htm/ i# M" b" u7 W. ~( B* P6 E0 S
& \) ?! x1 @1 U# `' c 编制好这两文件后,包含在HHP工程文件中,用HTML WORK SHOP进行编译就可以了。 现在网上也有很多软件可以按照WORD文档的章节自动生成上述文件,极大的方便了用户制作软件热点敏感帮助。现推荐一款制作CHM的软件:Word2CHM帮助文档制作工具,此软件自动将WORD文档按照章节转换成CHM文档,并自动生成上述两个文件。您需要做的就是按照第一节介绍的方法在VC下加入代码编译软件即可实现热点敏感帮助。 |
|