ISpeechRecoGrammar CmdLoadFromResource Method

Microsoft Speech SDK

Intelligent Interface Technologies Home Page Microsoft Speech SDK

Speech Automation 5.1

Interface: ISpeechRecoGrammar

CmdLoadFromResource Method


The CmdLoadFromResource method loads a command and control grammar from a Win32 resource.


ISpeechRecoGrammar.CmdLoadFromResource(
     hModule As Long,
     ResourceName As Variant,
     ResourceType As Variant,
     LanguageId As Long,
     [LoadOption As SpeechLoadOption = SLOStatic]
)

Parameters

hModule
Specifies the hModule.
ResourceName
Specifies the ResourceName.
ResourceType
Specifies the ResourceType.
LanguageId
Specifies the LanguageId.
LoadOption
[Optional] Specifies whether the grammar is to be loaded for static or dynamic use. The default is static.

Return Value

None.


Remarks

The grammar resource must be a compiled SAPI 5 binary version of a context-free grammar (CFG).

Using this method will unload the currently loaded CFG or proprietary grammar.

Example

The following Visual Basic form code demonstrates the use of the CmdLoadFromResource method. Before attempting to run this code, you must:

  • Create a SpeechDocs.dll file as detailed in the Sample DLL Code Example, and
  • Make sure your microphone is connected and functional.

The Form_Load procedure creates a grammar object and loads it with the compiled Solitaire grammar contained in the DLL. There are no controls on this form; simply speak into your microphone. Phrases like "Move the red ten" or "Play the queen of hearts" will be recognized.


Option Explicit

Dim WithEvents C As SpSharedRecoContext
Dim G As ISpeechRecoGrammar
Dim hndRes As Long

' Change this constant to match the path 
' of the SpeechDocs DLL on your machine!

Const lib As String = "C:\SpeechDocs.dll"

Const resType As String = "CFGGRAMMAR"
Const resName  As Long = 101
Const langID As Long = &H409;

Private Declare Function LoadLibrary Lib "kernel32" Alias "LoadLibraryA" _
    (ByVal lpLibFileName As String) As Long

Private Sub Form_Load()
    Set C = New SpSharedRecoContext
    Set G = C.CreateGrammar
    
    ' Obtain a handle to the executable holding the grammar as a resource
    hndRes = LoadLibrary(lib)
    
    ' Load the grammar from the resource
    G.CmdLoadFromResource hndRes, resName, resType, langID, SLOStatic
    
    ' Set all DefaultToActive rules active
    ' NOTE: The solitaire grammar happens to have DefaultToActive rules
    ' which is why we can activate them this way.
    G.CmdSetRuleState "", SGDSActive

End Sub

Private Sub C_FalseRecognition( _
        ByVal StreamNumber As Long, _
        ByVal StreamPosition As Variant, _
        ByVal result As SpeechLib.ISpeechRecoResult _
    )
    MsgBox "(not recognized!)"
End Sub

Private Sub C_Recognition( _
        ByVal StreamNumber As Long, _
        ByVal StreamPosition As Variant, _
        ByVal RecognitionType As SpeechLib.SpeechRecognitionType, _
        ByVal result As SpeechLib.ISpeechRecoResult _
    )
    MsgBox result.PhraseInfo.GetText
End Sub