ContextLink (Clase)
Actualización: noviembre 2007
Representa una relación entre dos objetos ContextNode que no es una relación primaria-secundaria.
Espacio de nombres: Microsoft.Ink
Ensamblado: Microsoft.Ink.Analysis (en Microsoft.Ink.Analysis.dll)
Sintaxis
'Declaración
Public Class ContextLink
'Uso
Dim instance As ContextLink
public class ContextLink
public ref class ContextLink
public class ContextLink
public class ContextLink
Comentarios
Entre los ejemplos de la relación que representa una relación ContextLink se incluyen:
Un nodo ParagraphNode rodeado por un nodo InkDrawingNode. Se crea un objeto ContextLink y se agrega a las propiedades Links de ParagraphNode y de InkDrawingNode. SourceNode tiene el valor InkDrawingNode y DestinationNode es ParagraphNode.
AnalysisHintNode y WritingRegionNode. Cuando se usa AnalysisHintNode en el análisis de entrada manuscrita, ContextLink se crea entre WritingRegionNode y AnalysisHintNode. SourceNode tiene el valor AnalysisHintNode y DestinationNode es WritingRegionNode.
Dos objetos InkDrawingNode donde se dibuja una línea entre ellos, como en un diagrama de flujo.
Para determinar la relación entre SourceNode y DestinationNode se usa propiedad WritingRegionNode.SemanticType o InkDrawingNode.SemanticType en el nodo adecuado.
Ejemplos
En el ejemplo siguiente se buscan todos los nodos que están vinculados al nodo ContextNode, selectedNode. Si selectedNode no es un nodo de destino, el nodo de destino se agrega a un objeto ArrayList, destinationNodes. Si selectedNode no es un nodo de origen, se agrega a ArrayList, sourceNodes.
Dim destinationNodes As ArrayList = New ArrayList()
Dim sourceNodes As ArrayList = New ArrayList()
' Find all the nodes that link to the currently selected node.
For Each link As Microsoft.Ink.ContextLink In selectedNode.Links
If link.DestinationNode <> selectedNode Then
destinationNodes.Add(link.DestinationNode)
End If
If link.SourceNode <> selectedNode Then
sourceNodes.Add(link.SourceNode)
End If
Next
ArrayList destinationNodes = new ArrayList();
ArrayList sourceNodes = new ArrayList();
// Find all the nodes that link to the currently selected node.
foreach (Microsoft.Ink.ContextLink link in selectedNode.Links)
{
if (link.DestinationNode != selectedNode)
{
destinationNodes.Add(link.DestinationNode);
}
if (link.SourceNode != selectedNode)
{
sourceNodes.Add(link.SourceNode);
}
}
En el ejemplo siguiente se buscan todos los objetos WritingRegionNode en el árbol de nodos de InkAnalyzer, theInkAnalyzerWithHint.. Después pone los que estén vinculados a AnalysisHintNode con Factoid de "IS_DATE_FULLDATE" en ContextNodeCollection, writingRegionsWithFactoids.
Dim writingRegionsWithFactoids As _
New ContextNodeCollection(Me.theInkAnalyzerWithHint)
Dim allWritingRegions As ContextNodeCollection = _
Me.theInkAnalyzerWithHint.FindNodesOfType( _
Microsoft.Ink.ContextNodeType.WritingRegion)
Dim writingRegion As WritingRegionNode
For Each writingRegion In allWritingRegions
' See if they are linked to any factoid
Dim link As ContextLink
For Each link In writingRegion.Links
If link.SourceNode.Type = ContextNodeType.AnalysisHint Then
Dim hint As AnalysisHintNode = _
CType(link.SourceNode, AnalysisHintNode)
If hint.Factoid = "IS_DATE_FULLDATE" Then
writingRegionsWithFactoids.Add(writingRegion)
End If
End If
Next link
Next writingRegion
ContextNodeCollection writingRegionsWithFactoids =
new ContextNodeCollection(this.theInkAnalyzerWithHint);
ContextNodeCollection allWritingRegions =
this.theInkAnalyzerWithHint.FindNodesOfType(Microsoft.Ink.ContextNodeType.WritingRegion);
foreach (WritingRegionNode writingRegion in allWritingRegions)
{
// See if they are linked to any factoid
foreach (ContextLink link in writingRegion.Links)
{
if (link.SourceNode.Type == ContextNodeType.AnalysisHint)
{
AnalysisHintNode hint = (AnalysisHintNode) link.SourceNode;
if (hint.Factoid == "IS_DATE_FULLDATE")
{
writingRegionsWithFactoids.Add(writingRegion);
}
}
}
}
Jerarquía de herencia
System.Object
Microsoft.Ink.ContextLink
Seguridad para subprocesos
Todos los miembros static (Shared en Visual Basic) públicos de este tipo son seguros para la ejecución de subprocesos. No se garantiza que los miembros de instancias sean seguros para la ejecución de subprocesos.
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)