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

软件热点敏感帮助的实现

[复制链接]
发表于 2006-12-27 12:48:36 | 显示全部楼层 |阅读模式
  很多人问起现在的CHM帮助文档如何作为软件的热点敏感帮助,网上搜索的资料也不多,可能是太简单了吧,呵呵!今天整理了一下,详细的介绍在VC开发的软件中对CHM帮助文档的调用方法以及CHM帮助文档的制作要求。
0 H4 q- z/ d, k' m8 c' M! _" L) i4 t1 x: b7 v$ J
一、软件中对CHM帮助文档的调用方法
$ l( y* q' N# {* \1 m; o) F+ i$ R! t9 B5 w
  VC中调用CHM帮助必须用API函数HtmlHelp(),此函数在LIB库函数内,为方便调用,我把它整体打包了,您要做的就是把它放到VC工程所在的目录,然后包含CHMHelp.h头文件即可。
/ r3 ]% a7 c% B( I7 [" k系统包含文件如下: 6 d- m2 X. I+ X/ F, @7 x/ z

( I* w( r' y2 O& a
  1. #include "CHMHelp.h"
    " Z" c) R- d; n, G% }/ y

  2. : v8 G5 G* @, c7 S7 a
  3. BOOL CDataDlg::OnInitDialog() ! O) ~" w, H, b  [
  4. {
    # A# {8 m6 c- p0 d
  5.         CDialog::OnInitDialog();
    1 m* s7 e, W, W, k9 d4 t
  6.         SetWindowContextHelpId(IDH_WJH_0300702025);
    ; D6 i% k' W5 c; _. R' B: `
  7.         return TRUE;0 h. w' q8 C( D& W
  8. }
复制代码
+ b/ l  n1 i0 r! }8 K8 P
  上述代码中IDH_WJH_0300702025为在CHMHelpID.h中定义的敏感帮助的页面ID,设置了ID后在需要显示帮助的过程中(一般是用户按F1)增加如下代码:
  1. BOOL CMainFrame::OnHelpInfo(HELPINFO* pHelpInfo)
    " D, U: V* n+ |8 c, M
  2. {& d6 Q! ]* w+ w' y
  3.         HWND hWnd;  Y* E8 u& B5 s4 D- ^
  4.         if(pHelpInfo->dwContextId > 0)
    / x* l4 O: v$ p3 }. F1 U7 b
  5.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
    ; y+ i$ t; [5 H; |* ^' Z# T
  6.                                         theApp.m_szHelpFile,
    , Z  ?2 n1 U$ T8 P
  7.                                         HH_HELP_CONTEXT, 9 S/ A9 u8 G( v& V# j
  8.                                         pHelpInfo->dwContextId);
    % P/ Q# c. A: i$ |# q
  9.         else - x; v% ^% [! H
  10.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
      c3 f; H- N6 y0 u" c' A
  11.                                         theApp.m_szHelpFile, + b: W8 ^4 i" ~" }$ F; B8 s* h/ `
  12.                                         HH_HELP_CONTEXT,
    3 n. ^  ]& a% _% Q1 t& C
  13.                                         IDH_WJH_0100000000);# i4 t! Z4 X: c$ A- i( A# I
  14. ; W5 n4 V/ \: F& k7 e
  15.         return (hWnd != NULL);& S* i  P+ L$ X* s: m! l
  16.         return CMDIFrameWnd::OnHelpInfo(pHelpInfo);
    ' V% [. ]* l- q  ~! P2 e* K: {2 x
  17. }
复制代码
. X! C) ~" J5 b. \, m" t4 E0 ?6 w
  上述代码即响应用户F1按键,若当前显示界面设置了热点敏感帮助的页面ID时,程序将打开CHM帮助文档并跳转到ID对应的页面;若当前显示界面没有设置热点敏感帮助的页面ID,则显示软件帮助缺省的页面。IDH_WJH_0100000000为软件的缺省显示页面ID。
7 V- E" ^5 C, _: T: j" P二、CHM帮助文档的制作要求 * d, L# V; C+ v3 D. f
$ Q$ @0 g4 i4 _. I6 g9 d! [
CHM帮助文档必须包含API文档信息,包含页面ID文件和ID对应页面名称申明二个文件,格式如下: % L) G! ?# e, Q) V% s

8 z, n0 ^0 e& I/ nCHMHelpID.h 页面ID文件格式:6 [; t2 B# I& G& \. n
#define IDH_WJH_0000000000  0
5 ]  S: W% W/ G; x, l' K#define IDH_WJH_0100000000  100000000
- T! n7 i7 R% `# `+ s  v- J: D" X#define IDH_WJH_0100100000  100100000
0 E% O& U6 E" S' C: K#define IDH_WJH_0100101000  1001010003 H3 h" h( R/ Z/ K
' `) W& Y/ k1 W/ ~5 ]  [3 d6 i
AliasID.hID对应页面名称申明文件格式: IDH_WJH_0000000000 = 用户操作手册.Content\0000000000_操   作   手   册.Htm
* t. |) K8 @5 K  f7 Q& }IDH_WJH_0100000000 = 用户操作手册.Content\0100000000_第一部分 系统介绍.Htm
4 [( {4 u. i" S6 yIDH_WJH_0100100000 = 用户操作手册.Content\0100100000_第一章 主要功能.Htm8 o7 W3 ]9 h' I; D  W1 j
IDH_WJH_0100101000 = 用户操作手册.Content\0100101000_1、基本功能.Htm; J) i1 X3 d  [5 P$ V1 b5 o
IDH_WJH_0100102000 = 用户操作手册.Content\0100102000_2、高级应用功能.Htm
$ i7 Z& ~9 T" O0 \4 D
4 Y- K8 Y% e1 Z: W, s$ z& k  编制好这两文件后,包含在HHP工程文件中,用HTML WORK SHOP进行编译就可以了。 现在网上也有很多软件可以按照WORD文档的章节自动生成上述文件,极大的方便了用户制作软件热点敏感帮助。现推荐一款制作CHM的软件:Word2CHM帮助文档制作工具,此软件自动将WORD文档按照章节转换成CHM文档,并自动生成上述两个文件。您需要做的就是按照第一节介绍的方法在VC下加入代码编译软件即可实现热点敏感帮助。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

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

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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