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

软件热点敏感帮助的实现

[复制链接]
发表于 2006-12-27 12:48:36 | 显示全部楼层 |阅读模式
  很多人问起现在的CHM帮助文档如何作为软件的热点敏感帮助,网上搜索的资料也不多,可能是太简单了吧,呵呵!今天整理了一下,详细的介绍在VC开发的软件中对CHM帮助文档的调用方法以及CHM帮助文档的制作要求。
6 |) x: D$ A8 r. N' R; a2 [! p' k  P3 X& [, l2 G
一、软件中对CHM帮助文档的调用方法
: d5 l( `# P' R- V$ v/ O* Q: X6 t/ u; h% f  N
  VC中调用CHM帮助必须用API函数HtmlHelp(),此函数在LIB库函数内,为方便调用,我把它整体打包了,您要做的就是把它放到VC工程所在的目录,然后包含CHMHelp.h头文件即可。
1 H! X5 P+ V# E; ?; ]系统包含文件如下:
6 Y8 R6 x) v: p5 z, Y' M
3 h7 `4 K8 \* O( O: U8 ~5 ]* m8 k, W
  1. #include "CHMHelp.h"
    9 [9 j' g! y& T+ q! }  q

  2. . e9 G% ]+ g" i& Y
  3. BOOL CDataDlg::OnInitDialog()
    9 a& d7 M: ~- c0 R7 M3 p7 ]
  4. {
    4 F/ l  \2 C0 s7 j8 s
  5.         CDialog::OnInitDialog();/ T. `# ]. m: G# P$ o( V2 ^
  6.         SetWindowContextHelpId(IDH_WJH_0300702025);
    ' W, \# Y/ O2 Q  K7 E, a$ Z) F# p2 A8 ~
  7.         return TRUE;
    ; Z" B! m6 `, e  q* W
  8. }
复制代码

9 W1 Z2 r+ u4 v  上述代码中IDH_WJH_0300702025为在CHMHelpID.h中定义的敏感帮助的页面ID,设置了ID后在需要显示帮助的过程中(一般是用户按F1)增加如下代码:
  1. BOOL CMainFrame::OnHelpInfo(HELPINFO* pHelpInfo) ; U/ A0 K! z; [/ {- y4 v. J" L# f
  2. {, P9 x9 ?" J7 F# f' e. O
  3.         HWND hWnd;
      d6 V3 ?0 L/ ~  G/ I
  4.         if(pHelpInfo->dwContextId > 0) 0 s, n$ m& U/ e5 G# b1 A5 X
  5.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
    0 N9 \( z: I" @7 s- M: H0 ^: a
  6.                                         theApp.m_szHelpFile, ' E! `- e2 l' o$ \& r6 P
  7.                                         HH_HELP_CONTEXT,
    ) U* I5 f4 P* t+ B  [/ h5 k- O
  8.                                         pHelpInfo->dwContextId);
    : u) V1 h; ^# F' }" e/ e$ E
  9.         else + |5 ^, w) m% N/ l# @: Z
  10.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
    , `+ z3 G' k. V" k$ c3 b
  11.                                         theApp.m_szHelpFile,
    ; d7 e1 |9 F# ^5 P
  12.                                         HH_HELP_CONTEXT, ( `, K$ p. {! V/ q, n1 G% R4 O* r
  13.                                         IDH_WJH_0100000000);$ {% Y5 Q# d/ x3 ]5 h

  14. % l6 b/ n9 N, i5 ]) r! m
  15.         return (hWnd != NULL);
      ?# n" s% e. P" V
  16.         return CMDIFrameWnd::OnHelpInfo(pHelpInfo);  D* \, M: M; g* G
  17. }
复制代码
3 b( l( \5 a- N7 D$ L& q
  上述代码即响应用户F1按键,若当前显示界面设置了热点敏感帮助的页面ID时,程序将打开CHM帮助文档并跳转到ID对应的页面;若当前显示界面没有设置热点敏感帮助的页面ID,则显示软件帮助缺省的页面。IDH_WJH_0100000000为软件的缺省显示页面ID。 1 O/ l: D  {( c" v- O* F: C
二、CHM帮助文档的制作要求
" ?9 ^3 L% U& U  M& Q/ n, Y6 A4 T3 e* s" }
CHM帮助文档必须包含API文档信息,包含页面ID文件和ID对应页面名称申明二个文件,格式如下: - E6 i4 R5 r8 P8 G6 K6 l& o  d

; [; Z6 ^! R& @" N5 W" t: K: d5 VCHMHelpID.h 页面ID文件格式:" ^( T4 A: ]# N  R% K
#define IDH_WJH_0000000000  0* x# W  g- J/ b5 m6 N
#define IDH_WJH_0100000000  100000000
5 m, V* S3 x; l, h#define IDH_WJH_0100100000  100100000
( f5 I% Z0 Y" W; k  Z+ ^#define IDH_WJH_0100101000  100101000  X# Q* w8 f. b* P

1 V: `0 E: e) Y2 KAliasID.hID对应页面名称申明文件格式: IDH_WJH_0000000000 = 用户操作手册.Content\0000000000_操   作   手   册.Htm/ j( v- T# Y/ B2 B0 V- d) n1 I
IDH_WJH_0100000000 = 用户操作手册.Content\0100000000_第一部分 系统介绍.Htm! [- B: ^: F0 W5 @) w
IDH_WJH_0100100000 = 用户操作手册.Content\0100100000_第一章 主要功能.Htm
- ^* ~+ \5 q: C6 N" N3 m6 D9 q1 fIDH_WJH_0100101000 = 用户操作手册.Content\0100101000_1、基本功能.Htm
3 E" T4 P' N( n/ jIDH_WJH_0100102000 = 用户操作手册.Content\0100102000_2、高级应用功能.Htm4 j- O. U$ u9 G
( u9 g! Q# u4 X
  编制好这两文件后,包含在HHP工程文件中,用HTML WORK SHOP进行编译就可以了。 现在网上也有很多软件可以按照WORD文档的章节自动生成上述文件,极大的方便了用户制作软件热点敏感帮助。现推荐一款制作CHM的软件:Word2CHM帮助文档制作工具,此软件自动将WORD文档按照章节转换成CHM文档,并自动生成上述两个文件。您需要做的就是按照第一节介绍的方法在VC下加入代码编译软件即可实现热点敏感帮助。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-12-15 14:33 , Processed in 0.017177 second(s), 14 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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