Compartilhar via


ISpTokenUI::DisplayUI (Windows Embedded CE 6.0)

1/6/2010

This method displays the UI associated with an object token. A call to this method is synchronous. Thus the method does not return until the UI has been closed.

The best practice implementation practice is to call ISpTokenUI::IsUISupported with a specific UI type before calling ISpTokenUI::DisplayUI.

Syntax

[local] HRESULT DisplayUI(
  HWND hwndParent,
  const WCHAR* pszTitle,
  const WCHAR* pszTypeOfUI,
  void* pvExtraData,
  ULONG cbExtraData,
  ISpObjectToken* pToken,
  IUnknown* punkObject
);

Parameters

  • hwndParent
    [in] Handle to the parent window.
  • pszTitle
    [in] Pointer to a null-terminated string specifying the window title to display on the UI. This value can be set to NULL to indicate that the object implementing ISpTokenUI should use its default window title.
  • pszTypeOfUI
    [in] Pointer to a null-terminated string specifying the type of UI to display.
  • pvExtraData
    [in] Pointer to additional information needed for the object token. The implementation of ISpTokenUI dictates the format and use of the data provided.
  • cbExtraData
    [in] Size, in bytes, of the data provided in pvExtraData.
  • pToken
    [in] Pointer to an object implementing ISpObjectToken that represents the object token. See the Remarks section.
  • punkObject
    [in] Pointer to IUnknown. See the Remarks section.

Return Value

The following table shows the possible return values.

Value Description

S_OK

Function completed successfully.

S_FALSE

The UI is supported but not with the current run-time environment or parameters.

E_INVALIDARG

One or more arguments are invalid.

E_POINTER

Invalid or bad pointer.

FAILED(hr)

Error returned by UI object.

Remarks

When an object token is requested to display a particular piece of UI, the object implementing ISpObjectToken can require extra functionality that only it understands. For example, a request to display the speech recognition training UI requires the use of a specific SR engine.

Common implementation practice for accessing extra token functionality is to call QueryInterface for the object token, or directly create a known object implementing ISpObjectToken. If QueryInterface must be called, the caller of ISpTokenUI::DisplayUI can set punkObject with the necessary IUnknown interface. If the object token is known, the caller sets the pToken parameter with a pointer to the required ISpObjectToken interface.

Example

The following code snippet illustrates the use of this method using the UI type SPDUI_AudioVolume.

HRESULT hr = S_OK;
// get the default input audio object token
hr = SpGetDefaultTokenFromCategoryId(SPCAT_AUDIOIN, &cpObjectToken);
// Check hr
// get the object token's UI
hr = cpObjectToken->QueryInterface(&cpTokenUI);
// Check hr
// Check if default audio input object has UI for volume
hr = cpTokenUI->IsUISupported(SPDUI_AudioVolume, NULL, NULL, NULL,
&fSupported);
    // Check hr
// if fSupported == TRUE, then default audio input object has UI for 
Volume
// Display the default audio input object's Volume UI 
hr = cpTokenUI->DisplayUI(MY_HWND, MY_AUDIO_DIALOG_TITLE, 
SPDUI_AudioVolume, NULL, NULL, cpObjectToken, NULL);
// Check hr

Requirements

Header sapiddk.h, sapiddk.idl
Library sapilib.lib
Windows Embedded CE Windows CE .NET 4.1 and later

See Also

Reference

ISpTokenUI
SAPI Interfaces