Menu

[r3700]: / branches / parsnip / Src / UHTMLHelpMgr.pas  Maximize  Restore  History

Download this file

132 lines (112 with data), 4.0 kB

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
{
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/
*
* Copyright (C) 2007-2012, Peter Johnson (www.delphidabbler.com).
*
* $Rev$
* $Date$
*
* Implements a class that implements the IHelpMgr interface and registers an
* instantiation of it as the program's help manager. The object provides help
* using the HTML help system.
}
unit UHTMLHelpMgr;
interface
implementation
uses
// Delphi
Windows,
// Project
UAppInfo, UEncodings, UHelpMgr;
type
{
THHAKLink:
Structure used to specify one or more ALink names or KLink keywords to be
searched for.
}
THHAKLink = packed record
cbStruct: Integer; // sizeof this structure
fReserved: BOOL; // must be FALSE (really!)
pszKeywords: LPCTSTR; // semi-colon separated keywords
pszUrl: LPCTSTR; // URL to jump to if no keywords found (may be nil)
pszMsgText: LPCTSTR; // MessageBox text on failure (used if pszUrl nil)
pszMsgTitle: LPCTSTR; // Title of any failure MessageBox
pszWindow: LPCTSTR; // Window to display pszURL in
fIndexOnFail: BOOL; // Displays index if keyword lookup fails.
end;
{
THTMLHelpMgr:
Class that interacts with and controls HTML Help and implements IHelpMgr.
}
THTMLHelpMgr = class(TInterfacedObject,
IHelpMgr
)
strict private
procedure DoAppHelp(const Command: UINT; const HelpPage: string;
const Data: DWORD);
{Calls HtmlHelp API with specified command and parameters.
@param Command [in] Command to send to HTML Help.
@param HelpPage [in] Name of HTML file containing required help page
within help file. May be '' if no specific page required.
@param Data [in] Data to pass to HTML Help. Format depends on command.
}
public
procedure ShowHelp(const AKeyword: string);
{Displays HTML help topic specified by an A-Link keyword.
@param AKeyword [in] Required A-Link keyword.
}
procedure ShowContents;
{Displays HTML help contents tab and default help page.
}
end;
{ THTMLHelpMgr }
procedure THTMLHelpMgr.DoAppHelp(const Command: UINT; const HelpPage: string;
const Data: DWORD);
{Calls HtmlHelp API with specified command and parameters.
@param Command [in] Command to send to HTML Help.
@param HelpPage [in] Name of HTML file containing required help page within
help file. May be '' if no specific page required.
@param Data [in] Data to pass to HTML Help. Format depends on command.
}
var
HelpSpec: string; // Help file followed by any required page
begin
HelpSpec := TAppInfo.HelpFileName;
if HelpPage <> '' then
HelpSpec := HelpSpec + '::/' + HelpPage;
HtmlHelp(GetDesktopWindow(), HelpSpec, Command, Data);
end;
procedure THTMLHelpMgr.ShowContents;
{Displays HTML help contents tab and default help page.
}
begin
DoAppHelp(HH_DISPLAY_TOC, '', 0);
end;
procedure THTMLHelpMgr.ShowHelp(const AKeyword: string);
{Displays HTML help topic specified by an A-Link keyword.
@param AKeyword [in] Required A-Link keyword.
}
var
ALink: THHAKLink; // structure containing details of A-Link
begin
ZeroMemory(@ALink, SizeOf(THHAKLink));
// Fill in A link structure
ALink.cbStruct := SizeOf(THHAKLink);
// *** NOTE:
// This one is weird: when using the Unicode API just casting the keyword to
// PChar causes HTML Help to see only the first character of the keyword. We
// have to cast to ASCII string and then to a pointer to get this to work,
// even though pszKeywords is declared as LPCTSTR which is defined as
// PWideChar.
ALink.pszKeywords := Pointer(StringToASCIIString(AKeyword));
ALink.fIndexOnFail := True;
// Display help
DoAppHelp(HH_ALINK_LOOKUP, '', DWORD(@ALink));
end;
initialization
// Create instance of help manager and register it for use as program's help
// system
RegisterHelpMgr(THTMLHelpMgr.Create);
end.
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.