Кодируйте кисти и градиенты в XPS
API решение для C++ для работы с кистями и градиентами файлов XPS.
Решение Aspose.Page API для C++ предоставляет вам возможность манипулировать векторной графикой файлов XPS. Он позволяет создавать различные геометрические фигуры с разными цветами и текстурами. Изучите также документацию Aspose.Page о работе с кистями .
Для работы с кистями и градиентами файлов XPS нам потребуется:
Aspose.Page for C++ API — многофункциональное, мощное и простое в использовании API решение для обработки и преобразования документов для платформы C++.
Вы можете загрузить его последнюю версию напрямую, просто откройте диспетчер пакетов NuGet, найдите Aspose.Page.Cpp и установите. Вы также можете использовать следующую команду из консоли диспетчера пакетов.
Package Manager Console Command
PM> Install-Package Aspose.Page
Работа с визуальной кистью на C++
Aspose.Page for C++ API позволяет добавить сетку в файлы XPS с помощью нескольких строк кода. Это можно сделать как для новых, так и для существующих документов. Класс XpsVisualBrush используется для установки свойств сетки с использованием XpsPathGeometry и XpsCanvas . Чтобы добавить сетку в документ XPS, вам необходимо выполнить следующие действия:
- Используя класс XpsDocument , создайте объект Document
- Создайте объект XpsPathGeometry с необходимыми определенными сегментами.
- Используйте класс XpsCanvas, чтобы установить преобразование рендеринга.
- Отрегулируйте свойства Fill и Opacity по желанию.
- Сохраните документ, вызвав метод Save().
Код C++ для добавления сетки к визуальной кисти
using Aspose::Page::XPS;
using Aspose::Page::XPS::XpsModel;
using System::Drawing;
// Create geometry for a magenta grid VisualBrush
System::SharedPtr<XpsPathGeometry> pathGeometry = doc->CreatePathGeometry();
pathGeometry->AddSegment(doc->CreatePolyLineSegment(System::MakeArray<System::Drawing::PointF>({ System::Drawing::PointF(240.f, 5.f), System::Drawing::PointF(240.f, 310.f), System::Drawing::PointF(0.f, 310.f) })));
pathGeometry->idx_get(0)->set_StartPoint(System::Drawing::PointF(0.f, 5.f));
// Create canvas for the magenta grid VisualBrush
System::SharedPtr<XpsCanvas> visualCanvas = doc->CreateCanvas();
System::SharedPtr<XpsPath> visualPath = visualCanvas->AddPath(doc->CreatePathGeometry(u"M 0,4 L 4,4 4,0 6,0 6,4 10,4 10,6 6,6 6,10 4,10 4,6 0,6 Z"));
visualPath->set_Fill(doc->CreateSolidColorBrush(doc->CreateColor(1.f, .61f, 0.1f, 0.61f)));
System::SharedPtr<XpsPath> gridPath = doc->CreatePath(pathGeometry);
// Create a Visual Brush, it is specified by some XPS fragment (vector graphics and glyphs)
gridPath->set_Fill(doc->CreateVisualBrush(visualCanvas, System::Drawing::RectangleF(0.f, 0.f, 10.f, 10.f), System::Drawing::RectangleF(0.f, 0.f, 10.f, 10.f)));
(System::DynamicCast<Aspose::Page::Xps::XpsModel::XpsVisualBrush>(gridPath->get_Fill()))->set_TileMode(Aspose::Page::Xps::XpsModel::XpsTileMode::Tile);
// Create a new canvas
System::SharedPtr<XpsCanvas> canvas = doc->AddCanvas();
canvas->set_RenderTransform(doc->CreateMatrix(1.f, 0.f, 0.f, 1.f, 268.f, 70.f));
// Add a grid
canvas->AddPath(gridPath);
// Create a red transparent rectangle in the middle top
System::SharedPtr<XpsPath> path = canvas->AddPath(doc->CreatePathGeometry(u"M 30,20 l 258.24,0 0,56.64 -258.24,0 Z"));
path = canvas->AddPath(doc->CreatePathGeometry(u"M 10,10 L 228,10 228,100 10,100"));
path->set_Fill(doc->CreateSolidColorBrush(doc->CreateColor(1.0f, 0.0f, 0.0f)));
path->set_Opacity(0.7f);
// Save the resultant XPS document
doc->Save(outDir() + u"AddGrid_out.xps");
Добавьте горизонтальный градиент с помощью C++.
Aspose.Page for C++ API позволяет добавить сетку в файлы XPS с помощью нескольких строк кода. Это можно сделать как для новых, так и для существующих документов. Класс XpsVisualBrush используется для установки свойств сетки с использованием XpsPathGeometry и XpsCanvas . Чтобы добавить сетку в документ XPS, вам необходимо выполнить следующие действия:
- Используя класс XpsDocument , создайте объект Document
- Создайте объект XpsPathGeometry с необходимыми определенными сегментами.
- Используйте класс XpsCanvas, чтобы установить преобразование рендеринга.
- Отрегулируйте свойства Fill и Opacity по желанию.
Код С++ для вставки горизонтального градиента в файл XPS
// Create new XPS Document
auto doc = System::MakeObject<XpsDocument>();
// Initialize List of XpsGradentStop
System::SharedPtr<System::Collections::Generic::List<System::SharedPtr<XpsGradientStop>>> stops = System::MakeObject<System::Collections::Generic::List<System::SharedPtr<XpsGradientStop>>>();
stops->Add(doc->CreateGradientStop(doc->CreateColor(255, 244, 253, 225), 0.0673828f));
stops->Add(doc->CreateGradientStop(doc->CreateColor(255, 251, 240, 23), 0.314453f));
stops->Add(doc->CreateGradientStop(doc->CreateColor(255, 252, 209, 0), 0.482422f));
stops->Add(doc->CreateGradientStop(doc->CreateColor(255, 241, 254, 161), 0.634766f));
stops->Add(doc->CreateGradientStop(doc->CreateColor(255, 53, 253, 255), 0.915039f));
stops->Add(doc->CreateGradientStop(doc->CreateColor(255, 12, 91, 248), 1.f));
// Create new path by defining geometery in abbreviation form
System::SharedPtr<XpsPath> path = doc->AddPath(doc->CreatePathGeometry(u"M 10,210 L 228,210 228,300 10,300"));
path->set_RenderTransform(doc->CreateMatrix(1.f, 0.f, 0.f, 1.f, 20.f, 70.f));
path->set_Fill(doc->CreateLinearGradientBrush(System::Drawing::PointF(10.f, 0.f), System::Drawing::PointF(228.f, 0.f)));
(System::DynamicCast<Aspose::Page::Xps::XpsModel::XpsGradientBrush>(path->get_Fill()))->get_GradientStops()->AddRange(stops);
// Save resultant XPS document
doc->Save(outDir() + u"AddHorizontalGradient_out.xps");
Часто задаваемые вопросы
1. Как добавить градиент в файл XPS?
Задайте путь к каталогу документов. Чтобы добавить градиент, используйте методы CreateColor() и CreateGradientStop().
2. Как работать с визуальной кистью в файле XPS?
Задайте путь к каталогу документов. Чтобы создать визуальную кисть, используйте метод CreateVisualBrush().
3. Как открыть файл XPS?
Используйте решение Aspose.Page API, чтобы открыть XPS файл программно или с помощью кроссплатформенного XPS Viewer .
XPS Формат файла XPS
Формат XPS похож на формат PDF. Оба являются форматами языка описания страниц (PDL). EPS основан на HTML, а не на языке PostScript. Файл .eps может содержать разметку структуры документа вместе с информацией о том, как документ будет выглядеть. Также добавлены инструкции о том, как распечатать и визуализировать документ. Особенность формата в том, что он фиксирует описание документа, а значит, он будет выглядеть одинаково независимо от того, кто и из какой операционной системы его открывает.