Why to Convert SVG to POTX?
If you are a C++ developer looking to add a feature to your applications that allows for SVG to POTX conversion, then you are in the right place. SVG (Scalable Vector Graphics) is an XML-based vector image format for two-dimensional graphics with support for interactivity and animation. POTX (PowerPoint Open XML Template) is a file format used by Microsoft PowerPoint to store slide templates. Converting SVG to POTX allows you to create presentations with a consistent look and feel, as well as to save time by reusing existing templates.
How Aspose.Total Helps for SVG to POTX Conversion?
Aspose.Total for C++ is a suite of APIs that provides developers with the tools they need to create, manipulate, and convert documents, images, and other file formats. It includes two APIs that can be used to convert SVG to POTX: Aspose.PDF for C++ and Aspose.Slides for C++.
Using Aspose.PDF for C++, you can export SVG to PPTX, which is a presentation format supported by Microsoft PowerPoint. Then, using Aspose.Slides for C++, you can convert PPTX to POTX. Both APIs are included in the Aspose.Total for C++ package, so you can get started right away.
The process of converting SVG to POTX is simple and straightforward. All you need to do is install the Aspose.Total for C++ package, and you can begin exporting SVG to PPTX and converting PPTX to POTX. With Aspose.Total for C++, you can quickly and easily add SVG to POTX conversion to your C++ applications.
C++ API to Export SVG to POTX
- Open SVG file using Document class reference
- Convert SVG to PPTX by using Save method function
- Load PPTX document by using Presentation class reference
- Save the document to POTX format using
Save
member function and set
Potx
as SaveFormat
Get Started with C++ File Automation APIs
Install from command line as nuget install Aspose.Total.Cpp
or via Package Manager Console of Visual Studio with Install-Package Aspose.Total.Cpp
.
Alternatively, get the offline MSI installer or DLLs in a ZIP file from downloads .
// load SVG file with an instance of Document class
auto doc = MakeObject<Document>(u"template.svg");
// save SVG as PPTX format
doc->Save(u"PptxOutput.pptx", SaveFormat::Pptx);
// instantiate a Presentation object that represents a PPTX file
SharedPtr<Presentation> prs = MakeObject<Presentation>(u"PptxOutput.pptx");
// save the presentation as Potx format
prs->Save(u"output.potx", Aspose::Slides::Export::SaveFormat::Potx);
Change Password of SVG Document via C++
In the process of rendering SVG to POTX, you can open a password protected SVG and also change its password. In order to change the password of a SVG file, you must know the owner password of that document. You can load password protected PDF document with Aspose.PDF for C++ by specifying its owner password and use ChangePasswords method to change the password.
// load an existing SVG Document
auto doc = MakeObject<Document>(L"input.svg", L"owner");
// change password of SVG Document
doc->ChangePasswords(L"owner", L"newuser", L"newuser");
// save the document
doc->Save(L"output.Doc");
Add Images From Web in POTX File via C++
After converting SVG to POTX, you can also add images from web to your output document. Aspose.Slides for C++ supports operations with images in these popular formats: JPEG, PNG, BMP, GIF, and others. You can add one or several images on your computer onto a slide in a presentation. This sample code in C++ shows you how to add an image to a POTX file
// instantiate a Presentation object that represents a POTX file
auto pres = System::MakeObject<Presentation>("output.potx");
// get slide
auto slide = pres->get_Slides()->idx_get(0);
// initialize Web Client
auto webClient = System::MakeObject<WebClient>();
// get image data
auto imageData = webClient->DownloadData(System::MakeObject<Uri>(u"[REPLACE WITH URL]"));
// add image
auto image = pres->get_Images()->AddImage(imageData);
// add picture frame
slide->get_Shapes()->AddPictureFrame(ShapeType::Rectangle, 10.0f, 10.0f, 100.0f, 100.0f, image);
// save updated file
pres->Save(u"updated.potx", SaveFormat::Potx);