Menu

[r3136]: / branches / 3.x / Src / UHTMLHelpMgr.pas  Maximize  Restore  History

Download this file

136 lines (117 with data), 4.1 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
131
132
133
134
{
* UHTMLHelpMgr.pas
*
* 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.
*
* $Rev$
* $Date$
*
* ***** BEGIN LICENSE BLOCK *****
*
* Version: MPL 1.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
* the specific language governing rights and limitations under the License.
*
* The Original Code is UHelpMgr.pas
*
* The Initial Developer of the Original Code is Peter Johnson
* (http://www.delphidabbler.com/).
*
* Portions created by the Initial Developer are Copyright (C) 2007-2010 Peter
* Johnson. All Rights Reserved.
*
* Contributor(s)
* NONE
*
* ***** END LICENSE BLOCK *****
}
unit UHTMLHelpMgr;
interface
implementation
uses
// Delphi
Windows,
// Project
UAppInfo, UEncodings, UHTMLHelp, UHelpMgr;
type
{
THTMLHelpMgr:
Class that interacts with and controls HTML Help and implements IHelpMgr.
}
THTMLHelpMgr = class(TInterfacedObject,
IHelpMgr
)
strict private
procedure DoAppHelp(const Command: LongWord; const HelpPage: string;
const Data: LongWord);
{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: LongWord;
const HelpPage: string; const Data: LongWord);
{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(), PChar(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 PWideChar
ALink.pszKeywords := Pointer(StringToASCIIString(AKeyword));
ALink.fIndexOnFail := True;
// Display help
DoAppHelp(HH_ALINK_LOOKUP, '', LongWord(@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.