Partilhar via


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.

Consulte também

Conceitos

Programando com a API UML

Como definir um comando de menu em um diagrama de modelagem