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

软件热点敏感帮助的实现

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

' E  G  T  n; B/ {( z8 _一、软件中对CHM帮助文档的调用方法
/ H6 C1 _; P1 T9 l5 w- s$ N1 ^* E$ ~+ W; ]* {9 @  V: o
  VC中调用CHM帮助必须用API函数HtmlHelp(),此函数在LIB库函数内,为方便调用,我把它整体打包了,您要做的就是把它放到VC工程所在的目录,然后包含CHMHelp.h头文件即可。
  V! V: ?8 K; l1 h. n( y) M系统包含文件如下:
/ j+ A" `# J4 a: p/ E
" j( H9 P! d* M
  1. #include "CHMHelp.h"! E6 h  O' H, {- W9 g; j% e

  2. + W5 I1 o, E. D! C
  3. BOOL CDataDlg::OnInitDialog()
    - t) P: M$ K" {7 ?: w
  4. {
    5 y$ Q; x7 d' \" ^) P
  5.         CDialog::OnInitDialog();: d* d8 x2 Z' m# {
  6.         SetWindowContextHelpId(IDH_WJH_0300702025);
    ' H& C+ n% g" `  M- u
  7.         return TRUE;
    8 i5 d) h/ G9 m2 Y" h; X5 p
  8. }
复制代码
' J; r7 i+ c, z" E% q' k
  上述代码中IDH_WJH_0300702025为在CHMHelpID.h中定义的敏感帮助的页面ID,设置了ID后在需要显示帮助的过程中(一般是用户按F1)增加如下代码:
  1. BOOL CMainFrame::OnHelpInfo(HELPINFO* pHelpInfo) 3 S, n. |" f* u* a6 [3 E
  2. {: u0 \" w; |% `0 G: ^, x
  3.         HWND hWnd;
    / ]. _6 o7 g- j: R6 M8 V* p
  4.         if(pHelpInfo->dwContextId > 0) 1 P" d5 B7 ^/ _8 K
  5.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle,   D# W$ @# i& y( c+ ?5 `/ j* e
  6.                                         theApp.m_szHelpFile,
    ( o+ r8 p' P1 O: y0 S7 Z
  7.                                         HH_HELP_CONTEXT,
    " i0 `# H, p0 g6 }3 h7 J
  8.                                         pHelpInfo->dwContextId);6 o, m$ [# C* D
  9.         else * w4 X3 h( i2 |, W2 D
  10.                         hWnd = HtmlHelp((HWND)pHelpInfo->hItemHandle, 0 y: W6 c) f9 @9 o7 a0 I
  11.                                         theApp.m_szHelpFile, . u1 g- ?7 n; u& L( a3 H
  12.                                         HH_HELP_CONTEXT,
    & v' r2 l6 ]+ ]+ V2 Y& d
  13.                                         IDH_WJH_0100000000);
    , U  k( U- [& z+ Z: N

  14. 0 w4 Y8 T2 y- u
  15.         return (hWnd != NULL);+ c2 S  q9 D" z, _/ b$ n5 k
  16.         return CMDIFrameWnd::OnHelpInfo(pHelpInfo);
    8 V; {3 g& f# t* E1 R
  17. }
复制代码
3 K2 Y* u& g4 J
  上述代码即响应用户F1按键,若当前显示界面设置了热点敏感帮助的页面ID时,程序将打开CHM帮助文档并跳转到ID对应的页面;若当前显示界面没有设置热点敏感帮助的页面ID,则显示软件帮助缺省的页面。IDH_WJH_0100000000为软件的缺省显示页面ID。 9 R$ g( t0 i# u6 z0 R
二、CHM帮助文档的制作要求
: K7 u: J% p9 \; I. S" V( ^
  Q3 c$ `2 K9 i" S& l1 u0 e- r: dCHM帮助文档必须包含API文档信息,包含页面ID文件和ID对应页面名称申明二个文件,格式如下: 8 p& H8 e3 i/ l) n

" z- s7 q, n$ l% K4 ?* rCHMHelpID.h 页面ID文件格式:
1 ^9 r- s* Q' p9 M  [/ T$ D#define IDH_WJH_0000000000  0
/ B9 o* H# E+ z9 y#define IDH_WJH_0100000000  100000000/ f+ R' n; ^" J- o/ e  v5 ]9 ]. R
#define IDH_WJH_0100100000  1001000004 q/ j- y5 Z$ l! {( u" y9 z! W
#define IDH_WJH_0100101000  100101000
, H2 G/ C) l* O5 j& m# j/ P9 j7 y+ y0 b+ z
AliasID.hID对应页面名称申明文件格式: IDH_WJH_0000000000 = 用户操作手册.Content\0000000000_操   作   手   册.Htm3 j1 q& d0 u) ~) _9 s# d) t2 t/ q
IDH_WJH_0100000000 = 用户操作手册.Content\0100000000_第一部分 系统介绍.Htm/ b3 G6 `& u& }) F" j7 f% |. y
IDH_WJH_0100100000 = 用户操作手册.Content\0100100000_第一章 主要功能.Htm
# S( u) [. {* n# `( Q1 jIDH_WJH_0100101000 = 用户操作手册.Content\0100101000_1、基本功能.Htm7 f( w. ^) g$ ^- {  Y& ~
IDH_WJH_0100102000 = 用户操作手册.Content\0100102000_2、高级应用功能.Htm
5 P$ H0 q! h0 A
' r, _! `' w6 w& |5 Q. t0 J* i" F  编制好这两文件后,包含在HHP工程文件中,用HTML WORK SHOP进行编译就可以了。 现在网上也有很多软件可以按照WORD文档的章节自动生成上述文件,极大的方便了用户制作软件热点敏感帮助。现推荐一款制作CHM的软件:Word2CHM帮助文档制作工具,此软件自动将WORD文档按照章节转换成CHM文档,并自动生成上述两个文件。您需要做的就是按照第一节介绍的方法在VC下加入代码编译软件即可实现热点敏感帮助。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-11-15 02:58 , Processed in 0.019023 second(s), 14 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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