Aggiungi, recupera, copia e leggi Visio Shape Data
Aggiunta di una nuova forma in Visio
Aspose.Diagram for .NET consente di manipolare i diagrammi Microsoft Visio in diversi modi. Una delle cose che puoi fare è aggiungere nuove forme a un diagramma. Aspose.Diagram for .NET consente di aggiungere una nuova forma a un diagram. La forma aggiunta può anche essere personalizzata utilizzando Aspose.Diagram for .NET.
Questo argomento descrive come aggiungere una nuova forma rettangolare a un diagram.
Utilizzare Aspose.Diagram for .NET API per creare nuove forme e quindi aggiungere queste forme a una raccolta di forme di diagram.
Per aggiungere una nuova forma:
- Trova la pagina - Ogni Visio diagram contiene una raccolta di pagine. Gli sviluppatori possono recuperare l’ID o il nome pagina per pagina e memorizzare la pagina richiesta nel filePaginaoggetto di classe.
- Aggiungi il Master di una forma richiesto - Ogni Visio diagram contiene una raccolta di maestri. Gli sviluppatori possono aggiungere un master (per ID o nome) dal file stencil esistente (per percorso diretto o flusso di file).
- Aggiungi forma nel Visio diagram - Gli sviluppatori possono inserire una nuova forma in Visio diagram per indice della pagina (a partire da 0), nome principale, PinX, PinY, altezza (opzionale) e larghezza (opzionale).
- Imposta le proprietà della forma - Il metodo AddShape della classe Diagram restituisce l’ID della forma. Gli sviluppatori possono recuperare la forma da un Visio diagram utilizzando questo ID e quindi impostarne le proprietà, ad esempio colore, posizione, allineamento e testo.
L’ingresso diagram |
Lo diagram con una forma aggiunta |
---|
Aggiungi esempio di programmazione
Lo snippet di codice seguente mostra come eseguire ogni passaggio.
Recupero delle informazioni sulla forma
Lavorare con i diagrammispiega come creare diagrammi, aggiungere forme e connettori, quindi come recuperare informazioni su diagram elementi comepagine, maestri, connettori ecaratteri. Questo articolo esamina come recuperare informazioni sulle forme in un diagram.
Ogni forma in uno diagram ha un ID e un nome. L’ID è importante quando si programma con Visio: è il metodo principale per accedere ad una forma. Ogni forma conserva anche informazioni su quale master (stencil) è composta.
UNForma è un oggetto in un disegno Visio. La proprietà Shapes, esposta dalla classe Page, supporta una raccolta di oggetti Aspose.Diagram.Shape. La proprietà Shapes può essere utilizzata per recuperare informazioni su una forma.
Nella finestra della console sottostante, ad esempio, è possibile visualizzare l’output delle informazioni per un diagram che conteneva quattro forme: due terminatori, un processo e un connettore dinamico. Ognuno ha un ID univoco e il nome della forma principale (stencil).
Una finestra della console che mostra le informazioni sulla forma |
---|
Per recuperare le informazioni sulla pagina Visio: |
- Carica un diagram.
- Imposta un ciclo foreach per scorrere tutte le forme in diagram.
- Visualizza le informazioni sulla forma.
Recupera esempio di programmazione
Il seguente pezzo di codice recupera le informazioni sulla forma da un Visio diagram.
Copia forme da un Visio esistente
Aspose.Diagram for .NET API consente agli sviluppatori di copiare le forme dalla pagina Visio di origine alla nuova pagina Visio diagram. Supporta anche la copia di forme di gruppo. Questo articolo descrive come copiare tutte le forme dalla pagina diagram di origine.
Per copiare le forme, gli sviluppatori devono anche copiare i temi PageSheet e Visio di origine per conservare lo stile di riempimento delle forme e altre proprietà di formattazione.
Questo esempio funziona come segue:
- Carica una fonte Visio.
- Inizializza un nuovo Visio
- Aggiungi master e temi dalla fonte Visio.
- Ottieni la pagina dalla fonte Visio.
- Copia il suo foglio di pagina nella nuova pagina Visio.
- Scorri le forme della pagina Visio di origine.
- Imposta il suo nuovo ID e aggiungilo alla nuova pagina Visio.
- Salva il nuovo Visio nella memoria locale.
Copia esempio di programmazione
Copia una forma Visio in un’altra istanza di forma
Il metodo Copy della classe Shape accetta un’istanza di forma da clonare.
// import diagram
Diagram diagram = new Diagram(dataDir + "Drawing1.vsdx");
Shape newShape = new Shape();
// copy diagram
newShape.Copy(diagram.Pages[0].Shapes[0]);
newShape.ID = 3;
newShape.XForm.PinX.Value = 1;
newShape.XForm.PinY.Value = 1;
Lettura dei dati di forma Visio
La collezione Props esposta dalForma la classe supporta ilAspose.Diagram.Prop oggetto. La proprietà può essere utilizzata per leggere i dati di una forma (proprietà personalizzate).
Leggi tutte le proprietà della forma
Per identificare le proprietà personalizzate in Microsoft Visio:
- In un diagram, fare clic con il pulsante destro del mouse su una forma.
- SelezionareDati , poiDati di forma dal menù. Tutte le proprietà esistenti sono elencate nella finestra di dialogo.
I dati di una forma, come si vede in Microsoft Visio. | ** |
---|---|
Una finestra della console che mostra l’output dei dati della forma. | ** |
---|---|
Leggi l’esempio di programmazione
I frammenti di codice seguenti leggono i dati della forma (proprietà personalizzate).
Leggere una proprietà Shape per nome
Il frammento di codice seguente legge una proprietà di forma per nome (proprietà personalizzata).
Leggere per nome Esempio di programmazione
Leggi InheritProps of Shape
Il frammento di codice seguente legge InheritProps di una forma.
Aggiungi e collega Visio Forme
Aspose.Diagram for .NET consente di aggiungere forme personalizzate e collegarle indiagrammi che crei.
Aggiunta e connessione di forme
Il codice negli esempi seguenti mostra come:
- Crea uno diagram.
- Aggiungi e personalizza forme (rettangolo, stella, esagono).
- Collega le forme stella ed esagono al rettangolo.
- Salva lo diagram.
Esempio di programmazione di aggiunta e connessione di forme
Usa gli indici di connessione per connettere le forme
Aspose.Diagram for .NET API consente già agli sviluppatori di aggiungere nuovi punti di connessione sulla forma e gli sviluppatori possono ora collegare le forme utilizzando gli indici di connessione.
Usa gli indici di connessione per connettere le forme
Il membro ConnectShapesViaConnectorIndex esposto daPaginaclass può essere utilizzata per connettere forme utilizzando gli indici di connessione. Il codice seguente mostra come connettere le forme:
- Inizializza un nuovo disegno.
- Posiziona quattro forme rettangolari
- Aggiungi due punti di connessione aggiuntivi, in modo che ci siano tre punti di connessione sulla linea di confine inferiore
- Collega la prima forma da ciascuna connessione inferiore ad altre tre forme rettangolari dall’alto con connettori dinamici
- Salva disegno
Utilizzare gli indici di connessione per connettere le forme Esempio di programmazione
Utilizzare il codice seguente nell’applicazione .NET per connettere le forme utilizzando gli indici di connessione con Aspose.Diagram for .NET API.
C#
// initialize a new drawing
Diagram diagram = new Diagram();
// get page by index
Aspose.Diagram.Page page = diagram.Pages[0];
// add masters
string connectorMaster = "Dynamic connector", rectangle = "Rectangle";
int pageNumber = 0;
double width = 2, height = 2, pinX = 4.25, pinY = 9.5;
diagram.AddMaster(@"C:\temp\Basic Shapes.vss", rectangle);
diagram.AddMaster(@"C:\temp\Basic Shapes.vss", connectorMaster);
// add shapes
long shape1_ID = diagram.AddShape(4.5, 7, rectangle, pageNumber);
long shape2_ID = diagram.AddShape(2.25, 4.5, rectangle, pageNumber);
long shape3_ID = diagram.AddShape(4.5, 4.5, rectangle, pageNumber);
long shape4_ID = diagram.AddShape(6.75, 4.5, rectangle, pageNumber);
// get shapes by ID
Aspose.Diagram.Shape shape1 = page.Shapes.GetShape(shape1_ID);
Aspose.Diagram.Shape shape2 = page.Shapes.GetShape(shape2_ID);
Aspose.Diagram.Shape shape3 = page.Shapes.GetShape(shape3_ID);
Aspose.Diagram.Shape shape4 = page.Shapes.GetShape(shape4_ID);
// add two more connection points
Connection connection1 = new Connection();
connection1.X.Ufe.F = "Width*0.33";
connection1.Y.Ufe.F = "Height*0";
Connection connection3 = new Connection();
connection3.X.Ufe.F = "Width*0.66";
connection3.Y.Ufe.F = "Height*0";
shape1.Connections.Add(connection1);
shape1.Connections.Add(connection3);
// add connector shapes
Aspose.Diagram.Shape connector1 = new Aspose.Diagram.Shape();
Aspose.Diagram.Shape connector2 = new Aspose.Diagram.Shape();
Aspose.Diagram.Shape connector3 = new Aspose.Diagram.Shape();
long connecter1Id = diagram.AddShape(connector1, connectorMaster, 0);
long connecter2Id = diagram.AddShape(connector2, connectorMaster, 0);
long connecter3Id = diagram.AddShape(connector3, connectorMaster, 0);
// connect shapes by index of conneecting points
page.ConnectShapesViaConnectorIndex(shape1.ID, 6, shape2.ID, 3, connecter1Id);
page.ConnectShapesViaConnectorIndex(shape1.ID, 1, shape3.ID, 3, connecter2Id);
page.ConnectShapesViaConnectorIndex(shape1.ID, 7, shape4.ID, 3, connecter3Id);
// save drawing
diagram.Save(@"C:\temp\Drawing1_out.vsdx", SaveFileFormat.VSDX);
Recupera la forma padre di una forma secondaria
Aspose.Diagram for .NET consente agli sviluppatori di recuperare la forma padre di una forma secondaria.
Ottieni la forma genitore
IlFormaclass offre la proprietà ParentShape per recuperare la forma genitore.