ContextLinkBase (Clase)
Actualización: noviembre 2007
Clase base de ContextLink. Representa una relación entre dos objetos ContextNodeBase que no es una relación primaria-secundaria.
Espacio de nombres: System.Windows.Ink.AnalysisCore
Ensamblado: IACore (en IACore.dll)
Sintaxis
'Declaración
Public Class ContextLinkBase
'Uso
Dim instance As ContextLinkBase
public class ContextLinkBase
public ref class ContextLinkBase
public class ContextLinkBase
public class ContextLinkBase
Comentarios
Entre los ejemplos de la relación que representa un objeto ContextLinkBase se incluyen:
Un nodo Paragraph rodeado por un nodo InkDrawing. Se crea un objeto ContextLinkBase y se agrega a las propiedades Links del nodo Paragraph y del nodo InkDrawing. SourceNode es el nodo InkDrawing y DestinationNode es el nodo Paragraph.
Un nodo AnalysisHint y un nodo WritingRegion. Cuando se usa un nodo AnalysisHint en el análisis de entrada manuscrita, se crea un objeto ContextLinkBase entre el nodo WritingRegion y el nodo AnalysisHint(). SourceNode es el nodo AnalysisHint y DestinationNode es el nodo WritingRegion.
Dos nodos InkDrawing entre los cuales se dibuja una línea, como en un diagrama de flujo.
Para determinar la relación entre SourceNode y DestinationNode, obtenga SemanticType mediante una llamada al método GetPropertyData.
Ejemplos
En el ejemplo siguiente se buscan todos los nodos que están vinculados al nodo ContextNodeBase, selectedNode. Si selectedNode no es un nodo de destino, el nodo de destino se agrega a un objeto ArrayList denominado destinationNodes. Si selectedNode no es un nodo de origen, se agrega a un objeto ArrayList denominado 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 un objeto InkAnalyzer denominado theInkAnalyzerWithHint. Los nodos que están vinculados a un objeto PropertyGuidsForAnalysisHintsBase con un valor Factoid de "IS_DATE_FULLDATE" se colocan en una colección ContextNodeCollection denominada writingRegionsWithFactoids.
Dim writingRegionsWithFactoids As _
New ContextNodeBaseCollection(Me.theInkAnalyzerWithHint)
Dim allWritingRegions As ContextNodeBaseCollection = _
Me.theInkAnalyzerWithHint.FindNodesOfType( _
ContextNodeTypeBase.WritingRegion)
Dim writingRegion As ContextNodeBase
For Each writingRegion In allWritingRegions
' See if they are linked to any factoid
Dim link As ContextLinkBase
For Each link In writingRegion.Links
If link.SourceNode.Type = ContextNodeType.AnalysisHint And _
link.SourceNode.ContainsPropertyData(PropertyGuidsForAnalysisHintsBase.Factoid) Then
If CType(link.SourceNode.GetPropertyData(PropertyGuidsForAnalysisHintsBase.Factoid), String) _
= "IS_DATE_FULLDATE" Then
writingRegionsWithFactoids.Add(writingRegion)
End If
End If
Next link
Next writingRegion
ContextNodeBaseCollection writingRegionsWithFactoids =
new ContextNodeBaseCollection(this.theInkAnalyzerBaseWithHint);
ContextNodeBaseCollection allWritingRegions =
this.theInkAnalyzerBaseWithHint.FindNodesOfType(
System.Windows.Ink.AnalysisCore.ContextNodeTypeBase.WritingRegion);
foreach (ContextNodeBase writingRegion in allWritingRegions)
{
// See if they are linked to any factoid
foreach (ContextLinkBase link in writingRegion.Links)
{
if (link.SourceNode.Type == ContextNodeTypeBase.AnalysisHint &&
link.SourceNode.ContainsPropertyData(PropertyGuidsForAnalysisHintsBase.Factoid))
{
if ((string) link.SourceNode.GetPropertyData(PropertyGuidsForAnalysisHintsBase.Factoid)
== "IS_DATE_FULLDATE")
{
writingRegionsWithFactoids.Add(writingRegion);
}
}
}
}
Jerarquía de herencia
System.Object
System.Windows.Ink.AnalysisCore.ContextLinkBase
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, Windows XP SP2, Windows Server 2003
.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