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

软件热点敏感帮助的实现

[复制链接]
发表于 2006-12-27 12:48:36 | 显示全部楼层 |阅读模式
  很多人问起现在的CHM帮助文档如何作为软件的热点敏感帮助,网上搜索的资料也不多,可能是太简单了吧,呵呵!今天整理了一下,详细的介绍在VC开发的软件中对CHM帮助文档的调用方法以及CHM帮助文档的制作要求。
% V7 u4 B6 D, U: W. [$ B: X+ t2 i  Y# _( V5 W* ?+ M+ N) k
一、软件中对CHM帮助文档的调用方法' O( t# b/ g! R
$ k& ^# M9 o% ~3 M$ S  P
  VC中调用CHM帮助必须用API函数HtmlHelp(),此函数在LIB库函数内,为方便调用,我把它整体打包了,您要做的就是把它放到VC工程所在的目录,然后包含CHMHelp.h头文件即可。
$ S) S, L' Q+ X0 a5 ]( R. ]系统包含文件如下: 3 Z6 ^0 L5 u3 e6 U' D+ ]

# a2 H: S: X% @! K: v5 K
  1. #include "CHMHelp.h"
    ; @& b. c) d7 H9 m0 {! `( o

  2. , M4 h% k( K+ S+ n5 y, D, d# r
  3. BOOL CDataDlg::OnInitDialog() 6 v: q% D6 r5 k( b# ?
  4. {
    & g8 U# Z/ |7 C8 @
  5.         CDialog::OnInitDialog();
    " A3 C3 `+ J- m7 ]+ E& n: d
  6.         SetWindowContextHelpId(IDH_WJH_0300702025);" K# K4 q( ?, F1 P
  7.         return TRUE;3 [- `0 A# E5 b1 Q1 H! n
  8. }
复制代码
4 b, p  a  y' u1 w4 ?5 j& {
  上述代码中IDH_WJH_0300702025为在CHMHelpID.h中定义的敏感帮助的页面ID,设置了ID后在需要显示帮助的过程中(一般是用户按F1)增加如下代码:
  1. BOOL CMainFrame::OnHelpInfo(HELPINFO* pHelpInfo)
    0 ]2 L( K+ }' h* e0 U
  2. {6 t  D+ g1 y& B$ P3 A2 u
  3.         HWND hWnd;& O; t! }4 L& \
  4.         if(pHelpInfo->dwContextId > 0)
    / z4 C! d+ A! c$ a8 j7 N
  5.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
    ! [4 A& a# j5 C0 b5 X, V5 \( @7 ^
  6.                                         theApp.m_szHelpFile,
    $ `$ y& i* b- [) y) y7 n; M0 ?
  7.                                         HH_HELP_CONTEXT,
    + W8 P+ q7 R" t5 u+ L1 m  q
  8.                                         pHelpInfo->dwContextId);& i9 O' F) Y7 n
  9.         else 5 A+ Z2 Z; P7 \8 y( H% X
  10.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
    . z! ]; [& y! w& @( e! C
  11.                                         theApp.m_szHelpFile,
    9 K3 D- c) d2 [& C' H* m7 P( i* `
  12.                                         HH_HELP_CONTEXT,
    , {* b2 K: o7 P/ {
  13.                                         IDH_WJH_0100000000);! F2 g  |/ t7 {9 y  y
  14. 6 Q6 B2 w( d3 L1 Q; j3 N
  15.         return (hWnd != NULL);
    : J/ u! j4 d. Y; I( \
  16.         return CMDIFrameWnd::OnHelpInfo(pHelpInfo);. b5 M$ Y% w  w2 Z0 H  Q
  17. }
复制代码

) I! B2 @! E) r; H. n  上述代码即响应用户F1按键,若当前显示界面设置了热点敏感帮助的页面ID时,程序将打开CHM帮助文档并跳转到ID对应的页面;若当前显示界面没有设置热点敏感帮助的页面ID,则显示软件帮助缺省的页面。IDH_WJH_0100000000为软件的缺省显示页面ID。 ' P" i3 H8 x& V, `2 c
二、CHM帮助文档的制作要求 5 B, s' m/ ?  Z& i+ q) c

$ }  i& j; k: B4 E9 y+ MCHM帮助文档必须包含API文档信息,包含页面ID文件和ID对应页面名称申明二个文件,格式如下:
' K7 n  b3 L/ v# {/ t, g
' ?8 p$ L8 U6 [3 C; DCHMHelpID.h 页面ID文件格式:
! B4 J0 b7 y3 _- x, x& }#define IDH_WJH_0000000000  0" P. Y" |1 F5 p- T5 X
#define IDH_WJH_0100000000  100000000. G# |4 l1 g% h2 Z9 ~
#define IDH_WJH_0100100000  100100000
; A9 b9 Z9 m. \- p' n' h- O" I, W#define IDH_WJH_0100101000  100101000
+ D/ F* p0 J$ G3 W& f$ i% _2 A  n
AliasID.hID对应页面名称申明文件格式: IDH_WJH_0000000000 = 用户操作手册.Content\0000000000_操   作   手   册.Htm! G$ ]! r1 H. r4 u* \" ?$ A
IDH_WJH_0100000000 = 用户操作手册.Content\0100000000_第一部分 系统介绍.Htm6 N1 c$ y0 M; b% Q1 L' T" @/ O
IDH_WJH_0100100000 = 用户操作手册.Content\0100100000_第一章 主要功能.Htm
! k9 Y/ {3 Q! `, S9 f1 V. B9 TIDH_WJH_0100101000 = 用户操作手册.Content\0100101000_1、基本功能.Htm
* @9 d/ Z% @$ R& j/ UIDH_WJH_0100102000 = 用户操作手册.Content\0100102000_2、高级应用功能.Htm
; ^0 n; L1 o4 q8 S/ c) o# y2 J; L' m- |2 p% z4 H* v, e( t4 w
  编制好这两文件后,包含在HHP工程文件中,用HTML WORK SHOP进行编译就可以了。 现在网上也有很多软件可以按照WORD文档的章节自动生成上述文件,极大的方便了用户制作软件热点敏感帮助。现推荐一款制作CHM的软件:Word2CHM帮助文档制作工具,此软件自动将WORD文档按照章节转换成CHM文档,并自动生成上述两个文件。您需要做的就是按照第一节介绍的方法在VC下加入代码编译软件即可实现热点敏感帮助。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-12-13 08:21 , Processed in 0.019053 second(s), 15 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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