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

软件热点敏感帮助的实现

[复制链接]
发表于 2006-12-27 12:48:36 | 显示全部楼层 |阅读模式
  很多人问起现在的CHM帮助文档如何作为软件的热点敏感帮助,网上搜索的资料也不多,可能是太简单了吧,呵呵!今天整理了一下,详细的介绍在VC开发的软件中对CHM帮助文档的调用方法以及CHM帮助文档的制作要求。9 W5 Z7 i+ ?* A3 N, Q

$ z- g, ]& ]. U* K( @一、软件中对CHM帮助文档的调用方法
) }: k/ z$ P/ I/ |
) j, H( D$ h  C  y  VC中调用CHM帮助必须用API函数HtmlHelp(),此函数在LIB库函数内,为方便调用,我把它整体打包了,您要做的就是把它放到VC工程所在的目录,然后包含CHMHelp.h头文件即可。3 t( W* r4 H. U8 z
系统包含文件如下: : b3 D! }8 \/ K6 V
/ Y  U4 ?8 V. L4 R" Y/ {: F9 M- \
  1. #include "CHMHelp.h"! i7 K+ j4 X1 X- v0 O. s- y5 u. C6 W

  2. , x5 d5 Q+ Q7 B0 g! [) y
  3. BOOL CDataDlg::OnInitDialog() * g3 ~; s4 X1 a
  4. {
    $ U" o  v2 W  @8 Z
  5.         CDialog::OnInitDialog();8 o9 f0 ^3 k$ Y2 m" I
  6.         SetWindowContextHelpId(IDH_WJH_0300702025);
    5 ?( P- ]( d+ \! N
  7.         return TRUE;5 Q& h! o3 F$ q. i
  8. }
复制代码
2 Y/ j- O* o( v" T: q1 w9 `) I
  上述代码中IDH_WJH_0300702025为在CHMHelpID.h中定义的敏感帮助的页面ID,设置了ID后在需要显示帮助的过程中(一般是用户按F1)增加如下代码:
  1. BOOL CMainFrame::OnHelpInfo(HELPINFO* pHelpInfo) * B1 |* j! c) \
  2. {
    5 r5 W" W9 X  U3 o7 k; }& L: u
  3.         HWND hWnd;
    9 p  P9 f" P5 s+ Q
  4.         if(pHelpInfo->dwContextId > 0) 2 P) A/ [9 L0 |* t; ]6 v% o
  5.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
    0 V. l: R4 Y8 Q5 X- \
  6.                                         theApp.m_szHelpFile,
    ! z5 j: w6 k& [" |- j3 [
  7.                                         HH_HELP_CONTEXT,
    ) J. S) \+ f$ W
  8.                                         pHelpInfo->dwContextId);
    , r# L) r9 \/ N9 S1 ]( }5 d
  9.         else 1 A4 I' V. V6 s$ W4 p
  10.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle, * Q+ w9 l% S( u* A3 V: \0 x# H
  11.                                         theApp.m_szHelpFile, ( N% `: Q) i; F
  12.                                         HH_HELP_CONTEXT,
    : B7 t+ a* [. H
  13.                                         IDH_WJH_0100000000);5 M; X! i# }' O/ m+ _! R7 i% D
  14. 8 i% d" Q5 H% j6 X$ W+ _
  15.         return (hWnd != NULL);& B9 ^1 _( Y" q5 P% l  |% L' b5 q
  16.         return CMDIFrameWnd::OnHelpInfo(pHelpInfo);" ]; \& v5 M- k" d
  17. }
复制代码

7 m4 a+ K2 q- C' D! y  上述代码即响应用户F1按键,若当前显示界面设置了热点敏感帮助的页面ID时,程序将打开CHM帮助文档并跳转到ID对应的页面;若当前显示界面没有设置热点敏感帮助的页面ID,则显示软件帮助缺省的页面。IDH_WJH_0100000000为软件的缺省显示页面ID。
$ X* s9 X3 z- \6 L二、CHM帮助文档的制作要求
4 E! S2 t, ?6 g( E7 _. S9 s6 b
: ?3 [9 f' y* w9 a/ ?CHM帮助文档必须包含API文档信息,包含页面ID文件和ID对应页面名称申明二个文件,格式如下:
( A; v6 S' n- w7 `) m. S8 @$ [+ p8 I  _  P# c0 p$ {$ G
CHMHelpID.h 页面ID文件格式:
0 C! r6 O! @8 H1 A$ j' N#define IDH_WJH_0000000000  0* m" g$ ~0 i# T3 N1 j7 d5 N
#define IDH_WJH_0100000000  100000000
8 Z7 |* k! y! l. @. H" o#define IDH_WJH_0100100000  100100000; }% a3 o8 h, k% C
#define IDH_WJH_0100101000  100101000) y% L6 d6 s0 ?7 v. O
5 A* l2 B4 ~2 _' T
AliasID.hID对应页面名称申明文件格式: IDH_WJH_0000000000 = 用户操作手册.Content\0000000000_操   作   手   册.Htm; a4 R, `7 i& L
IDH_WJH_0100000000 = 用户操作手册.Content\0100000000_第一部分 系统介绍.Htm
6 }) f; ]: L$ {# \/ g5 [: RIDH_WJH_0100100000 = 用户操作手册.Content\0100100000_第一章 主要功能.Htm! f7 P5 v5 I1 Q! M1 W3 R
IDH_WJH_0100101000 = 用户操作手册.Content\0100101000_1、基本功能.Htm+ m0 T3 V3 r, H7 a! g
IDH_WJH_0100102000 = 用户操作手册.Content\0100102000_2、高级应用功能.Htm/ i# M" b" u7 W. ~( B* P6 E0 S

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

本版积分规则

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

GMT+8, 2025-11-15 01:28 , Processed in 0.016590 second(s), 15 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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