Browse our Products

Aspose.Slides for CPP 19.6 Release Notes

Supported Platforms

  • Aspose.Slides for C++ for Windows (Microsoft Visual C++).
  • Aspose.Slides for C++ for Linux (Clang).
KeySummaryCategory
SLIDESCPP-1816Use Aspose.Slides for .NET 19.6 featuresFeature
SLIDESCPP-41142Support for setting lock Aspect Ratio for text boxFeature
SLIDESNET-41092IColorFormat.Color doesn’t return effective colorFeature
SLIDESNET-34681Support for progress in percentage for PDF conversionFeature
SLIDESCPP-41101Implement a progress in percentage for PDF conversionFeature
SLIDESCPP-40958Option for making every page self-sufficient when saving presentation as HTMLFeature
SLIDESNET-16733Fusion Charts support in Aspose.SlidesFeature
SLIDESNET-31569Adding custom lines in PowerPoint chartsFeature
SLIDESNET-40672Support for extracting VBA macros from presentationFeature
SLIDESNET-30385Auto-Refresh Chart with Editing dataFeature
SLIDESNET-18215Support for ComponentArt chart objects in Aspose.SlidesFeature
SLIDESNET-12438SmartArt and Chart Object implementation for PPTX -> PDFEnhancement
SLIDESNET-41149Generating Box and Whisker ChartEnhancement
SLIDESCPP-1869Improve thumbnails rendering quality (v19.6)Enhancement

Public API Changes

BackgroundEffectiveData and IBackgroundEffectiveData classes have been added

Aspose::Slides::IBackgroundEffectiveData interface class and it’s implementation by Aspose::Slides::BackgroundEffectiveData class have been added. They represent effective background of slide and contain information about effective fill format and effective effect format.

CreateBackgroundEffective() method has been added to IBaseSlide class

CreateBackgroundEffective() method has been added to IBaseSlide and BaseSlide classes. Using this method allows to get effective values for slide’s background.

Sample code below outputs effective background fill:

auto pres = System::MakeObject<Presentation>(u"SamplePresentation.pptx");
System::SharedPtr<IBackgroundEffectiveData> effBackground = pres->get_Slides()->idx_get(0)->CreateBackgroundEffective();
if (effBackground->get_FillFormat()->get_FillType() == Aspose::Slides::FillType::Solid)
{
    System::Console::WriteLine(System::String(u"Fill color: ") + effBackground->get_FillFormat()->get_SolidFillColor());
}
else
{
    System::Console::WriteLine(System::String(u"Fill type: ") + System::ObjectExt::ToString(effBackground->get_FillFormat()->get_FillType()));
}

IProgressCallback class has been added

IProgressCallback class has been added to ISaveOptions and SaveOptions classes. IProgressCallback interface class represents a callback object for saving progress updates in percentage.

Code snippets below show how to use IProgressCallback interface class:

auto presentation = System::MakeObject<Presentation>(fileName);
System::SharedPtr<ISaveOptions> saveOptions = System::MakeObject<PdfOptions>();
saveOptions->set_ProgressCallback(System::MakeObject<CloningTests::ExportProgressHandler>());
presentation->Save(pdfFileName, Aspose::Slides::Export::SaveFormat::Pdf, saveOptions);
class ExportProgressHandler : public Aspose::Slides::IProgressCallback
{
public:
    void Reporting(double progressValue)
    {
        //...
    }
};

The following methods of the INotesSlide class have been removed:

System::SharedPtr<System::Drawing::Bitmap> GetThumbnail(float scaleX, float scaleY);
System::SharedPtr<System::Drawing::Bitmap> GetThumbnail(System::Drawing::Size imageSize);

Use ISlide::GetThumbnail() method with parameter of type INotesCommentsLayoutingOptions instead.

The following methods of the ISlide class have been removed:

void RenderToGraphics(bool withNotes, System::SharedPtr<System::Drawing::Graphics> graphics, int32_t width, int32_t height);
void RenderToGraphics(bool withNotes, System::SharedPtr<System::Drawing::Graphics> graphics, float scale);
void RenderToGraphics(bool withNotes, System::SharedPtr<System::Drawing::Graphics> graphics);

Use RenderToGraphics() method with parameter of type INotesCommentsLayoutingOptions instead.

The following methods of the IHtmlOptions, IPdfOptions, ISwfOptions and ITiffOptions classes have been removed:

bool get_IncludeComments();
void set_IncludeComments(bool value);

Use INotesCommentsLayoutingOptions class instead.

PdfNotes, TiffNotes, SwfNotes and HtmlNotes values have been removed from the SaveFormat enum class. Use specific options with INotesCommentsLayoutingOptions element for saving presentation instead.

Pot value has been added to LoadFormat and SaveFormat enum classes

The new Pot value has been added to Aspose::Slides::LoadFormat and Aspose::Slides::SaveFormat enum classes. This value represents Microsoft PowerPoint 97-2003 Presentation template format.

Support of management images as BLOBs has been added

Since version 19.6 Aspose.Slides supports managing of presentation images as BLOB.

Also the new method has been added to IImageCollection and ImageCollection classes to support adding large image as streams to treat them as BLOBs:

System::SharedPtr<IPPImage> AddImage(System::SharedPtr<System::IO::Stream> stream, LoadingStreamBehavior loadingStreamBehavior);

Adding new image as BLOB to the presentation This example demonstrates how to include the large BLOB (image) and prevent a high memory consumption.

void AddingNewBlobImageToPresentation()
{
    // supposed we have the large image file we want to include into the presentation
    const System::String pathToLargeImage = u"largeImage.png";
    
    // create a new presentation which will contain this image
    auto pres = System::MakeObject<Presentation>();

    auto fileStream = System::MakeObject<System::IO::FileStream>(pathToLargeImage, System::IO::FileMode::Open);

    // let's add the image to the presentation - we choose KeepLocked behavior, because we not
    // have an intent to access the "largeImage.png" file.
    auto img = pres->get_Images()->AddImage(fileStream, Aspose::Slides::LoadingStreamBehavior::KeepLocked);

    pres->get_Slides()->idx_get(0)->get_Shapes()->AddPictureFrame(Aspose::Slides::ShapeType::Rectangle, 0.0f, 0.0f, 300.0f, 200.0f, img);
    // save the presentation. Despite that the output presentation will be
    // large, the memory consumption will be low the whole lifetime of the pres object
    pres->Save(u"presentationWithLargeImage.pptx", Aspose::Slides::Export::SaveFormat::Pptx);
}