Visio Şekil Verilerini Ekleme, Alma, Kopyalama ve Okuma
Visio’de Yeni Şekil Ekleme
Aspose.Diagram for .NET, Microsoft Visio diyagramlarını farklı şekillerde işlemenizi sağlar. Yapabileceğiniz şeylerden biri, diyagramlara yeni şekiller eklemektir. Aspose.Diagram for .NET, diagram’e yeni bir şekil eklemenizi sağlar. Eklenen şekil, Aspose.Diagram for .NET kullanılarak da özelleştirilebilir.
Bu konu, diagram’e yeni bir dikdörtgen şeklinin nasıl ekleneceğini açıklar.
Yeni şekiller oluşturmak için Aspose.Diagram for .NET API’i kullanın ve ardından bu şekilleri diagram’in şekil koleksiyonuna ekleyin.
Yeni bir şekil eklemek için:
- sayfayı bul - Her Visio diagram, bir sayfa koleksiyonu içerir. Geliştiriciler, sayfayı sayfa kimliği veya Adına göre alabilir ve gerekli sayfayıSayfasınıf nesnesi.
- Gerekli Master of a Shape’i ekleyin - Her Visio diagram, bir usta koleksiyonu içerir. Geliştiriciler, mevcut şablon dosyasından (doğrudan yol veya dosya akışı yoluyla) bir Master (Kimlik veya Ada göre) ekleyebilir.
- Visio diagram’de şekil ekleyin - Geliştiriciler, sayfa dizini (0’dan başlayarak), ana ad, PinX, PinY, yükseklik (isteğe bağlı) ve genişliğe (isteğe bağlı) göre Visio diagram’e yeni bir şekil yerleştirebilir.
- Şekil özelliklerini ayarla - Diagram sınıfının AddShape yöntemi, şekil kimliğini döndürür. Geliştiriciler, bu kimliği kullanarak bir Visio diagram’den şekil alabilir ve ardından renk, konum, hizalama ve metin gibi özelliklerini ayarlayabilir.
diagram girişi |
Şekil eklenmiş diagram |
---|
Programlama Örneği Ekle
Aşağıdaki kod parçacığı, her bir adımın nasıl yapılacağını gösterir.
Şekil Bilgilerini Alma
Diyagramlarla Çalışmakdiyagramların nasıl oluşturulacağını, şekiller ve bağlayıcıların nasıl ekleneceğini ve ardından diagram gibi diagram öğeleri hakkında bilgilerin nasıl alınacağını açıklar.sayfalar, ustalar, konektörler veyazı tipleri. Bu makale, bir diagram’deki şekillerle ilgili bilgilerin nasıl alınacağını ele almaktadır.
diagram’deki her şeklin bir kimliği ve adı vardır. Kimlik, Visio ile programlama yaparken önemlidir: bir şekle erişmenin ana yöntemidir. Her şekil ayrıca hangi kalıptan (şablondan) yapıldığına dair bilgileri de tutar.
AŞekil Visio çizimindeki bir nesnedir. Page sınıfı tarafından sunulan Shapes özelliği, Aspose.Diagram.Shape nesne koleksiyonunu destekler. Shapes özelliği, bir şekil hakkında bilgi almak için kullanılabilir.
Örneğin aşağıdaki konsol penceresinde, dört şekil içeren bir diagram için bilgi çıktısını görebilirsiniz: iki sonlandırıcı, bir işlem ve bir dinamik bağlayıcı. Her birinin benzersiz bir kimliği ve ana (kalıp) şeklinin adı vardır.
Şekil bilgilerini gösteren bir konsol penceresi |
---|
Visio sayfa bilgisini almak için: |
- Bir diagram yükler.
- diagram’deki tüm şekillerde döngü yapmak için bir foreach döngüsü kurar.
- Şekil bilgilerini görüntüler.
Programlama Örneği Al
Aşağıdaki kod parçası, şekil bilgisini bir Visio diagram’den alır.
Mevcut Bir Visio’den Şekilleri Kopyala
Aspose.Diagram for .NET API, geliştiricilerin Visio kaynak sayfasındaki şekilleri yeni Visio diagram sayfasına kopyalamasına olanak tanır. Grup şekillerinin kopyalanmasını da destekler. Bu makalede, kaynak diagram sayfasındaki tüm şekillerin nasıl kopyalanacağı açıklanmaktadır.
Şekilleri kopyalamak için geliştiriciler, şekil doldurma stilini ve diğer biçimlendirme özelliklerini korumak için PageSheet ve kaynak Visio temalarını da kopyalamalıdır.
Bu örnek şu şekilde çalışır:
- Bir kaynak yükleyin Visio.
- Yeni bir Visio başlat
- Visio kaynağından ustalar ve temalar ekleyin.
- Sayfayı Visio kaynağından alın.
- PageSheet’ini yeni Visio Sayfasına kopyalayın.
- Kaynak Visio sayfasının şekillerini yineleyin.
- Yeni kimliğini ayarlayın ve yeni Visio sayfasına ekleyin.
- Yeni Visio’i yerel depolamaya kaydedin.
Programlama Örneği Kopyala
Visio Shape’i başka bir Shape örneğine kopyalama
Shape sınıfının Copy yöntemi, klonlamak için bir şekil örneği alır.
// 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;
Visio Şekil Verilerini Okuma
tarafından sergilenen Props koleksiyonuŞekil sınıfı desteklerAspose.Diagram.Prop nesne. Özellik, bir şeklin verilerini (özel özellikler) okumak için kullanılabilir.
Tüm Şekil Özelliklerini Oku
Microsoft Visio’de özel özellikleri tanımlamak için:
- diagram’de bir şekle sağ tıklayın.
- SeçmeVeri , sonraŞekil Verisi menüden. Varolan tüm özellikler iletişim kutusunda listelenir.
Microsoft Visio’de görüldüğü gibi bir şeklin verileri. | ** |
---|---|
Şekil verisi çıktısını gösteren bir konsol penceresi. | ** |
---|---|
Programlama Örneği Oku
Aşağıdaki kod parçacıkları, şekil verilerini (özel özellikler) okur.
Bir Şekil Özelliğini Ada Göre Okuma
Aşağıdaki kod parçacığı, bir şekil özelliğini ada göre okur (özel özellik).
Ada Göre Okuma Programlama Örneği
InheritProps of Shape’i okuyun
Aşağıdaki kod parçacığı, bir şeklin InheritProps’unu okur.
Ekle ve Bağla Visio Şekiller
Aspose.Diagram for .NET, özelleştirilmiş şekiller eklemenizi ve bunları birbirine bağlamanızı sağlar.oluşturduğunuz diyagramlar.
Şekilleri Ekleme ve Birleştirme
Aşağıdaki örneklerdeki kod, nasıl yapılacağını gösterir:
- Bir diagram oluşturun.
- Şekiller ekleyin ve özelleştirin (dikdörtgen, yıldız, altıgen).
- Yıldız ve altıgen şekillerini dikdörtgene bağlayın.
- diagram’i kaydedin.
Şekilleri Ekleme ve Birleştirme Programlama Örneği
Şekilleri bağlamak için Bağlantı dizinlerini kullanın
Aspose.Diagram for .NET API zaten geliştiricilerin şekle yeni bağlantı noktaları eklemesine izin veriyor ve geliştiriciler artık bağlantı dizinlerini kullanarak şekilleri birbirine bağlayabiliyor.
Şekilleri bağlamak için Bağlantı dizinlerini kullanın
Tarafından sunulan ConnectShapesViaConnectorIndex üyesiSayfaclass, bağlantı dizinlerini kullanarak şekilleri bağlamak için kullanılabilir. Aşağıdaki kod, şekillerin nasıl bağlanacağını gösterir:
- Yeni bir çizim başlatın.
- Dört dikdörtgen şekli yerleştirin
- Alt sınır çizgisinde üç bağlantı noktası olacak şekilde iki ek bağlantı noktası ekleyin
- Her bir alt bağlantıdaki ilk şekli, dinamik bağlayıcılarla Üstteki diğer üç dikdörtgen şekle bağlayın
- Çizimi kaydet
Şekilleri bağlamak için bağlantı dizinlerini kullanın Programlama Örneği
Aspose.Diagram for .NET API ile bağlantı dizinlerini kullanarak şekilleri bağlamak için .NET uygulamanızda aşağıdaki kodu kullanın.
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);
Bir Alt Şeklin Ana Şeklini Alma
Aspose.Diagram for .NET, geliştiricilerin bir alt şeklin ana şeklini almasına olanak tanır.
Ebeveyn Şeklini Alın
buŞekilclass, üst şekli almak için ParentShape özelliğini sunar.