Преносими форми Отделно от документ

При обработката на документи, обща задача е да се извлекат всички изображения, намерени в документа и да се изнасят на външно място. Тази задача става проста с Aspose.Words API, която вече осигурява функционалността за извличане и запазване на данните от изображенията. Въпреки това, понякога може да искате да извлечете по подобен начин други видове графично съдържание, което е представено от различен тип рисуващ обект, например текстова кутия, съдържаща параграфи, форми на стрелки и малко изображение. Няма лесен начин да се направи този обект, тъй като той е комбинация от отделни елементи на съдържанието. Можете също така да се сблъскате със случай, когато съдържанието е групирано заедно в обекта, който изглежда като едно изображение.

Aspose.Words осигурява функционалност за извличане на този тип съдържание по същия начин, по който можете да извлечете просто изображение от форма като преведено съдържание. Тази статия описва как да се използва тази функционалност, за да се направят форми независимо от документа.

Видове форма в Aspose.Words

Цялото съдържание в слой за рисуване на документи се представя от Shape или GroupShape възел в Aspose.Words Модул на обекта на документа (DOM). Такова съдържание могат да бъдат текстови кутии, изображения, AutoShapes, OLE обекти и др. Някои полета също се внасят като форми, например INCLUDEPICTURE поле.

Прост образ е представен от Shape възел на ShapeType.Image. Тази форма възел няма детски възли, но данните от изображението, съдържащи се в тази форма възел може да бъде достъпен от Shape.ImageData собственост. От друга страна, формата може да бъде съставена и от много детски възли. Например, формата текст кутия, която е представена от ShapeType.TextBox имоти, могат да бъдат съставени от много възли, като Paragraph както и Table. Повечето форми могат да включват Paragraph както и Table Блокови възли. Това са същите възли като тези, които се появяват в основното тяло. Формулите са винаги части от някой параграф, включени директно в линия или закотвени към Параграф Но това е навсякъде в страницата с документите.

rendering-shapes-separately-from-a-document_1

Документът може да съдържа и форми, които са групирани заедно. Grouping може да бъде активиран в Microsoft Word чрез избор на няколко обекта и щракване върху гоGroupВ дясното меню.

rendering-shapes-separately-from-a-document_2

В Aspose.Words, Тези групи форми са представени от GroupShape Възел. Те могат да бъдат използвани по същия начин, за да се направи цялата група да се образира.

rendering-shapes-separately-from-a-document_3

Форматът DOX може да съдържа специални видове изображения, като диаграми или диаграми. Тези форми също са представени чрез Shape Възел в Aspose.Words, който също така осигурява подобен метод за тяхното представяне като изображения. По дизайн формата не може да съдържа друга форма като дете, освен ако тази форма не е изображение (ShapeType.Image). Например, Microsoft Word не ви позволява да поставите текстова кутия в друга текстова кутия.

Типовете форма, описани по-горе, осигуряват специален метод за превръщане на формите през ShapeRenderer Клас. Пример за ShapeRenderer Класът се получава за a Shape или GroupShape през GetShapeRenderer метод или чрез преминаване на Shape до конструктора на ShapeRenderer Клас. Този клас осигурява достъп до членове, които позволяват да се направи форма на следното:

  • Файл на диска чрез Save Претоварване на метода
  • Поток използвайки Save Претоварване на метода
  • .NET Графика Обект чрез използване на RenderToSize както и RenderToScale методи

Превръщане във файл или поток

На Save метод осигурява претоварване, което прави формата директно към файл или поток. И двете претоварвания приемат случай на ImageSaveOptions клас, който позволява да се определят опции за представяне на формата. Това работи по същия начин като Document.Save метод. Въпреки че този параметър е необходим, можете да преминете към нулева стойност, като посочите, че няма потребителски опции.

Форматът може да бъде изнесен във всеки формат на изображението, посочен в SaveFormat Изброяване. Например, изображението може да бъде преведено като образ на растер, като JPEG чрез определяне на SaveFormat.Jpeg изброяване или като векторно изображение, като EMF, като се посочва SaveFormat.Emf.

Примерът с кода по-долу илюстрира формата на изображение с EMF отделно от документ и запис на диск:

// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-.NET
ShapeRenderer r = shape.GetShapeRenderer();
// Define custom options which control how the image is rendered. Render the shape to the JPEG raster format.
ImageSaveOptions imageOptions = new ImageSaveOptions(SaveFormat.Emf)
{
Scale = 1.5f
};
dataDir = dataDir + "TestFile.RenderToDisk_out.emf";
// Save the rendered image to disk.
r.Save(dataDir, imageOptions);

Примерът с кода по-долу илюстрира формата на изображение на JPEG отделно от документа и спестяване към поток:

// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-.NET
ShapeRenderer r = new ShapeRenderer(shape);
// Define custom options which control how the image is rendered. Render the shape to the vector format EMF.
ImageSaveOptions imageOptions = new ImageSaveOptions(SaveFormat.Jpeg)
{
// Output the image in gray scale
ImageColorMode = ImageColorMode.Grayscale,
// Reduce the brightness a bit (default is 0.5f).
ImageBrightness = 0.45f
};
dataDir = dataDir + "TestFile.RenderToStream_out.jpg";
FileStream stream = new FileStream(dataDir, FileMode.Create);
// Save the rendered image to the stream using different options.
r.Save(stream, imageOptions);

На ImageSaveOptions клас ви позволява да посочите различни опции, които контролират как изображението се предава. Функционалността, описана по-горе, може да се прилага по същия начин към GroupShape както и Shape Възли.

Пренасяне към .NET Графичен обект

Пренасяне директно към Graphics обект ви позволява да определите вашите собствени настройки и състоянието за Graphics Възразявам. Един общ сценарий включва превръщането на формата директно в Graphics обект, получен от Windows Форма или Bitmap. Когато Shape Възелът се предава, настройките ще повлияят на външния вид. Например, можете да завъртите или мащабирате формата с помощта на RotateTransform или ScaleTransform методи за Graphics Възразявам.

Примерът по-долу показва как да се направи форма на .NET Graphics обект отделно от документа и се прилага ротация на преведеното изображение:

// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-.NET
public static void RenderShapeToGraphics(string dataDir, Shape shape)
{
ShapeRenderer r = shape.GetShapeRenderer();
// Find the size that the shape will be rendered to at the specified scale and resolution.
Size shapeSizeInPixels = r.GetSizeInPixels(1.0f, 96.0f);
// Rotating the shape may result in clipping as the image canvas is too small. Find the longest side
// And make sure that the graphics canvas is large enough to compensate for this.
int maxSide = System.Math.Max(shapeSizeInPixels.Width, shapeSizeInPixels.Height);
using (Bitmap image = new Bitmap((int)(maxSide * 1.25), (int)(maxSide * 1.25)))
{
// Rendering to a graphics object means we can specify settings and transformations to be applied to
// The shape that is rendered. In our case we will rotate the rendered shape.
using (Graphics gr = Graphics.FromImage(image))
{
// Clear the shape with the background color of the document.
gr.Clear(shape.Document.PageColor);
// Center the rotation using translation method below
gr.TranslateTransform((float)image.Width / 8, (float)image.Height / 2);
// Rotate the image by 45 degrees.
gr.RotateTransform(45);
// Undo the translation.
gr.TranslateTransform(-(float)image.Width / 8, -(float)image.Height / 2);
// Render the shape onto the graphics object.
r.RenderToSize(gr, 0, 0, shapeSizeInPixels.Width, shapeSizeInPixels.Height);
}
dataDir = dataDir + "TestFile.RenderToGraphics_out.png";
image.Save(dataDir, ImageFormat.Png);
Console.WriteLine("\nShape rendered to graphics successfully.\nFile saved at " + dataDir);
}
}

Подобно на RenderToSize метод, RenderToSizeметод, наследен от NodeRendererBase е полезно за създаване на нокти от документ. Размерът на формата е определен чрез конструктора. На RenderToSize метод приема Graphics обект, координатите X и Y на позицията на изображението и размера на изображението (широчина и височина), които ще бъдат изтеглени върху Graphics Възразявам.

На Shape може да се прехвърли в определена скала с помощта на ShapeRenderer.RenderToScale метод, наследен от NodeRendererBase Клас. Това е подобно на Document.RenderToScale метод, който приема същите основни параметри. Разликата между тези два метода е, че с ShapeRenderer.RenderToScale метод, вместо буквален размер, вие избирате плаваща стойност, която мащабира формата по време на нейното представяне. Ако плаващата стойност е равна на 1.0 причинява формата да бъде предадена на 100% от първоначалния размер. Плаваща стойност от 0.5 ще намали размера на изображението наполовина.

Образуване на изображение

На Shape класът представлява обекти в рисувания слой, като AutoShape, текстова кутия, свободна форма, OLE обект, ActiveX контрол, или картина. Използване на Shape клас, можете да създавате или променяте форми в Microsoft Word документ. Важно свойство на формата е неговото ShapeType. Форми от различни типове могат да имат различни възможности в документ на Word. Например, само образ и OLE форми могат да имат изображения вътре в тях, докато повечето от формите могат да имат само текст.

Следният пример показва как да се направи изображение на формата на JPEG изображение отделно от документа и да се запази на диска:

// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-.NET
dataDir = dataDir + "TestFile.RenderShape_out.jpg";
// Save the Shape image to disk in JPEG format and using default options.
shape.GetShapeRenderer().Save(dataDir, null);

Изтегляне на размера на формата

На ShapeRenderer клас също така осигурява функционалност за извличане на размера на формата в пиксели през GetSizeInPixels метод. Този метод приема два параметъра на float (Single) - мащабът и kniff, които се използват при изчисляването на размера на формата, когато формата е предадена. Методът връща Size обект, който съдържа ширината и височината на изчисления размер. Това е полезно, когато е необходимо да се знае размера на формата предварително, например при създаването на нов Bitmap от трансформирания изход.

По-долу примерът показва как да се създаде нов обект Bitmap и Graphics с ширината и височината на формата, която да бъде предадена:

// For complete examples and data files, please go to https://github.com/aspose-words/Aspose.Words-for-.NET
Size shapeRenderedSize = shape.GetShapeRenderer().GetSizeInPixels(1.0f, 96.0f);
using (Bitmap image = new Bitmap(shapeRenderedSize.Width, shapeRenderedSize.Height))
{
using (Graphics g = Graphics.FromImage(image))
{
// Render shape onto the graphics object using the RenderToScale or RenderToSize methods of ShapeRenderer class.
}
}

Когато използвате RenderToSize или RenderToScale методи, преведеното изображение размер също се връща в SizeF Възразявам. Това може да се придаде на променлива и да се използва, ако е необходимо.

На SizeInPoints имот връща размера на формата, измерена в точки (вж. ShapeRenderer. Резултатът е SizeF обект, съдържащ ширината и височината.