Aspose.Slides for C++ 21.6 Release Notes
Supported Platforms
- Aspose.Slides for C++ for Windows x64 (Microsoft Visual C++).
- Aspose.Slides for C++ for Windows x86 (Microsoft Visual C++).
- Aspose.Slides for C++ for Linux (Clang).
New Features and Enhancements
Key | Summary | Category |
---|---|---|
SLIDESNET-30675 | Support of Presentation to XAML export | Feature |
SLIDESNET-42514 | Support of Cylinder column shape for 3-D Column and 3-D Bar Charts | Feature |
SLIDESNET-42447 | Support of 3-D Bar Chart | Feature |
SLIDESNET-37955 | Support of 3D Transforms for thumbnails | Feature |
Other Improvements and Changes
Key | Summary | Category |
---|---|---|
SLIDESCPP-2701 | Use Aspose.Slides for .NET 21.6 features | Enhancement |
Public API Changes
Support of Presentation to XAML export
To support Presentation export to XAML, we added new API members.
IXamlOptions interface and XamlOptions class. IXamlOptions declaration:
/// <summary>
/// Options that control how a XAML document is saved.
/// </summary>
class IXamlOptions : public virtual Aspose::Slides::Export::ISaveOptions
{
public:
/// <summary>
/// Determines whether hidden slides will be exported.
/// </summary>
virtual bool get_ExportHiddenSlides() = 0;
/// <summary>
/// Determines whether hidden slides will be exported.
/// </summary>
virtual void set_ExportHiddenSlides(bool value) = 0;
/// <summary>
/// Represents an implementation of IOutputSaver interface.
/// </summary>
virtual System::SharedPtr<IXamlOutputSaver> get_OutputSaver() = 0;
/// <summary>
/// Represents an implementation of IOutputSaver interface.
/// </summary>
virtual void set_OutputSaver(System::SharedPtr<IXamlOutputSaver> value) = 0;
};
For Presentation export to XAML, a new Save method overload got added to the Presentation class:
void Save(System::SharedPtr<Export::Xaml::IXamlOptions> options);
This code sample demonstrates the exporting of a Presentation to a set of XAML files:
auto pres = System::MakeObject<Presentation>(u"pres.pptx");
SharedPtr<IXamlOptions> options = System::MakeObject<XamlOptions>();
options->set_ExportHiddenSlides(true);
pres->Save(options);
The XAML files get saved in a newly created folder—“pres”.
The IXamlOutputSaver interface allows you to define your own output-saving service. IXamlOutputSaver declaration:
/// <summary>
/// Represents an output saver implementation for transfer data to the external storage.
/// </summary>
class IXamlOutputSaver : public System::Object
{
public:
/// <summary>
/// Saves a bytes array to a destination location.
/// </summary>
/// <param name="path">The destination path.</param>
/// <param name="data">A binary data for saving to a destination location.</param>
virtual void Save(System::String path, System::ArrayPtr<uint8_t> data) = 0;
};
IEffect::get_TargetShape() method has been added
The IEffect::get_TargetShape() method has been added. It returns the shape affected by the effect.
Method declaration:
/// <summary>
/// Returns target shape for effect.
/// Read-only <see cref="IShape"></see>.
/// </summary>
virtual System::SharedPtr<IShape> get_TargetShape() = 0;
This code sample demonstrates the output of information for all animated shapes in the main sequence for all slides in a presentation.
auto pres = System::MakeObject<Presentation>(u"SomePresentation.pptx");
for (auto slide : System::IterateOver(pres->get_Slides()))
{
for (auto effect : System::IterateOver(slide->get_Timeline()->get_MainSequence()))
{
System::Console::WriteLine(u"{0} animation effect is set to shape #{1} on slide #{2}",
effect->get_Type(), effect->get_TargetShape()->get_UniqueId(), slide->get_SlideNumber());
}
}