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

软件热点敏感帮助的实现

[复制链接]
发表于 2006-12-27 12:48:36 | 显示全部楼层 |阅读模式
  很多人问起现在的CHM帮助文档如何作为软件的热点敏感帮助,网上搜索的资料也不多,可能是太简单了吧,呵呵!今天整理了一下,详细的介绍在VC开发的软件中对CHM帮助文档的调用方法以及CHM帮助文档的制作要求。
' B! H/ S2 X: ]1 Z, W5 X' n; y: ?. Q6 |- L! H1 t. ]
一、软件中对CHM帮助文档的调用方法
( \; j6 i3 Z0 X( G5 ?
4 s' T1 c5 p( L6 L  VC中调用CHM帮助必须用API函数HtmlHelp(),此函数在LIB库函数内,为方便调用,我把它整体打包了,您要做的就是把它放到VC工程所在的目录,然后包含CHMHelp.h头文件即可。; O2 p( @. W' [7 |0 f
系统包含文件如下: ; Z! |- D' |" _5 q9 |

" h# U4 x: E8 l- g5 O) G- |
  1. #include "CHMHelp.h"# x! N5 s" Z5 g) y  V4 a
  2. / t$ F0 A1 u! D" \0 F% F
  3. BOOL CDataDlg::OnInitDialog()
    $ l! ?) V% d; v4 z3 I
  4. {
    : P) [2 w& Z& A# q
  5.         CDialog::OnInitDialog();  p& l: X# n0 c
  6.         SetWindowContextHelpId(IDH_WJH_0300702025);
    6 e, p1 D& U; Y7 U
  7.         return TRUE;
    . T( v  N3 s7 F: ^7 s$ m) L) h( n
  8. }
复制代码
6 p; i  J3 ]" E6 x5 h, O
  上述代码中IDH_WJH_0300702025为在CHMHelpID.h中定义的敏感帮助的页面ID,设置了ID后在需要显示帮助的过程中(一般是用户按F1)增加如下代码:
  1. BOOL CMainFrame::OnHelpInfo(HELPINFO* pHelpInfo)
    ! C# W' W/ ~. S9 E* g6 v' B
  2. {# p0 o8 `# }: l4 i' r0 `
  3.         HWND hWnd;
    % D% {( }% X$ p6 H
  4.         if(pHelpInfo->dwContextId > 0)
    4 @& G/ P6 y# k7 r5 V& C
  5.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
    ( H* n- }0 d" d3 q7 d
  6.                                         theApp.m_szHelpFile, * w1 v9 p1 R# s$ c
  7.                                         HH_HELP_CONTEXT,
    / S* V0 A2 A, r: F, R
  8.                                         pHelpInfo->dwContextId);
    0 q( J/ F  {( x8 v4 [, o7 Z
  9.         else
    $ V2 j3 ^6 ^& G  I) T
  10.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
      ]+ |7 X; _# }" C5 x7 O
  11.                                         theApp.m_szHelpFile,
    , ]' V. L2 D2 ~2 V
  12.                                         HH_HELP_CONTEXT, ! L& i6 F: o& R% y
  13.                                         IDH_WJH_0100000000);; Y( m" \, s# W. V7 [; D5 H* E$ o
  14. 0 }4 f) d+ G, b7 n. Q
  15.         return (hWnd != NULL);4 K. k- L: N8 t2 L/ L  b7 k; L
  16.         return CMDIFrameWnd::OnHelpInfo(pHelpInfo);
    1 v! @$ p+ r- a+ J* |' e% A
  17. }
复制代码

3 p. k( q$ ~& M1 L- a: P8 W  上述代码即响应用户F1按键,若当前显示界面设置了热点敏感帮助的页面ID时,程序将打开CHM帮助文档并跳转到ID对应的页面;若当前显示界面没有设置热点敏感帮助的页面ID,则显示软件帮助缺省的页面。IDH_WJH_0100000000为软件的缺省显示页面ID。 ) h6 s$ ]# _2 k: y3 w
二、CHM帮助文档的制作要求
, O. O5 L6 b2 \* z& U/ T
' g& v3 Z3 y  h9 BCHM帮助文档必须包含API文档信息,包含页面ID文件和ID对应页面名称申明二个文件,格式如下: , o+ U2 H! \8 c' q* a
9 B2 p5 V) O  i) t, h* J8 E7 U
CHMHelpID.h 页面ID文件格式:$ B& }. \% s* D$ H3 R) y2 R; @1 d
#define IDH_WJH_0000000000  00 t4 m5 m) B6 W
#define IDH_WJH_0100000000  1000000002 q8 f  \! p& j! n
#define IDH_WJH_0100100000  1001000001 a* F* J$ r$ X7 |( }( s2 E" Q
#define IDH_WJH_0100101000  100101000
% i6 |6 D: H7 e, x1 n8 z3 P0 @. T" J5 m; j" S& E# c
AliasID.hID对应页面名称申明文件格式: IDH_WJH_0000000000 = 用户操作手册.Content\0000000000_操   作   手   册.Htm8 w* b% w, T3 {9 ]
IDH_WJH_0100000000 = 用户操作手册.Content\0100000000_第一部分 系统介绍.Htm
) H+ W4 e5 ^+ pIDH_WJH_0100100000 = 用户操作手册.Content\0100100000_第一章 主要功能.Htm
0 L& }) l8 \1 m* MIDH_WJH_0100101000 = 用户操作手册.Content\0100101000_1、基本功能.Htm6 M' l9 c+ |' V; j- L6 L0 Q
IDH_WJH_0100102000 = 用户操作手册.Content\0100102000_2、高级应用功能.Htm7 `0 u2 `! G: l1 K' P& T/ T2 E4 z* Z, E

6 F) Z& V1 h. \( B; U! _. v$ T  编制好这两文件后,包含在HHP工程文件中,用HTML WORK SHOP进行编译就可以了。 现在网上也有很多软件可以按照WORD文档的章节自动生成上述文件,极大的方便了用户制作软件热点敏感帮助。现推荐一款制作CHM的软件:Word2CHM帮助文档制作工具,此软件自动将WORD文档按照章节转换成CHM文档,并自动生成上述两个文件。您需要做的就是按照第一节介绍的方法在VC下加入代码编译软件即可实现热点敏感帮助。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-9-30 13:08 , Processed in 0.037389 second(s), 15 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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