Eksportowanie formatu DGN AutoCAD

Eksportowanie formatu DGN AutoCAD do PDF

Aspose.CAD dla API .NET wprowadziło funkcjonalność ładowania pliku DGN AutoCAD i konwersji go do formatu PDF. Klasa CadImage służy temu celowi.

Musisz załadować istniejący plik DGN jako CadImage. Utwórz instancję klasy CadRasterizationOptions i ustaw różne właściwości. Utwórz instancję klasy PdfOptions i przekaż instancję CadRasterizationOptions. Teraz wywołaj metodę Save instancji klasy CadImage.

Przykładowy kod

Poniżej znajduje się demonstracja kodu do konwersji/eksportu DGN do formatu PDF.

// The path to the documents directory.
string MyDir = RunExamples.GetDataDir_DXFDrawings();
string sourceFilePath = MyDir + "conic_pyramid.dxf";
using (CadImage cadImage = (CadImage)Image.Load(sourceFilePath))
{
CadRasterizationOptions rasterizationOptions = new CadRasterizationOptions();
rasterizationOptions.Layouts = new[] { "Model" };
PdfOptions pdfOptions = new PdfOptions();
pdfOptions.VectorRasterizationOptions = rasterizationOptions;
cadImage.Save(MyDir + "conic_pyramid.pdf", pdfOptions);
}

Eksportowanie formatu DGN AutoCAD do formatu obrazu rastrowego

Aspose.CAD dla API .NET wprowadziło funkcjonalność ładowania pliku DGN AutoCAD i konwersji go do obrazu rastrowego. Klasa CadImage służy temu celowi.

Musisz załadować istniejący plik DGN jako CadImage. Utwórz instancję klasy CadRasterizationOptions i ustaw różne właściwości. Utwórz instancję klasy JpegOptions i przekaż instancję CadRasterizationOptions. Teraz wywołaj metodę Save instancji klasy CadImage.

Przykładowy kod

Poniżej znajduje się demonstracja kodu do konwersji/eksportu DGN do obrazu JPEG.

// The path to the documents directory.
string MyDir = RunExamples.GetDataDir_ExportingDGN();
string sourceFilePath = MyDir + "Nikon_D90_Camera.dgn";
// Load an existing DGN file as CadImage.
using (Aspose.CAD.FileFormats.Cad.CadImage cadImage = (Aspose.CAD.FileFormats.Cad.CadImage)Aspose.CAD.Image.Load(sourceFilePath))
{
// Create an object of DgnRasterizationOptions class and define/set different properties
Aspose.CAD.ImageOptions.CadRasterizationOptions rasterizationOptions = new Aspose.CAD.ImageOptions.CadRasterizationOptions();
rasterizationOptions.PageWidth = 600;
rasterizationOptions.PageHeight = 300;
rasterizationOptions.NoScaling = true;
rasterizationOptions.AutomaticLayoutsScaling = false;
// Create an object of JpegOptions class as we are converting the DGN to jpeg and assign DgnRasterizationOptions object to it.
Aspose.CAD.ImageOptionsBase options = new Aspose.CAD.ImageOptions.JpegOptions();
options.VectorRasterizationOptions = rasterizationOptions;
// Call the save method of the CadImage class object.
cadImage.Save(MyDir + "ExportDGNToRasterImage_out.pdf", options);
}

Wsparcie dla 3D w DGN v7

Aspose.CAD dla API .NET wprowadziło funkcjonalność ładowania pliku DGN AutoCAD i wsparcia dla obiektów 3D w DGN v7. Klasa CadImage służy temu celowi. Każdy obraz DGN wspiera 9 predefiniowanych widoków. Jest to numerowane od 1 do 9. Jeśli widok nie jest zdefiniowany podczas eksportu, dla wielostronnych formatów wyjściowych (jak PDF) wszystkie widoki będą eksportowane, każdy na osobnej stronie. Obiekty 3D wspierane są w formacie pliku DGN, tak samo jak 2D. W tym celu używane jest VectorRasterizationOptions, TypeOfEntities nie jest już używane w formacie DGN (zarówno 2D, jak i 3D wspierane jednocześnie).

Przykładowy kod

Poniżej znajduje się przykładowy kod do przeglądania wspieranych elementów DGN.

// The path to the documents directory.
string MyDir = RunExamples.GetDataDir_ExportingDGN();
string sourceFilePath = MyDir + "Nikon_D90_Camera.dgn";
string outFile = MyDir + "Nikon_D90_Camera.dgn";
// Load an existing DGN file as CadImage.
using (DgnImage dgnImage = (DgnImage)Image.Load(sourceFilePath))
{
var options = new PdfOptions
{
VectorRasterizationOptions = new CadRasterizationOptions
{
PageWidth = 1500,
PageHeight = 1500,
AutomaticLayoutsScaling = true,
BackgroundColor = Color.Black,
Layouts = new string[] { "1", "2", "3", "9" }//only export 4 (1,2,3 and 9) views
}
};
dgnImage.Save(outFile, options);
}