Delphi7程序中上下文关联chm帮助的实现

王朝delphi·作者佚名  2006-01-31
窄屏简体版  字體: |||超大  

Delphi7程序中上下文关联chm帮助的实现

作者:李新 kelvinsdu@sina.com QQ:1348513

Chm格式的帮助是从windows98以后才出现的新的格式,与.hlp格式相比,具有更简单的编辑方式、更丰富的画面。它是通过Chm制作工具对网页文件进行编译得到的,所以理论上你可以把帮助文件做的和网页一样漂亮

最简单的制作方法:先用FronPage制作帮助文件,然后用HTML Help Workshop或者Visual CHM等软件编译得到*.chm的帮助文件了。HTML Help Workshop可以到微软的网站上去下载。

应用程序中的帮助可分为上下文关联和非关联两种。上下文关联,是指用户按F1键后,出现与当前焦点对象(如窗体、文本框、下拉列表框)相关的帮助画面;不同对象,出现的帮助不同。非关联帮助,是指在程序任何位置按F1键后,出现同一帮助画面。

在Delphi中实现上下文关联的chm帮助,可以通过调用Windows系统目录System32下的HHCTRL.OCX控件中的HtmlHelpA函数实现。 下面就以一个包含两个窗体的小例子,谈谈在Delphi7中实现上下文关联CHM帮助的方法。

该程序包含两个窗体,主窗体frmMain和弹出窗体dlgQuery。如下图所示

主窗体frmMain中包含一个Edit1和Memo1,查询对话框dlgQuery中包含一个Edit1和ComboBox1。将它们的HelpContext属性设为大于0的整数值。例如,主窗体frmMain.HelpContext=10100 ,其中的文本框 Edit1.HelpContext=10101, Memo1.HelpContext=10102;对话框dlgQuery.HelpContext=10200,其中 Edit1. HelpContext=10201,ComboBox1. HelpContext=10202。.

将所有窗体的KeyPreview属性设为True,响应窗体的键盘事件;然后,编写F1按键的响应代码,调用chm帮助文件中的页面。这样,在不同位置(不同对话框或者不同控件)按F1键,程序将弹出与其HelpContext相关的帮助页面。

相关实现代码如下:

1.声明Windows API函数HtmlHelpA

function HtmlHelpA (hwndcaller:Longint; lpHelpFile:string; wCommand:Longint;dwData:string): HWND;stdcall; external 'hhctrl.ocx'

2.定义调用chm帮助文件的公共函数

procedure ShowChmHelp(sTopic:string);

//公用函数ShowChmHelp,根据不同的参数显示不同帮助画面。

Const HH_DISPLAY_TOPIC=0;

var i:integer;

begin

i:=HtmlHelpA(Application.Handle,Pchar(ExtractFileDir(application.exename)

+'\help.chm'),HH_DISPLAY_TOPIC,sTopic);

if i=0 then

begin

Showmessage('help.chm 帮助文件不存在或者文件格式损坏!');

exit;

end;

end;

3.设置应用程序的Onhelp事件响应函数

procedure TfrmMain.FormCreate(Sender: TObject);

begin

application.OnHelp:=FormHelp;

end;

4. 设置所有窗体的OnHelp事件

function TfrmMain.FormHelp(Command: Word; Data: Integer; var CallHelp: Boolean): Boolean;

begin

case Data of

10100: ShowChmHelp('MainFunction.htm');

10101: ShowChmHelp('ProjectManager.htm');

10102: ShowChmHelp('FinanceInput.htm');

else ShowChmHelp('SystermIntroduction.htm');

end;

end;

function TdlgQuery.FormHelp(Command: Word; Data: Integer; var CallHelp: Boolean): Boolean;

begin

case Data of

10200: ShowChmHelp('QuickQuery.htm');

10201: ShowChmHelp('SuperQuery.htm');

else ShowChmHelp('SystermIntroduction.htm');

end;

end;

5. 所有窗体处理F1按键事件

procedure TfrmMain.FormKeyDown(Sender: TObject; var Key: Word; Shift: TShiftState);

begin

if key=VK_F1 then

begin

application.HelpCommand (HELP_CONTEXT,TControl(Self.ActiveControl).HelpContext);

end;

end;

procedure TdlgQuery.FormKeyDown(Sender: TObject; var Key: Word; Shift: TShiftState);

begin

if key=VK_F1 then

begin

application.HelpCommand (HELP_CONTEXT,TControl(Self.ActiveControl).HelpContext);

end;

end;

这样,通过设置相关属性和编写有关代码,就可以实现程序与chm格式帮助的关联。

以上介绍了delphi7应用程序与chm帮助关联的一种简单实现方法。如果要实现更复杂的关联(例如,与帮助页面内特定位置/书签的关联,请查看HtmlHelpA函数的说明。

Delphi5下实现上下文关联帮助比Delphi7下要简单,不需要编写窗体FormKeyDown相应F1的代码,请见《Delphi程序与Chm帮助关联的简单实现》(http://www.csdn.com.cn/program/880.htm)

如果需要例子程序的源代码,可直接与作者联系。kelvinsdu@sina.com

如果需要例子程序的源代码,可直接与作者联系。kelvinsdu@sina.com

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航