InkAnalyzer.InkAnalyzerStateChanging (Evento)
Actualización: noviembre 2007
Se produce antes de que el objeto InkAnalyzer concilie los resultados del análisis para que una aplicación pueda sincronizar los datos con el objeto InkAnalyzer.
Espacio de nombres: Microsoft.Ink
Ensamblado: Microsoft.Ink.Analysis (en Microsoft.Ink.Analysis.dll)
Sintaxis
'Declaración
Public Event InkAnalyzerStateChanging As InkAnalyzerStateChangingEventHandler
'Uso
Dim instance As InkAnalyzer
Dim handler As InkAnalyzerStateChangingEventHandler
AddHandler instance.InkAnalyzerStateChanging, handler
public event InkAnalyzerStateChangingEventHandler InkAnalyzerStateChanging
public:
event InkAnalyzerStateChangingEventHandler^ InkAnalyzerStateChanging {
void add (InkAnalyzerStateChangingEventHandler^ value);
void remove (InkAnalyzerStateChangingEventHandler^ value);
}
/** @event */
public void add_InkAnalyzerStateChanging (InkAnalyzerStateChangingEventHandler value)
/** @event */
public void remove_InkAnalyzerStateChanging (InkAnalyzerStateChangingEventHandler value)
JScript no admite eventos.
Comentarios
Utilice este evento cuando la aplicación mantenga su propia estructura de datos, que está sincronizada con la del objeto InkAnalyzer. Cuando el objeto InkAnalyzer provoca este evento, la aplicación debería rellenar la propiedad SubNodes de la propiedad RootNodedel objeto InkAnalyzer. Durante la fase de conciliación, el objeto InkAnalyzer utiliza esta información cuando analiza y realiza el reconocimiento de la entrada manuscrita.
El objeto InkAnalyzer provoca este evento después de provocar el evento ReadyToReconcile. Sólo provoca este evento mientras realiza el análisis en segundo plano.
Bloquea la estructura de datos cuando el analizador de entrada manuscrita desencadena el evento InkAnalyzerStateChanging. Los cambios que se produzcan en la estructura de datos durante esta fase de análisis pueden generar errores en el análisis y la sincronización de entrada manuscrita. Puede desbloquear la estructura de datos cuando el analizador de manuscrita provoca el evento IntermediateResultsUpdated o ResultsUpdated.
Para obtener más información sobre la sincronización de los datos de la aplicación con el objeto InkAnalyzer, vea Data Proxy with Ink Analysis.
Ejemplos
En este ejemplo se define un método, AttachDataProxyEventHandlers, que asocia los controladores de eventos del proxy de datos a un objeto InkAnalyzer, theInkAnalyzer.
Private Sub AttachDataProxyEventHandlers()
' If the document model supports on demand data proxy, then add an
' event handler for the PopulateContextNode event. This event is raised
' when the InkAnalyzer accesses a partially populated ContextNode created
' by the document model.
If Me.theDocumentModel.SupportsOnDemandDataProxy Then
AddHandler Me.theInkAnalyzer.PopulateContextNode, AddressOf Me.PopulateContextNode
End If
' Add the other data proxy related event handlers. These events are raised
' by the InkAnalyzer to communicate ink analysis results to the document model.
AddHandler Me.theInkAnalyzer.ContextNodeCreated, AddressOf Me.AddContextNode
AddHandler Me.theInkAnalyzer.ContextNodeDeleting, AddressOf Me.RemoveContextNode
AddHandler Me.theInkAnalyzer.ContextNodeLinkAdding, AddressOf Me.AddContextNodeLink
AddHandler Me.theInkAnalyzer.ContextNodeLinkDeleting, AddressOf Me.RemoveContextNodeLink
AddHandler Me.theInkAnalyzer.ContextNodeMovingToPosition, AddressOf Me.MoveContextNodeToPosition
AddHandler Me.theInkAnalyzer.ContextNodePropertiesUpdated, AddressOf Me.UpdateContextNodeProperties
AddHandler Me.theInkAnalyzer.ContextNodeReparenting, AddressOf Me.ReparentContextNode
AddHandler Me.theInkAnalyzer.InkAnalyzerStateChanging, AddressOf Me.InkAnalyzer_StateChanging
AddHandler Me.theInkAnalyzer.StrokesReparented, AddressOf Me.ReparentStroke
AddHandler Me.theInkAnalyzer.IntermediateResultsUpdated, AddressOf Me.ResultsAvailable
AddHandler Me.theInkAnalyzer.ResultsUpdated, AddressOf Me.ResultsAvailable
End Sub 'AttachDataProxyEventHandlers
private void AttachDataProxyEventHandlers()
{
// If the document model supports on demand data proxy, then add an
// event handler for the PopulateContextNode event. This event is raised
// when the InkAnalyzer accesses a partially populated ContextNode created
// by the document model.
if (this.theDocumentModel.SupportsOnDemandDataProxy)
{
this.theInkAnalyzer.PopulateContextNode +=
new Microsoft.Ink.PopulateContextNodeEventHandler(
this.PopulateContextNode);
}
// Add the other data proxy related event handlers. These events are raised
// by the InkAnalyzer to communicate ink analysis results to the document model.
this.theInkAnalyzer.ContextNodeCreated +=
new Microsoft.Ink.ContextNodeCreatedEventHandler(
this.AddContextNode);
this.theInkAnalyzer.ContextNodeDeleting +=
new Microsoft.Ink.ContextNodeDeletingEventHandler(
this.RemoveContextNode);
this.theInkAnalyzer.ContextNodeLinkAdding +=
new Microsoft.Ink.ContextNodeLinkAddingEventHandler(
this.AddContextNodeLink);
this.theInkAnalyzer.ContextNodeLinkDeleting +=
new Microsoft.Ink.ContextNodeLinkDeletingEventHandler(
this.RemoveContextNodeLink);
this.theInkAnalyzer.ContextNodeMovingToPosition +=
new Microsoft.Ink.ContextNodeMovingToPositionEventHandler(
this.MoveContextNodeToPosition);
this.theInkAnalyzer.ContextNodePropertiesUpdated +=
new Microsoft.Ink.ContextNodePropertiesUpdatedEventHandler(
this.UpdateContextNodeProperties);
this.theInkAnalyzer.ContextNodeReparenting +=
new Microsoft.Ink.ContextNodeReparentingEventHandler(
this.ReparentContextNode);
this.theInkAnalyzer.InkAnalyzerStateChanging +=
new Microsoft.Ink.InkAnalyzerStateChangingEventHandler(
this.InkAnalyzer_StateChanging);
this.theInkAnalyzer.StrokesReparented +=
new Microsoft.Ink.StrokesReparentedEventHandler(
this.ReparentStrokes);
this.theInkAnalyzer.IntermediateResultsUpdated +=
new Microsoft.Ink.ResultsUpdatedEventHandler(
this.ResultsAvailable);
this.theInkAnalyzer.ResultsUpdated +=
new Microsoft.Ink.ResultsUpdatedEventHandler(
this.ResultsAvailable);
}
En el ejemplo siguiente se define el método, InkAnalyzer_StateChanging, que controla el evento InkAnalyzerStateChanging. La información del evento se pasa al objeto del modelo de documento, theDocumentModel.
En este ejemplo no se proporciona la definición del modelo de documento ni se muestra cómo procesa la información que se le pasa.
'/ <summary>
'/ Handles the InkAnalyzer.InkAnalyzerStateChanging event.
'/ </summary>
'/ <param name="sender">The source of the event.</param>
'/ <param name="e">The event data.</param>
Private Sub InkAnalyzer_StateChanging( _
ByVal sender As Object, _
ByVal e As System.EventArgs)
Me.theDocumentModel.BeginReconcilePhase()
End Sub 'InkAnalyzer_StateChanging
/// <summary>
/// Handles the InkAnalyzer.InkAnalyzerStateChanging event.
/// </summary>
/// <param name="sender">The source of the event.</param>
/// <param name="e">The event data.</param>
private void InkAnalyzer_StateChanging(object sender, System.EventArgs e)
{
this.theDocumentModel.BeginReconcilePhase();
}
Plataformas
Windows Vista
.NET Framework y .NET Compact Framework no admiten todas las versiones de cada plataforma. Para obtener una lista de las versiones compatibles, vea Requisitos de sistema de .NET Framework.
Información de versión
.NET Framework
Compatible con: 3.0
Vea también
Referencia
Microsoft.Ink (Espacio de nombres)
InkAnalyzer.IntermediateResultsUpdated