onreco Event
Occurs when the recognizer has a recognition result available for the browser.
HTML | <listen onreco="recoHandler()" |
Scripting | listen.onreco = recoHandler; |
Named Script | <SCRIPT FOR = listen EVENT = onreco> |
Remarks
For recognition in the automatic mode, the onreco event stops the recognition process automatically and clears resources. The onreco event is typically used for programmatic analysis of the recognition result and processing of the result into the page.
The client-side onreco event occurs when user speech matches any active grammar rule or element. The client-side onnoreco event occurs only when all active grammar rules and elements fail to produce a match. Recognition of a single phrase in an utterance, such as "yes" or "no", triggers the onreco event, even if the rest of the utterance is unrecognizable.
Although the event handler does not receive properties directly, it can query the listen element for status and results information. Status information is contained in the status property while the text property and the recoresult property contain results information.
The onreco event does not support event bubbling or propagation.
Example
The following code demonstrates the use of the onreco event. Click the button to start the recognition. Speak a city name from the list of available cities. A successful recognition displays the Semantic Markup Language (SML) result. An unsuccessful recognition displays verification of the onnoreco event. Errors are not handled.
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html xmlns:salt="http://www.saltforum.org/2002/SALT">
<head>
<object id="Speechtags" CLASSID="clsid:DCF68E5B-84A1-4047-98A4-0A72276D19CC" VIEWASTEXT></object>
</head>
<body>
<?import namespace="salt" implementation="#Speechtags" />
<salt:listen id="listen1" mode="multiple" reject=".65" onreco="Handleonreco()" onnoreco="Handleonnoreco()">
<salt:grammar name="cities">
<grammar version="1.0" tag-format="semantics-ms/1.0" lang="en-US"
xmlns="http://www.w3.org/2001/06/grammar" root="root">
<rule id="root">
<item repeat="0-1">from </item>
<ruleref uri="#cities" />
</rule>
<rule id="cities">
<one-of>
<item>Seattle</item>
<item>Boston</item>
<item>Houston</item>
<item>New York</item>
</one-of>
</rule>
</grammar>
</salt:grammar>
</salt:listen>
<input type="button" name="BtnListen" value="Start Listening" OnClick="StartListening()" id="StartListen">
<input type="button" name="BtnStop" value="Stop" OnClick="StopListening()" id="StopListen"
<br><br>
This is an example of an automatic mode listen.<br>
Click Start to begin; after speaking, the application will automatically stop.<br>
Valid city names for recognition are Seattle, Boston, Houston, and New York.
<br><br>
<input type="text" name="TxtStatus" size = "80" value="Listening for test" id="RecoTxt">
<script language="JScript">
<!--
function StartListening() {
RecoTxt.value = "Starting to listen...";
listen1.Start();
RecoTxt.value = "Listening...";
}
function StopListening() {
RecoTxt.value = "Stopped listen";
listen1.Stop();
}
function Handleonreco() {
RecoTxt.value = "Received onreco.";
smlResult = event.srcElement.recoresult;
RecoTxt.value = smlResult.xml;
}
function Handleonnoreco() {
RecoTxt.value = "Received onnoreco";
}
-->
</script>
</body>
</html>
See Also
listen Element | onnoreco Event Property | recoresult Property | status Property | text Property