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

软件热点敏感帮助的实现

[复制链接]
发表于 2006-12-27 12:48:36 | 显示全部楼层 |阅读模式
  很多人问起现在的CHM帮助文档如何作为软件的热点敏感帮助,网上搜索的资料也不多,可能是太简单了吧,呵呵!今天整理了一下,详细的介绍在VC开发的软件中对CHM帮助文档的调用方法以及CHM帮助文档的制作要求。1 A7 ?  c# ~, q0 P, a
3 A$ j( f2 R9 _) Z
一、软件中对CHM帮助文档的调用方法
: [0 Z0 V- K. m" F8 F' G5 o+ a2 U4 _( D4 g2 I. D! U
  VC中调用CHM帮助必须用API函数HtmlHelp(),此函数在LIB库函数内,为方便调用,我把它整体打包了,您要做的就是把它放到VC工程所在的目录,然后包含CHMHelp.h头文件即可。
9 Z# z9 g# R7 H' n: V$ f系统包含文件如下: , a  D3 i+ d. l: p  S) g

$ P; g( i* z! A( k
  1. #include "CHMHelp.h"0 Q4 i6 L1 q: z$ K' c  G5 m  `
  2. 2 ]0 F+ U) u1 t: o6 ]. ^" |
  3. BOOL CDataDlg::OnInitDialog()
    2 P, D8 S# z9 R2 A) {4 v
  4. {+ P; P8 E5 v5 Q
  5.         CDialog::OnInitDialog();
    " A6 x; u" S, V' m4 F4 g: m
  6.         SetWindowContextHelpId(IDH_WJH_0300702025);, d0 F; }+ X2 h* j
  7.         return TRUE;
    & d1 g# E. k, k& g$ }
  8. }
复制代码
" m6 S: k* ^% U: H
  上述代码中IDH_WJH_0300702025为在CHMHelpID.h中定义的敏感帮助的页面ID,设置了ID后在需要显示帮助的过程中(一般是用户按F1)增加如下代码:
  1. BOOL CMainFrame::OnHelpInfo(HELPINFO* pHelpInfo) 8 J2 g8 K% y2 _6 Q" ^) X2 t
  2. {, y# o3 D3 s- F( x! `
  3.         HWND hWnd;" T5 P( P/ j& l) Z/ z4 P
  4.         if(pHelpInfo->dwContextId > 0) ; b0 z5 G- ^& o( i! q
  5.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,
    4 d5 c& P+ g6 |' H
  6.                                         theApp.m_szHelpFile, , {' z3 q0 A6 _' G) j7 _, ~
  7.                                         HH_HELP_CONTEXT,
    ; N( E: q8 K( r8 Y' f
  8.                                         pHelpInfo->dwContextId);
    0 X/ v3 x2 z9 d8 w( w0 D, n' y
  9.         else ! l3 J( E' h4 _1 V+ X- n
  10.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle, / ^3 |8 c% i2 f
  11.                                         theApp.m_szHelpFile,
    , P% J/ D8 V5 ~$ j: U% e, ^
  12.                                         HH_HELP_CONTEXT, 3 @$ ?7 q- @& ?# X& H
  13.                                         IDH_WJH_0100000000);
    7 p5 F8 Q# L% _0 q$ d) x$ d# c

  14. : \% N' o; O: _% V8 d
  15.         return (hWnd != NULL);
    ! M( q! {+ h; \, R: J
  16.         return CMDIFrameWnd::OnHelpInfo(pHelpInfo);
    1 \% p- D& U! f- e
  17. }
复制代码
! T# }- @2 R. J9 k! I
  上述代码即响应用户F1按键,若当前显示界面设置了热点敏感帮助的页面ID时,程序将打开CHM帮助文档并跳转到ID对应的页面;若当前显示界面没有设置热点敏感帮助的页面ID,则显示软件帮助缺省的页面。IDH_WJH_0100000000为软件的缺省显示页面ID。 ( q7 A+ D3 t4 P) X# h8 _
二、CHM帮助文档的制作要求 - H2 R( Z* c. n' m4 @

) A; `# e* g+ xCHM帮助文档必须包含API文档信息,包含页面ID文件和ID对应页面名称申明二个文件,格式如下:
  I  J# B) K$ ?# G7 s/ f% ~0 a& O# q- ~) W( [2 A7 X
CHMHelpID.h 页面ID文件格式:& o) V+ ^6 E( o5 F
#define IDH_WJH_0000000000  0
! b5 \* b1 s+ T#define IDH_WJH_0100000000  100000000% S* A( u; e$ C) S: U6 W- e8 H
#define IDH_WJH_0100100000  100100000
/ g0 z# X# u5 P" `( R+ \, U#define IDH_WJH_0100101000  100101000& H1 g8 K+ H4 A

: j  `1 J+ v2 F' \AliasID.hID对应页面名称申明文件格式: IDH_WJH_0000000000 = 用户操作手册.Content\0000000000_操   作   手   册.Htm6 |: k9 `4 V6 N2 p+ s
IDH_WJH_0100000000 = 用户操作手册.Content\0100000000_第一部分 系统介绍.Htm: k% N8 ?; s( G: }% M! q
IDH_WJH_0100100000 = 用户操作手册.Content\0100100000_第一章 主要功能.Htm
$ F: c$ C" E0 K3 d* ^. CIDH_WJH_0100101000 = 用户操作手册.Content\0100101000_1、基本功能.Htm
  s& Q& L  k0 c& y3 RIDH_WJH_0100102000 = 用户操作手册.Content\0100102000_2、高级应用功能.Htm& F7 ]7 X+ k) x1 ?

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

本版积分规则

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

GMT+8, 2026-5-2 10:18 , Processed in 0.017850 second(s), 14 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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