找回密码
 注册
搜索
查看: 5540|回复: 0

软件热点敏感帮助的实现

[复制链接]
发表于 2006-12-27 12:48:36 | 显示全部楼层 |阅读模式
  很多人问起现在的CHM帮助文档如何作为软件的热点敏感帮助,网上搜索的资料也不多,可能是太简单了吧,呵呵!今天整理了一下,详细的介绍在VC开发的软件中对CHM帮助文档的调用方法以及CHM帮助文档的制作要求。
9 Z4 J' ^* o" J$ w( l! p2 Y' P  ?1 s7 @; h, A3 t" P" b; x, D+ @
一、软件中对CHM帮助文档的调用方法
6 u+ W+ A+ r7 U: |) F4 R: u3 P8 E- _7 ]& V# w
  VC中调用CHM帮助必须用API函数HtmlHelp(),此函数在LIB库函数内,为方便调用,我把它整体打包了,您要做的就是把它放到VC工程所在的目录,然后包含CHMHelp.h头文件即可。
+ e& k8 `# _& m) K  b. A2 I系统包含文件如下: 1 a7 }! Z1 r, }+ R+ g3 M+ I/ P1 O
/ Y5 L0 D7 d2 H/ L) Q. F7 H
  1. #include "CHMHelp.h"% o) e. \0 o/ A0 l* W! A+ S% H
  2. 5 L4 T) j) D5 D: |
  3. BOOL CDataDlg::OnInitDialog() ; u6 x& f, J2 _6 l% O" G
  4. {3 O$ w2 X" Z. G9 O
  5.         CDialog::OnInitDialog();
    2 K9 f; R- R& u; z& M3 C
  6.         SetWindowContextHelpId(IDH_WJH_0300702025);
    3 @' r' x: r8 b8 T
  7.         return TRUE;
    3 A  u$ X2 M# c# X3 y# Z
  8. }
复制代码

, U3 e. ?& V2 a" {& ]  上述代码中IDH_WJH_0300702025为在CHMHelpID.h中定义的敏感帮助的页面ID,设置了ID后在需要显示帮助的过程中(一般是用户按F1)增加如下代码:
  1. BOOL CMainFrame::OnHelpInfo(HELPINFO* pHelpInfo)
    ' |2 N! z8 T6 a, W
  2. {
    ! N/ M' t- a+ @' Z0 F  W
  3.         HWND hWnd;% b, z1 p* T8 r. x' x- z
  4.         if(pHelpInfo->dwContextId > 0)
    7 l9 ?8 j  J, u9 Z! L
  5.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
    8 n. I! }7 ?! W4 y/ f: H0 Q; f
  6.                                         theApp.m_szHelpFile, 9 f7 d8 y" f$ Y
  7.                                         HH_HELP_CONTEXT, 4 X2 o3 h9 n, d( O
  8.                                         pHelpInfo->dwContextId);$ _7 j. |# c" B/ l2 P- X
  9.         else 4 M3 n0 s/ e/ H6 |9 t' d
  10.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
    ( C. b3 o5 |- k( `8 K8 l; Q. ], X
  11.                                         theApp.m_szHelpFile, 0 y% _8 x8 J& c
  12.                                         HH_HELP_CONTEXT, 8 G" n+ f# Y1 u& B5 s
  13.                                         IDH_WJH_0100000000);8 ~1 {5 Q9 ]* l5 j
  14. 5 Y4 Z" `% C! w" o2 F: m0 a
  15.         return (hWnd != NULL);
    ; P+ d* I! t! P# C
  16.         return CMDIFrameWnd::OnHelpInfo(pHelpInfo);6 Y& d4 o" j# l# m6 k" M/ R
  17. }
复制代码

7 z0 |5 d# h# q2 M  上述代码即响应用户F1按键,若当前显示界面设置了热点敏感帮助的页面ID时,程序将打开CHM帮助文档并跳转到ID对应的页面;若当前显示界面没有设置热点敏感帮助的页面ID,则显示软件帮助缺省的页面。IDH_WJH_0100000000为软件的缺省显示页面ID。
1 t* y/ H4 [/ T/ q7 k二、CHM帮助文档的制作要求
2 J; G* x( d: r5 k* V1 \$ t
. |3 ]! a2 V! Y" b+ ACHM帮助文档必须包含API文档信息,包含页面ID文件和ID对应页面名称申明二个文件,格式如下:
0 y* b6 Q' ]- x& J8 G$ i" y( o/ i" {3 t! z
CHMHelpID.h 页面ID文件格式:
  s5 p0 g; T2 O6 I0 Z, {#define IDH_WJH_0000000000  0
5 j/ j6 r) Z+ k. i; S1 b#define IDH_WJH_0100000000  100000000
: f% S, q4 L4 B, T; E#define IDH_WJH_0100100000  100100000( t: ~5 Z2 l. C5 ?2 |
#define IDH_WJH_0100101000  100101000, s0 t  I- L* A8 l

! C8 N4 e& b  G' J) UAliasID.hID对应页面名称申明文件格式: IDH_WJH_0000000000 = 用户操作手册.Content\0000000000_操   作   手   册.Htm
* ?" M' c% w! e/ ?5 i: mIDH_WJH_0100000000 = 用户操作手册.Content\0100000000_第一部分 系统介绍.Htm4 ]7 d! w/ s2 @+ c7 g5 \  U( \
IDH_WJH_0100100000 = 用户操作手册.Content\0100100000_第一章 主要功能.Htm
+ B7 |6 n$ Q; e. z! ZIDH_WJH_0100101000 = 用户操作手册.Content\0100101000_1、基本功能.Htm
( I; C; E& @* Q* i% ^' uIDH_WJH_0100102000 = 用户操作手册.Content\0100102000_2、高级应用功能.Htm" o6 g- O1 f# ^% I2 I2 m
( U" _6 H0 `* ^. g; g0 |3 Z: Q- `# K
  编制好这两文件后,包含在HHP工程文件中,用HTML WORK SHOP进行编译就可以了。 现在网上也有很多软件可以按照WORD文档的章节自动生成上述文件,极大的方便了用户制作软件热点敏感帮助。现推荐一款制作CHM的软件:Word2CHM帮助文档制作工具,此软件自动将WORD文档按照章节转换成CHM文档,并自动生成上述两个文件。您需要做的就是按照第一节介绍的方法在VC下加入代码编译软件即可实现热点敏感帮助。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|宁德市腾云网络科技有限公司 ( 闽ICP备2022007940号-5|闽公网安备 35092202000206号 )

GMT+8, 2025-8-9 04:26 , Processed in 0.033326 second(s), 15 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表