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

软件热点敏感帮助的实现

[复制链接]
发表于 2006-12-27 12:48:36 | 显示全部楼层 |阅读模式
  很多人问起现在的CHM帮助文档如何作为软件的热点敏感帮助,网上搜索的资料也不多,可能是太简单了吧,呵呵!今天整理了一下,详细的介绍在VC开发的软件中对CHM帮助文档的调用方法以及CHM帮助文档的制作要求。5 F2 q6 m' y( I
4 e* \& |. T0 X
一、软件中对CHM帮助文档的调用方法
* T0 F$ D+ Y4 T$ ^+ h: Q) j* F- S: j! W$ ]6 B
  VC中调用CHM帮助必须用API函数HtmlHelp(),此函数在LIB库函数内,为方便调用,我把它整体打包了,您要做的就是把它放到VC工程所在的目录,然后包含CHMHelp.h头文件即可。/ K* J* Q& }. s" n% V9 [
系统包含文件如下:
5 H* f1 A! N0 F5 I% W) Z- h) K3 S& l: z
  1. #include "CHMHelp.h"
      P( _  \- `1 Q  K/ [1 z9 V
  2. $ @3 n0 t% |! z' g4 O
  3. BOOL CDataDlg::OnInitDialog() ) \7 q, o; X; E1 c: O& ?- D! h
  4. {
      P6 G' K* e0 I3 W
  5.         CDialog::OnInitDialog();
    " D6 x- f0 S7 r( _! @
  6.         SetWindowContextHelpId(IDH_WJH_0300702025);0 }/ v% R- W$ h- J/ I* \/ C  B
  7.         return TRUE;$ q4 a+ }" s* c; h
  8. }
复制代码
3 [- Y+ ?3 n$ C) N. t9 Z% L
  上述代码中IDH_WJH_0300702025为在CHMHelpID.h中定义的敏感帮助的页面ID,设置了ID后在需要显示帮助的过程中(一般是用户按F1)增加如下代码:
  1. BOOL CMainFrame::OnHelpInfo(HELPINFO* pHelpInfo)
    " c% L$ z" r0 [$ ]2 [' E. h
  2. {
    6 f& F, P+ f1 s. q+ e
  3.         HWND hWnd;4 c2 h& O9 w( S: Y. m: C4 n: J
  4.         if(pHelpInfo->dwContextId > 0)
      i* ^# w9 t8 e( y9 y
  5.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle, # Y( W! U6 f* d
  6.                                         theApp.m_szHelpFile, . T+ c" h/ P+ Y* L1 Q# ?
  7.                                         HH_HELP_CONTEXT, - E' r4 [- ~7 x) G2 G! d( _4 L+ E: D
  8.                                         pHelpInfo->dwContextId);
    ) J# _" ~9 `+ S. x
  9.         else + c' |/ r6 K1 H# I
  10.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle, 3 c6 s2 g4 _6 m* Z
  11.                                         theApp.m_szHelpFile, 3 \( u# r& ]8 A- |% c0 Z
  12.                                         HH_HELP_CONTEXT,
    4 _' m: R6 C! G- [6 Z# z0 f( O2 C
  13.                                         IDH_WJH_0100000000);
    3 E& Z8 c) r! h) f& ]+ w
  14. ! s9 {! ~: |6 X( B; c- z/ E
  15.         return (hWnd != NULL);* k4 j% k0 B- I4 n5 u- T
  16.         return CMDIFrameWnd::OnHelpInfo(pHelpInfo);8 Z0 y) ?& P1 O8 B% `
  17. }
复制代码
/ _  f3 g5 ^! E" N' [; H
  上述代码即响应用户F1按键,若当前显示界面设置了热点敏感帮助的页面ID时,程序将打开CHM帮助文档并跳转到ID对应的页面;若当前显示界面没有设置热点敏感帮助的页面ID,则显示软件帮助缺省的页面。IDH_WJH_0100000000为软件的缺省显示页面ID。
7 ?, v! S! R+ z* ~4 Z+ K二、CHM帮助文档的制作要求 7 M4 S2 X; W9 g; g0 G" v
1 `% ?/ `9 ?- R7 ]+ \/ F- n8 ?
CHM帮助文档必须包含API文档信息,包含页面ID文件和ID对应页面名称申明二个文件,格式如下:
% Y4 i* L$ D- t: I8 |+ W
2 {5 P3 E- |1 K! ~/ E* qCHMHelpID.h 页面ID文件格式:
3 a" J+ Q1 I: H% ^#define IDH_WJH_0000000000  0
' T% l$ d) _' o* h" Z& w0 u#define IDH_WJH_0100000000  100000000
: l! w, U% [" I0 a: j+ H5 j  w0 {#define IDH_WJH_0100100000  100100000
( X. m5 L. r* o, E9 W#define IDH_WJH_0100101000  100101000" P8 g' ~/ N/ d8 ?8 L
; N% a2 [& U" m$ R# R
AliasID.hID对应页面名称申明文件格式: IDH_WJH_0000000000 = 用户操作手册.Content\0000000000_操   作   手   册.Htm
% p2 l% u. u/ b- t/ X) G8 g( w/ {- U( PIDH_WJH_0100000000 = 用户操作手册.Content\0100000000_第一部分 系统介绍.Htm! }9 N3 G8 h4 G
IDH_WJH_0100100000 = 用户操作手册.Content\0100100000_第一章 主要功能.Htm
, M/ e& a2 h, |$ h( k7 ^5 Y( Y! WIDH_WJH_0100101000 = 用户操作手册.Content\0100101000_1、基本功能.Htm
! M1 {# N) I7 [% ^- |8 X' rIDH_WJH_0100102000 = 用户操作手册.Content\0100102000_2、高级应用功能.Htm
% V. U8 G5 ~  _$ Z6 H& ]  Q3 m  ~5 ?/ B1 ?+ a9 E! G" n
  编制好这两文件后,包含在HHP工程文件中,用HTML WORK SHOP进行编译就可以了。 现在网上也有很多软件可以按照WORD文档的章节自动生成上述文件,极大的方便了用户制作软件热点敏感帮助。现推荐一款制作CHM的软件:Word2CHM帮助文档制作工具,此软件自动将WORD文档按照章节转换成CHM文档,并自动生成上述两个文件。您需要做的就是按照第一节介绍的方法在VC下加入代码编译软件即可实现热点敏感帮助。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-6-19 09:16 , Processed in 0.014687 second(s), 14 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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