Menu

[r4406]: / branches / parsnip / Src / Browser.UUIMgr.pas  Maximize  Restore  History

Download this file

710 lines (663 with data), 28.5 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
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
{
* 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) 2005-2013, Peter Johnson (www.delphidabbler.com).
*
* $Rev$
* $Date$
*
* Contains class that implements IDocHostUIHandler interface and allows
* customisation of IE web browser control's user interface, message
* translation, pop-up menu, external object and drag-drop handling.
}
unit Browser.UUIMgr;
interface
uses
// Delphi
Classes, Windows, ActiveX, SHDocVw, Menus,
// Project
Browser.IntfDocHostUI, Browser.UNulUIHandler;
type
{
TWBTranslateEvent:
Type of event triggered when a key is pressed in the web browser control.
The program decides whether to handle (translate) the keypress itself or
allow the web browser to handle it.
@param Sender [in] Object triggering event.
@param Msg [in[ Windows message record identifying the message that
triggered the event. This may be zeroed if there was no such message.
@param CmdID [in] Browser command that normally occurs in response to the
event. This value may be zero if there is no related command.
@param Handled [in/out] False when the event handler is called. Set to
True if the handler program handles (translates) the keypress and leave
False to let the web browser handle it. Keypresses can be supressed by
setting Handled to true and doing nothing with the key press.
}
TWBTranslateEvent = procedure(Sender: TObject;
const Msg: TMSG; const CmdID: DWORD; var Handled: Boolean) of object;
{
TWBMenuPopupEvent:
Event called when browser wishes to display a popup menu. If a context menu
@param Sender [in] Object triggering event.
@param PopupPos [in] Position to display the menu.
@param MenuID [in] Type of menu to be displayed - this is one of the
CONTEXT_MENU_* values.
@param Handled [in/out] When called will be false to indicate no popup
menu is displayed. If a popup menu is displayed by the event handler
then Handled should be set to false to prevent any popup menu assigned
to the browser control's PopupMenu property from being displayed.
@param Obj [in] IDispatch interface to the selected object in the current
document when the menu was summoned. Cast this to IHTMLElement to get
information about the selected tag.
}
TWBMenuPopupEvent = procedure(Sender: TObject; PopupPos: TPoint;
const MenuID: DWORD; var Handled: Boolean; const Obj: IDispatch)
of object;
{
TWBUpdateCSSEvent:
Event called when browser control needs to get default CSS. Handler can
modify or set default CSS.
@param Sender [in] Reference to browser UI manager triggering event.
@param CSS [in/out] CSS code. Current value of CSS property passed in.
Handler can modify or replace this CSS code.
}
TWBUpdateCSSEvent = procedure(Sender: TObject; var CSS: string) of object;
{
TWBScrollbarStyle:
Styles for browser's scroll bars as determined by the manager class's
ScrollbarStyle property.
}
TWBScrollbarStyle = (
sbsNormal, // display scroll bars in normal (default) style
sbsFlat, // display flat scroll bars (in classic Windows UI)
sbsHide // hide the scroll bars
);
{
TWBUIMgr:
Class that manages a web browser object and modifies its behaviour according
to this class's properties and events. The class can be constructed either
as a stand alone class or as an aggregated object of a containing class.
The class supports the IDocHostUIHandler interface whose methods are called
by the browser when it needs to customise or update its UI. It also provides
public methods for modifying or interogating the browser control and the
currently displayed document.
}
TWBUIMgr = class(TNulUIHandler,
IInterface,
IDocHostUIHandler
)
strict private
fWebBrowser: TWebBrowser;
{Reference to managed web browser control}
fShow3dBorder: Boolean;
{Determines whether browsers displays 3D border}
fAllowTextSelection: Boolean;
{Determines whether text can be selected in browser}
fCSS: string;
{Records master cascading style sheet used by browser}
fExternScript: IDispatch;
{Reference to object that implement's browser "external" object}
fDropTarget: IDropTarget;
{Reference to drag drop handler for browser object}
fScrollbarStyle: TWBScrollbarStyle;
{Determines style of scroll bars}
fUseThemes: Boolean;
{Determines whether browser uses themes}
fOnTranslateAccel: TWBTranslateEvent;
{Handler for OnTranslateAccel event}
fOnMenuPopup: TWBMenuPopupEvent;
{Handler for OnMenuPopup event}
fOnUpdateCSS: TWBUpdateCSSEvent;
{Handler for OnUpdateCSS event}
fOnBrowserDeactivate: TNotifyEvent;
{Handler for OnBrowserDeactivate event}
fOnBrowserActivate: TNotifyEvent;
{Handler for OnBrowserActivate event}
fOldOnEnter: TNotifyEvent;
{Original event handler for browser's OnEnter event. Used to pass any such
event on to original handler before we handle it}
function GetSelectedText: string;
{Read accessor for SelectedText property. Gets selected text from
browser's current document.
@return Selected text or '' if none.
}
procedure BrowserEnter(Sender: TObject);
{Handler for browser's OnEnter event. Ensures that browser receives focus.
@param Sender [in] Reference to web browser object that triggered the
event. Passed to any previous event handler, otherwise not used.
}
function GetPopupMenu: TPopupMenu;
{Read accessor for PopupMenu property.
@return Reference to web browser's popup menu or nil if none assigned.
}
procedure SetPopupMenu(const Value: TPopupMenu);
{Write accessor for PopupMenu property.
@param Value [in] Reference to required popup menu or nil if no popup
menu required.
}
procedure DisplayPopupMenu(const Pt: TPoint; const MenuID: DWORD;
Elem: IDispatch);
{Displays web browser's pop-up menu if any.
@param Pt [in] Co-ordinates at which to display menu.
@param MenuID [in] Describes type of menu required.
@param Elem [in] HTML element for which menu is requested.
}
public
{ IDocHostUIHandler overrides }
function ShowContextMenu(const dwID: DWORD; const ppt: PPOINT;
const pcmdtReserved: IUnknown; const pdispReserved: IDispatch): HResult;
stdcall;
{Called by browser when about to display a context menu. We always handle
popup menu and never use IE's default menu. Whether menu is displayed
depends on if OnMenuPopup event is handled or if PopupMenu property is
set.
@param dwID [in] Specifies identifier of the shortcut menu to be
displayed.
@param ppt [in] Pointer screen coordinates for the menu.
@param pcmdtReserved [in] Not used.
@param pdispReserved [in] IDispatch interface of HTML object under
mouse.
@return S_OK to prevent IE displaying its default context menu.
}
function GetHostInfo(var pInfo: TDocHostUIInfo): HResult; stdcall;
{Called by browser to get UI capabilities. We configure the required UI
appearance per relevant property values.
@param pInfo [in/out] Reference to structure that we fill in to
configure appearance of browser.
@return S_OK to show we handled OK.
}
function ShowUI(const dwID: DWORD;
const pActiveObject: IOleInPlaceActiveObject;
const pCommandTarget: IOleCommandTarget; const pFrame: IOleInPlaceFrame;
const pDoc: IOleInPlaceUIWindow): HResult; stdcall;
{Called by browser when a document activates to enable the host to update
its UI. We trigger an OnBrowserActivate event.
@param dwID [in] Not used other than to pass to inherited method.
@param pActiveObject [in] Not used other than to pass to inherited
method.
@param pCommandTarget [in] Not used other than to pass to inherited
method.
@pFrame [in] Not used other than to pass to inherited method.
@param pDoc [in] Not used other than to pass to inherited method.
@return S_OK to show we displayed our own UI.
}
function HideUI: HResult; stdcall;
{Called by browser when a document deactivates to enable the host to
update its UI. We trigger an OnBrowserDeactivate event.
@return S_OK to indicate we handled successfully.
}
function TranslateAccelerator(const lpMsg: PMSG; const pguidCmdGroup: PGUID;
const nCmdID: DWORD): HResult; stdcall;
{Called by browser when a key press is received. We trigger
OnTranslateAccel event to filter out key presses not to be handled by
browser.
@param lpMsg [in] Pointer to structure that specifies message to be
translated.
@param pguidCmdGroup [in] Not used.
@param nCmdID [in] Command identifier.
@return S_OK to prevent IE handling message or S_FALSE to allow it.
}
function GetExternal(out ppDispatch: IDispatch): HResult; stdcall;
{Notifies browser control of reference to any object assigned to
ExternScript property that extends browser's "external" object.
@param ppDispatch [out] Set to IDispatch interface for "external" COM
object.
@return S_OK if successful, or an error value otherwise.
}
function GetDropTarget(const pDropTarget: IDropTarget;
out ppDropTarget: IDropTarget): HResult; stdcall;
{Notifies browser control of any drag drop handler object assigned to
DropTarget property.
@param pDropTarget [in] Not used other than to pass to inherited method.
@param ppDropTarget [out] Set to object assigned to DropTarget property.
@return E_FAIL if DropTarget is nil or S_OK if DropTarget is assigned.
}
public
constructor Create(const WebBrowser: TWebBrowser;
const Controller: IInterface = nil);
{Object constructor. Sets up the object (optionally as an aggregated
object).
@param WebBrowser [in] Reference to managed browser control. Must not be
nil.
@param Controller [in] IInterface of containing object if this object is
to be aggregated or nil if to be stand alone.
}
function CanCopy: Boolean;
{Checks if text can be copied from browser control to clipboard.
@return True if copying permitted, False otherwise.
}
procedure CopyToClipboard;
{Copies selected text from browser control to clipboard if operation
permitted.
}
function CanSelectAll: Boolean;
{Checks if all browser control's text can be selected.
@return True if text can be selected, False otherwise.
}
procedure SelectAll;
{Selects all text in browser control if operation is permitted.
}
procedure ClearSelection;
{Clears any selected text in browser control.
}
function DocHeight: Integer;
{Gets height of currently displayed document.
@return Required height in pixels.
}
function SupportsPopupMenu: Boolean;
{Checks if pop-up menu(s) are supported for browser control.
REMARKS: Checks if either PopupMenu or OnMenuPopup are assigned.
@returns True if pop-up menus are supported, False if not.
}
procedure ShowPopupMenu(const Pt: TPoint);
{Displays any supported pop-up menu for active HTML element displayed in
browser control, or for body element if no element active.
@param Pt [in] Co-ordinates at which menu is displayed.
}
property ScrollbarStyle: TWBScrollbarStyle
read fScrollbarStyle write fScrollbarStyle default sbsNormal;
{Determines style of browser control's scroll bars, or hides them. See
documentation for TWBScrollbarStyle for details}
property Show3dBorder: Boolean
read fShow3dBorder write fShow3dBorder default True;
{Flag that indicates whether browser control displays 3D borders}
property AllowTextSelection: Boolean
read fAllowTextSelection write fAllowTextSelection default True;
{Flag that indicates whether user can select text in browser control}
property UseThemes: Boolean
read fUseThemes write fUseThemes;
{Flag that indicates whether browser control should use UIthemes when it
is displaying widgets. This property is ignored if not running on Windows
XP or later or when running in classic style or when running on an IE
version earlier earlier than v6. The property defaults to true if themes
are enabled and false if they are not available or not enabled}
property CSS: string
read fCSS write fCSS;
{The default CSS to apply to documents displayed in browser control}
property SelectedText: string
read GetSelectedText;
{Provides the current text selection or '' if no text is selected in
browser control}
property ExternScript: IDispatch
read fExternScript write fExternScript;
{Object that extends the browser control's "external" object. This
object's methods can be called by scripts running in the browser's
current document}
property DropTarget: IDropTarget
read fDropTarget write fDropTarget;
{Object that handles drag/drop on behalf of the browser control. If this
property is nil browser's default drag drop handling is used}
property PopupMenu: TPopupMenu
read GetPopupMenu write SetPopupMenu;
{Reference to any popup menu assigned to browser control or nil if there
is no such menu assigned}
property OnTranslateAccel: TWBTranslateEvent
read fOnTranslateAccel write fOnTranslateAccel;
{Event triggered when browser control receives a key press. This enables
the program to determine whether the key press is handled by the browser
or by the program. See the documentation of TWBTranslateEvent for more
details}
property OnMenuPopup: TWBMenuPopupEvent
read fOnMenuPopup write fOnMenuPopup;
{Extended version of OnMenuPopup event triggered when the browser is ready
to display a popup menu. In addition to information made available in
OnMenuPopup the IDispatch interface of the object under the cursor when
the menu was summoned is made available. This event is only triggered if
OnMenuPopup has no event handler}
property OnUpdateCSS: TWBUpdateCSSEvent
read fOnUpdateCSS write fOnUpdateCSS;
{Event triggered when browser needs default CSS. Provides opportunity to
modify or replace code per CSS property}
property OnBrowserActivate: TNotifyEvent
read fOnBrowserActivate write fOnBrowserActivate;
{Event triggered when browser control is activated, either by user
clicking in it or tabbing into it}
property OnBrowserDeactivate: TNotifyEvent
read fOnBrowserDeactivate write fOnBrowserDeactivate;
{Event triggered when browser control is deactivated, either by user
clicking or tabbing away from it or control being hidden}
end;
implementation
uses
// Delphi
SysUtils,
// Project
Browser.UControlHelper, UHTMLDOMHelper, UThemesEx, UUrlMonEx;
function TaskAllocWideString(const S: string): PWChar;
{Allocates memory for a wide string using the Shell's task allocator and
copies a given string into the memory as a wide string. Caller is responsible
for freeing the buffer and must use the shell's allocator to do this.
@param S [in] String to convert.
@return Pointer to buffer containing wide string.
}
var
StrLen: Integer; // length of string in bytes
begin
// Store length of string, allowing for terminal #0
StrLen := Length(S) + 1;
// Allocate buffer for wide string using task allocator
Result := CoTaskMemAlloc(StrLen * SizeOf(WideChar));
if not Assigned(Result) then
raise EOutOfMemory.Create('TaskAllocWideString: can''t allocate buffer.');
// Convert string to wide string and store in buffer
StringToWideChar(S, Result, StrLen);
end;
{ TWBUIMgr }
procedure TWBUIMgr.BrowserEnter(Sender: TObject);
{Handler for browser's OnEnter event. Ensures that browser receives focus.
@param Sender [in] Reference to web browser object that triggered the event.
Passed to any previous event handler, otherwise not used.
}
begin
// Focus the <body> tag if it exists
THTMLDOMHelper.FocusElem(THTMLDOMHelper.GetBodyElem(fWebBrowser.Document));
// Pass event on to any original handler
if Assigned(fOldOnEnter) then
fOldOnEnter(Sender);
end;
function TWBUIMgr.CanCopy: Boolean;
{Checks if text can be copied from browser control to clipboard.
@return True if copying permitted, False otherwise.
}
begin
// Check that browser control supports copying and that some text is selected
Result := TWBControlHelper.IsCommandEnabled(fWebBrowser, OLECMDID_COPY)
and (SelectedText <> '');
end;
function TWBUIMgr.CanSelectAll: Boolean;
{Checks if all browser control's text can be selected.
@return True if text can be selected, False otherwise.
}
begin
// Check if browser supports text selection and text selection allowed
Result := TWBControlHelper.IsCommandEnabled(fWebBrowser, OLECMDID_SELECTALL)
and AllowTextSelection;
end;
procedure TWBUIMgr.ClearSelection;
{Clears any selected text in browser control.
}
begin
// Check if browser supports clearing selection and clear it if so
if TWBControlHelper.IsCommandEnabled(
fWebBrowser, OLECMDID_CLEARSELECTION
) then
TWBControlHelper.ExecCommand(fWebBrowser, OLECMDID_CLEARSELECTION);
end;
procedure TWBUIMgr.CopyToClipboard;
{Copies selected text from browser control to clipboard if operation
permitted.
}
begin
if CanCopy then
// Get browser control to copy its content to clipboard
TWBControlHelper.ExecCommand(fWebBrowser, OLECMDID_COPY);
end;
constructor TWBUIMgr.Create(const WebBrowser: TWebBrowser;
const Controller: IInterface = nil);
{Object constructor. Sets up the object (optionally as an aggregated object).
@param WebBrowser [in] Reference to managed browser control. Must not be
nil.
@param Controller [in] IInterface of containing object if this object is to
be aggregated or nil if to be stand alone.
}
begin
Assert(Assigned(WebBrowser), ClassName + '.Create: WebBrowser is nil');
inherited Create(Controller);
fWebBrowser := WebBrowser;
fScrollbarStyle := sbsNormal;
fShow3dBorder := True;
fAllowTextSelection := True;
fUseThemes := ThemeServicesEx.ThemesEnabled;
// Handler browser ctrl's OnEnter event to focus browser control
fOldOnEnter := fWebBrowser.OnEnter;
fWebBrowser.OnEnter := BrowserEnter;
end;
procedure TWBUIMgr.DisplayPopupMenu(const Pt: TPoint; const MenuID: DWORD;
Elem: IDispatch);
{Displays web browser's pop-up menu if any.
@param Pt [in] Co-ordinates at which to display menu.
@param MenuID [in] Describes type of menu required.
@param Elem [in] HTML element for which menu is requested.
}
var
Handled: Boolean; // flag indicating if OnPopupMenu event handled menu display
begin
// Assume event handler doesn't handle context menu
Handled := False;
// Try to trigger OnMenuPopup event. Handler sets Handled to True if it
// actually handles the event.
if Assigned(fOnMenuPopup) then
fOnMenuPopup(Self, Pt, MenuID, Handled, Elem);
if not Handled and Assigned(fWebBrowser.PopupMenu) then
// Event handlers didn't handle context menu: display any menu referenced by
// PopupMenu property.
fWebBrowser.PopupMenu.Popup(Pt.X, Pt.Y);
end;
function TWBUIMgr.DocHeight: Integer;
{Gets height of currently displayed document.
@return Required height in pixels.
}
begin
// Calculate height of HTML in browser control: this is height of <body> tag
Result := THTMLDOMHelper.GetScrollHeight(
THTMLDOMHelper.GetBodyElem(fWebBrowser.Document)
);
end;
function TWBUIMgr.GetDropTarget(const pDropTarget: IDropTarget;
out ppDropTarget: IDropTarget): HResult;
{Notifies browser control of any drag drop handler object assigned to
DropTarget property.
@param pDropTarget [in] Not used other than to pass to inherited method.
@param ppDropTarget [out] Set to object assigned to DropTarget property.
@return E_FAIL if DropTarget is nil or S_OK if DropTarget is assigned.
}
begin
if Assigned(fDropTarget) then
begin
// We are handling drag-drop: notify browser of drop target object to use
ppDropTarget := fDropTarget;
Result := S_OK;
end
else
// We are not handling drag-drop: use inherited default behaviour
Result := inherited GetDropTarget(pDropTarget, ppDropTarget);
end;
function TWBUIMgr.GetExternal(out ppDispatch: IDispatch): HResult;
{Notifies browser control of reference to any object assigned to ExternScript
property that extends browser's "external" object.
@param ppDispatch [out] Set to IDispatch interface for "external" COM
object.
@return S_OK if successful, or an error value otherwise.
}
begin
if Assigned(fExternScript) then
begin
// We have an external script object: notify browser
ppDispatch := fExternScript;
Result := S_OK; // indicates we've provided script
end
else
// We have no script object: use inherited default behviour
Result := inherited GetExternal(ppDispatch);
end;
function TWBUIMgr.GetHostInfo(var pInfo: TDocHostUIInfo): HResult;
{Called by browser to get UI capabilities. We configure the required UI
appearance per relevant property values.
@param pInfo [in/out] Reference to structure that we fill in to configure
appearance of browser.
@return S_OK to show we handled OK.
}
var
CSS: string; // CSS to pass to browser
begin
// Update flags depending on property values
pInfo.dwFlags := 0;
if fUseThemes and ThemeServicesEx.ThemesEnabled then
pInfo.dwFlags := pInfo.dwFlags or TDocHostUIFlag.THEME
else if ThemeServicesEx.ThemesAvailable then
pInfo.dwFlags := pInfo.dwFlags or TDocHostUIFlag.NOTHEME;
// scroll bar style
case fScrollbarStyle of
sbsHide:
// hide the scroll bars
pInfo.dwFlags := pInfo.dwFlags or TDocHostUIFlag.SCROLL_NO;
sbsFlat:
// use flat scroll bars (has effect in classic UI only)
pInfo.dwFlags := pInfo.dwFlags or TDocHostUIFlag.FLAT_SCROLLBAR;
sbsNormal:
// use standard scroll bars: this is default
{Do nothing};
end;
// 3d border
if not fShow3dBorder then
pInfo.dwFlags := pInfo.dwFlags or TDocHostUIFlag.NO3DBORDER;
// text selection
if not fAllowTextSelection then
pInfo.dwFlags := pInfo.dwFlags or TDocHostUIFlag.DIALOG;
// Record default style sheet if provided
CSS := fCSS;
if Assigned(fOnUpdateCSS) then
fOnUpdateCSS(Self, CSS);
if CSS <> '' then
pInfo.pchHostCss := TaskAllocWideString(CSS);
// Turn off the annoying click sound in browser control: it's not helpful in
// an application where interface does not appear to be a browser.
CoInternetSetFeatureEnabled(
FEATURE_DISABLE_NAVIGATION_SOUNDS, SET_FEATURE_ON_PROCESS, True
);
Result := S_OK;
end;
function TWBUIMgr.GetPopupMenu: TPopupMenu;
{Read accessor for PopupMenu property.
@return Reference to web browser's popup menu or nil if none assigned.
}
begin
Result := fWebBrowser.PopupMenu;
end;
function TWBUIMgr.GetSelectedText: string;
{Read accessor for SelectedText property. Gets selected text from browser's
current document.
@return Selected text or '' if none.
}
begin
Result := THTMLDOMHelper.GetTextSelection(fWebBrowser.Document);
end;
function TWBUIMgr.HideUI: HResult;
{Called by browser when a document deactivates to enable the host to update
its UI. We trigger an OnBrowserDeactivate event.
@return S_OK to indicate we handled successfully.
}
begin
Result := inherited HideUI;
if Assigned(fOnBrowserDeactivate) then
fOnBrowserDeactivate(Self);
end;
procedure TWBUIMgr.SelectAll;
{Selects all text in browser control if operation is permitted.
}
begin
if CanSelectAll then
// Get web browser to select all its text
TWBControlHelper.ExecCommand(fWebBrowser, OLECMDID_SELECTALL);
end;
procedure TWBUIMgr.SetPopupMenu(const Value: TPopupMenu);
{Write accessor for PopupMenu property.
@param Value [in] Reference to required popup menu or nil if no popup menu
required.
}
begin
fWebBrowser.PopupMenu := Value;
end;
function TWBUIMgr.ShowContextMenu(const dwID: DWORD; const ppt: PPOINT;
const pcmdtReserved: IInterface;
const pdispReserved: IDispatch): HResult;
{Called by browser when about to display a context menu. We always handle
popup menu and never use IE's default menu. Whether menu is displayed depends
on if OnMenuPopup event is handled or if PopupMenu property is set.
@param dwID [in] Specifies identifier of the shortcut menu to be displayed.
@param ppt [in] Pointer screen coordinates for the menu.
@param pcmdtReserved [in] Not used.
@param pdispReserved [in] IDispatch interface of HTML object under mouse.
@return S_OK to prevent IE displaying its default context menu.
}
begin
// Always returns S_OK to prevent IE showing own context menu
Result := S_OK;
DisplayPopupMenu(Point(ppt.X, ppt.Y), dwID, pDispReserved);
end;
procedure TWBUIMgr.ShowPopupMenu(const Pt: TPoint);
{Displays any supported default pop-up menu for displayed HTML document, if
any.
@param Pt [in] Co-ordinates at which menu is displayed.
}
var
BodyElem: IDispatch;
begin
BodyElem := THTMLDOMHelper.GetBodyElem(fWebBrowser.Document);
if not Assigned(BodyElem) then
Exit;
DisplayPopupMenu(Pt, TDocHostUIContextMenu.DEFAULT, BodyElem);
end;
function TWBUIMgr.ShowUI(const dwID: DWORD;
const pActiveObject: IOleInPlaceActiveObject;
const pCommandTarget: IOleCommandTarget; const pFrame: IOleInPlaceFrame;
const pDoc: IOleInPlaceUIWindow): HResult;
{Called by browser when a document activates to enable the host to update its
UI. We trigger an OnBrowserActivate event.
@param dwID [in] Not used other than to pass to inherited method.
@param pActiveObject [in] Not used other than to pass to inherited method.
@param pCommandTarget [in] Not used other than to pass to inherited method.
@pFrame [in] Not used other than to pass to inherited method.
@param pDoc [in] Not used other than to pass to inherited method.
@return S_OK to show we displayed our own UI.
}
begin
Result := inherited ShowUI(dwID, pActiveObject, pCommandTarget, pFrame, pDoc);
if Assigned(fOnBrowserActivate) then
fOnBrowserActivate(Self);
end;
function TWBUIMgr.SupportsPopupMenu: Boolean;
{Checks if pop-up menu(s) are supported for browser control.
REMARKS: Checks if either PopupMenu or OnMenuPopup are assigned.
@returns True if pop-up menus are supported, False if not.
}
begin
Result := Assigned(OnMenuPopup) or Assigned(PopupMenu);
end;
function TWBUIMgr.TranslateAccelerator(const lpMsg: PMSG;
const pguidCmdGroup: PGUID; const nCmdID: DWORD): HResult;
{Called by browser when a key press is received. We trigger OnTranslateAccel
event to filter out key presses not to be handled by browser.
@param lpMsg [in] Pointer to structure that specifies message to be
translated.
@param pguidCmdGroup [in] Not used.
@param nCmdID [in] Command identifier.
@return S_OK to prevent IE handling message or S_FALSE to allow it.
}
var
Handled: Boolean; // flag set true by event handler if it handles key
Msg: TMsg; // Windows message record for given message
begin
// Assume not handled by event handler
Handled := False;
// Call event handler if set
if Assigned(fOnTranslateAccel) then
begin
// create copy of message: set all fields zero if lpMsg is nil
if Assigned(lpMsg) then
Msg := lpMsg^
else
FillChar(Msg, SizeOf(Msg), 0);
// trigger event handler
fOnTranslateAccel(Self, Msg, nCmdID, Handled);
end;
// If event handler handled accelerator then return S_OK to stop web browser
// handling it otherwise return S_FALSE so browser will handle it
if Handled then
Result := S_OK
else
Result := S_FALSE;
end;
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.