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

软件热点敏感帮助的实现

[复制链接]
发表于 2006-12-27 12:48:36 | 显示全部楼层 |阅读模式
  很多人问起现在的CHM帮助文档如何作为软件的热点敏感帮助,网上搜索的资料也不多,可能是太简单了吧,呵呵!今天整理了一下,详细的介绍在VC开发的软件中对CHM帮助文档的调用方法以及CHM帮助文档的制作要求。4 Q+ L- y2 I( Q0 L1 f9 N
# L3 x7 M5 v% X0 ?2 B
一、软件中对CHM帮助文档的调用方法
! s3 p8 l3 z4 W  B) L; v3 v
8 P# O! G, X/ o, K2 ?- C" u  VC中调用CHM帮助必须用API函数HtmlHelp(),此函数在LIB库函数内,为方便调用,我把它整体打包了,您要做的就是把它放到VC工程所在的目录,然后包含CHMHelp.h头文件即可。( K8 m2 V# R1 M
系统包含文件如下:
9 g* m/ ?0 x0 C
% o; c  Z; i- \$ Q$ m$ }
  1. #include "CHMHelp.h"
    ) V  R7 ^! J% J- n$ x8 u
  2. 2 E+ c+ i( m# \: Z* }0 W+ g* ~
  3. BOOL CDataDlg::OnInitDialog() 0 e$ B2 `2 Y5 u8 C/ F9 s$ g* P% o
  4. {, q  k! m9 |9 W" }% F7 p5 H: ~9 Q
  5.         CDialog::OnInitDialog();9 h1 z  U; X) L0 O8 S  P9 k9 I
  6.         SetWindowContextHelpId(IDH_WJH_0300702025);; A5 g2 E" G* z% ?+ c
  7.         return TRUE;
    8 }2 ~% x1 ~+ D( M2 A9 k
  8. }
复制代码
+ E* n  W: M' D* \/ Z  a$ P
  上述代码中IDH_WJH_0300702025为在CHMHelpID.h中定义的敏感帮助的页面ID,设置了ID后在需要显示帮助的过程中(一般是用户按F1)增加如下代码:
  1. BOOL CMainFrame::OnHelpInfo(HELPINFO* pHelpInfo)
    5 U8 I0 ~% D$ {( `7 ^* S' o
  2. {2 u0 H8 l$ s! t$ l) j
  3.         HWND hWnd;5 X% R- S5 x/ h! H
  4.         if(pHelpInfo->dwContextId > 0) . h) e  X8 ~: p, ?- U
  5.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
    2 O' Q) J' f  y
  6.                                         theApp.m_szHelpFile, / _' B  ^: ~; d& q$ }+ j. k" F
  7.                                         HH_HELP_CONTEXT, ; c; X1 E; Z$ Q# W2 K3 S% i
  8.                                         pHelpInfo->dwContextId);
    . ~& x* L) J! \' r! S+ o/ x
  9.         else
    - b, ?: c: k/ u! a- m0 k" ?( x% G
  10.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
    0 \3 A) m* x; f
  11.                                         theApp.m_szHelpFile, # Q. K. i2 @5 r+ `" N/ w0 ]# _* v/ B
  12.                                         HH_HELP_CONTEXT,
    - m& w; Q; W* C) H& S; @6 _) I$ Q0 f7 Z
  13.                                         IDH_WJH_0100000000);. x/ O% x/ t) B7 \$ d

  14. 9 z) B5 u; Y  K( X
  15.         return (hWnd != NULL);
    2 D4 ^8 @' W' w8 w  X- h: ?
  16.         return CMDIFrameWnd::OnHelpInfo(pHelpInfo);
    2 h5 D- ]5 a0 }9 z; }/ h
  17. }
复制代码
5 s8 W) @: J% O, N. }' v
  上述代码即响应用户F1按键,若当前显示界面设置了热点敏感帮助的页面ID时,程序将打开CHM帮助文档并跳转到ID对应的页面;若当前显示界面没有设置热点敏感帮助的页面ID,则显示软件帮助缺省的页面。IDH_WJH_0100000000为软件的缺省显示页面ID。 ( i( T$ X. f$ U$ c" d1 [
二、CHM帮助文档的制作要求 ) P9 u7 C3 i( A5 m
" b2 A" F* Q' l; n$ R
CHM帮助文档必须包含API文档信息,包含页面ID文件和ID对应页面名称申明二个文件,格式如下: # O! ~& v- _' s* T: i5 {
) Y5 ^  z( [3 d" L$ z
CHMHelpID.h 页面ID文件格式:& N/ L% D' |8 E( L4 X
#define IDH_WJH_0000000000  02 z. \" m1 Z  v& t
#define IDH_WJH_0100000000  100000000& Y( Z7 ]/ u. w
#define IDH_WJH_0100100000  100100000
% O/ l# F' `$ S$ @#define IDH_WJH_0100101000  100101000
# }1 K  l* B3 T5 X) U; m2 R3 v0 D, w( L6 }5 ~8 i5 a: N$ P" D2 W0 m
AliasID.hID对应页面名称申明文件格式: IDH_WJH_0000000000 = 用户操作手册.Content\0000000000_操   作   手   册.Htm! S: S% J" i! T' b) N6 ~
IDH_WJH_0100000000 = 用户操作手册.Content\0100000000_第一部分 系统介绍.Htm
8 E- ]6 q3 [2 s5 N) @* \IDH_WJH_0100100000 = 用户操作手册.Content\0100100000_第一章 主要功能.Htm
+ Y8 @! p0 [# L  R: W; x' {/ OIDH_WJH_0100101000 = 用户操作手册.Content\0100101000_1、基本功能.Htm
, f7 C0 N0 O0 i, VIDH_WJH_0100102000 = 用户操作手册.Content\0100102000_2、高级应用功能.Htm
* `" I' [7 l& C' t' T
& g4 r* e  g" Z1 c8 L, _  编制好这两文件后,包含在HHP工程文件中,用HTML WORK SHOP进行编译就可以了。 现在网上也有很多软件可以按照WORD文档的章节自动生成上述文件,极大的方便了用户制作软件热点敏感帮助。现推荐一款制作CHM的软件:Word2CHM帮助文档制作工具,此软件自动将WORD文档按照章节转换成CHM文档,并自动生成上述两个文件。您需要做的就是按照第一节介绍的方法在VC下加入代码编译软件即可实现热点敏感帮助。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-6-20 06:03 , Processed in 0.035025 second(s), 15 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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