Como obter elementos de modelo UML de IDataObject
Quando o usuário arrasta elementos de qualquer fonte para um diagrama, os elementos arrastados são codificados em um System.Windows.Forms.IDataObject. A codificação depende do tipo de objeto de origem. O fragmento a seguir demonstra como recuperar os elementos quando a origem for um diagrama de UML.
Dica
A maioria das operações que você precisa fazer em modelos de UML podem ser executadas usando tipos definidos nos assemblies Microsoft.VisualStudio.Uml.Interfaces e Microsoft.VisualStudio.ArchitectureTools.Extensibility.Mas para isso, você precisa usar algumas classes que fazem parte da implementação de ferramentas de modelagem UML.Por exemplo, ShapeElement neste fragmento não é o mesmo que UML IShape.Para reduzir o risco de colocar o modelo e os diagramas UML em um estado inconsistente, é melhor evitar usar os métodos nessas classes de implementação, a não ser onde não haja nenhuma alternativa.
Exemplo de Código
Seu projeto deve referenciar os seguintes assemblies .NET:
Microsoft.VisualStudio.Modeling.Sdk.12.0
Microsoft.VisualStudio.Modeling.Sdk.Diagrams.12.0
System.Windows.Forms
using Microsoft.VisualStudio.Modeling;
// for ElementGroupPrototype
using Microsoft.VisualStudio.Modeling.Diagrams;
// for ShapeElement, DiagramDragEventArgs, DiagramPointEventArgs
…
/// <summary>
/// Retrieves UML IElements from drag arguments.
/// Works for drags from UML diagrams.
/// </summary>
private IEnumerable<IElement> GetModelElementsFromDragEvent
(DiagramDragEventArgs dragEvent)
{
//ElementGroupPrototype is the container for
//dragged and copied elements and toolbox items.
ElementGroupPrototype prototype =
dragEvent.Data.
GetData(typeof(ElementGroupPrototype))
as ElementGroupPrototype;
// Locate the originals in the implementation store.
IElementDirectory implementationDirectory =
dragEvent.DiagramClientView.Diagram.Store.ElementDirectory;
return prototype.ProtoElements.Select(
prototypeElement =>
{
ModelElement element = implementationDirectory
.FindElement(prototypeElement.ElementId);
ShapeElement shapeElement = element as ShapeElement;
if (shapeElement != null)
{
// Dragged from a diagram.
return shapeElement.ModelElement as IElement;
}
else
{
// Dragged from UML Model Explorer.
return element as IElement;
}
});
}
Para obter mais informações sobre ElementGroupPrototype e Store em que as ferramentas de modelagem UML são implementadas, consulte SDK de Modelagem para Visual Studio - linguagens específicas ao domínio.