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

软件热点敏感帮助的实现

[复制链接]
发表于 2006-12-27 12:48:36 | 显示全部楼层 |阅读模式
  很多人问起现在的CHM帮助文档如何作为软件的热点敏感帮助,网上搜索的资料也不多,可能是太简单了吧,呵呵!今天整理了一下,详细的介绍在VC开发的软件中对CHM帮助文档的调用方法以及CHM帮助文档的制作要求。
# }9 d+ L- K9 ]% Q4 e9 v
$ \( f7 I' I) J# L- P一、软件中对CHM帮助文档的调用方法
3 ~$ R: g$ z2 G# ~3 J8 V
$ _- L1 F, S# w5 Y8 s0 H  VC中调用CHM帮助必须用API函数HtmlHelp(),此函数在LIB库函数内,为方便调用,我把它整体打包了,您要做的就是把它放到VC工程所在的目录,然后包含CHMHelp.h头文件即可。$ B( k6 `$ B% M3 a. ]$ C$ j
系统包含文件如下:
" X1 q2 [( [/ \
* C$ {& T5 b/ M* s* z6 f' x/ K
  1. #include "CHMHelp.h"8 f; k2 I" r  _
  2. - p  i/ t+ W. i( g# X1 e
  3. BOOL CDataDlg::OnInitDialog() % d$ a6 P8 p4 ~* f' @' k+ w7 f
  4. {
    & |: X9 V: |# j4 t
  5.         CDialog::OnInitDialog();
    ! t! V2 G5 W/ L. E- ^
  6.         SetWindowContextHelpId(IDH_WJH_0300702025);0 s: P5 C$ X) N7 f8 @) |6 P. _
  7.         return TRUE;0 T, G( T4 q7 u; D; |( L
  8. }
复制代码

" `1 r4 h( {. e3 G  上述代码中IDH_WJH_0300702025为在CHMHelpID.h中定义的敏感帮助的页面ID,设置了ID后在需要显示帮助的过程中(一般是用户按F1)增加如下代码:
  1. BOOL CMainFrame::OnHelpInfo(HELPINFO* pHelpInfo) # t0 l) V( V2 e/ F
  2. {
    8 v& G; E1 T; |+ Y1 i
  3.         HWND hWnd;
    5 c4 N  T1 z5 K9 _  c+ I8 [' t- I6 W
  4.         if(pHelpInfo->dwContextId > 0) & p; z8 ^! I8 P1 `# y* _
  5.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
    ) `/ e( R( |5 C' \( L
  6.                                         theApp.m_szHelpFile,
    % D, u) N) `7 U7 P: `
  7.                                         HH_HELP_CONTEXT,
    $ d1 Y! J$ V4 i0 S/ z
  8.                                         pHelpInfo->dwContextId);( u" g3 R4 V5 V3 U0 r3 C" ]' `
  9.         else 1 S3 I+ c) e- f) t( h0 a: h' e8 f
  10.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
    ' E5 ~9 M6 O0 }" v
  11.                                         theApp.m_szHelpFile, * E. M" \0 n! Y9 [. n
  12.                                         HH_HELP_CONTEXT,
    % ]5 ~0 P. `9 W8 m1 Z& x. E
  13.                                         IDH_WJH_0100000000);2 \- x" k( W& q0 Z) F
  14. : p4 p% }% ~) L9 G# r
  15.         return (hWnd != NULL);
    , @( A* Y+ y0 K0 ^6 v) v3 S( n
  16.         return CMDIFrameWnd::OnHelpInfo(pHelpInfo);( E& i0 n) |% A) i. q  V
  17. }
复制代码

7 x4 L/ q/ m6 j3 I8 O! N  上述代码即响应用户F1按键,若当前显示界面设置了热点敏感帮助的页面ID时,程序将打开CHM帮助文档并跳转到ID对应的页面;若当前显示界面没有设置热点敏感帮助的页面ID,则显示软件帮助缺省的页面。IDH_WJH_0100000000为软件的缺省显示页面ID。
8 a; w& v( {2 `' c( l6 E1 ?; A0 ~二、CHM帮助文档的制作要求 . m* @3 B/ U! f4 a0 D% ]$ }
% b- c1 L- }! X* _# b" ?
CHM帮助文档必须包含API文档信息,包含页面ID文件和ID对应页面名称申明二个文件,格式如下:
4 W: w- I& w" [0 Z
+ n# g7 x4 K1 N" ^CHMHelpID.h 页面ID文件格式:( j+ }$ K8 a# K- A
#define IDH_WJH_0000000000  0
; X; ^0 J& v$ M5 q#define IDH_WJH_0100000000  100000000
# c9 I) ~. H4 M1 L4 H/ V: ]+ Q- d#define IDH_WJH_0100100000  100100000
# H- E  w0 ^# e1 D6 D. J# n  K#define IDH_WJH_0100101000  100101000
- L6 ~* f, H' ^, `0 v# O. {4 P% v' S  H0 ]9 P9 J
AliasID.hID对应页面名称申明文件格式: IDH_WJH_0000000000 = 用户操作手册.Content\0000000000_操   作   手   册.Htm  J5 _4 |* n0 K, c1 @( x
IDH_WJH_0100000000 = 用户操作手册.Content\0100000000_第一部分 系统介绍.Htm
) M3 N- z! a8 I% t% j- ~7 T5 o6 A1 UIDH_WJH_0100100000 = 用户操作手册.Content\0100100000_第一章 主要功能.Htm# J1 e# e% v7 t$ Q
IDH_WJH_0100101000 = 用户操作手册.Content\0100101000_1、基本功能.Htm) D% d% F! Y: q9 g
IDH_WJH_0100102000 = 用户操作手册.Content\0100102000_2、高级应用功能.Htm% d( u  p& U" d, J* j5 W

* q& n* K  y7 G' J% ]$ W  编制好这两文件后,包含在HHP工程文件中,用HTML WORK SHOP进行编译就可以了。 现在网上也有很多软件可以按照WORD文档的章节自动生成上述文件,极大的方便了用户制作软件热点敏感帮助。现推荐一款制作CHM的软件:Word2CHM帮助文档制作工具,此软件自动将WORD文档按照章节转换成CHM文档,并自动生成上述两个文件。您需要做的就是按照第一节介绍的方法在VC下加入代码编译软件即可实现热点敏感帮助。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-8-9 01:37 , Processed in 0.033293 second(s), 15 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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