Aspose.Slides for .NET 17.5 Release Notes
Key | Summary | Category |
---|---|---|
SLIDESNET-38576 | Size of SWF generated is too high | Investigation |
SLIDESNET-38499 | PowerPoint to SVG with shape ID | Investigation |
SLIDESNET-38379 | Implement using HeaderFooterManager for slide/master/layout | Feature |
SLIDESNET-38608 | Exception on saving presentation | Bug |
SLIDESNET-38593 | Exported file cannot be opened via Aspose.Slides | Bug |
SLIDESNET-38584 | Exception on converting PPTX to PDF | Bug |
SLIDESNET-38572 | PPTX not converted properly to tiff | Bug |
SLIDESNET-38570 | Incorrect Presentation instantiating with empty string password | Bug |
SLIDESNET-38568 | PPT not converted properly to PDF | Bug |
SLIDESNET-38553 | Text changed to asterisk | Bug |
SLIDESNET-38550 | Changes in Workbook doesn’t get saved | Bug |
SLIDESNET-38548 | PPT to tiff not properly converted | Bug |
SLIDESNET-38547 | Conversion to PDF with low quality of images | Bug |
SLIDESNET-38537 | Adding Doughnut chart from scratch does not work | Bug |
SLIDESNET-38536 | PPT not converted properly to PDF | Bug |
SLIDESNET-38527 | PPT not converted properly to PDF | Bug |
SLIDESNET-38526 | Zoom problem in generated presentation | Bug |
SLIDESNET-38520 | Images are not properly generated from PPT | Bug |
SLIDESNET-38516 | Text are changed after saving PPT | Bug |
SLIDESNET-38514 | Text becomes shorter after saving PPT | Bug |
SLIDESNET-38504 | PPT changed after saving | Bug |
SLIDESNET-38464 | Problems editing chart after saving PPTX | Bug |
SLIDESNET-38454 | Table width is changed after saving file | Bug |
SLIDESNET-38422 | Incorrect font when rendering to HTML | Bug |
SLIDESNET-38299 | Footer is not working properly | Bug |
SLIDESNET-37736 | Footer failed to apply in presentation | Bug |
SLIDESNET-36678 | Text gets bigger | Bug |
Public API Changes
HeaderFooterManager specialized classes and interfaces have been added
IBaseHeaderFooterManager, IBaseSlideHeaderFooterManager, IMasterSlideHeaderFooterManager, ILayoutSlideHeaderFooterManager, ISlideHeaderFooterManager, IPresentationHeaderFooterManager interfaces and BaseHeaderFooterManager, BaseSlideHeaderFooterManager, MasterSlideHeaderFooterManager, LayoutSlideHeaderFooterManager, SlideHeaderFooterManager, PresentationHeaderFooterManager classes have been added. These types allow managing Header Footer settings of different presentation elements.
The base IBaseHeaderFooterManager interface of all listed types has following properties and methods.
These properties allow getting value indicating that a footer, page number and date-time placeholders are present:
bool IsFooterVisible { get; }
bool IsSlideNumberVisible { get; }
bool IsDateTimeVisible { get; }
These methods allow changing footer, page number and date-time placeholders visibility:
void SetFooterVisibility(bool isVisible);
void SetSlideNumberVisibility(bool isVisible);
void SetDateTimeVisibility(bool isVisible);
These methods allow setting text to footer and date-time placeholder:
void SetFooterText(string text);
void SetDateTimeText(string text);
In addition, IMasterSlideHeaderFooterManager and ILayoutSlideHeaderFooterManager have following properties and methods to manage instance own and all childs elements Header and Footer settings.
These methods allow changing master/layout slide footer, page number, date-time placeholder and all child footer placeholders visibility. Child placeholders mean placeholders are contained on depending layout slides and depending slides. Depending layout slides and slides use and depend on master slide:
void SetFooterAndChildFootersVisibility(bool isVisible);
void SetSlideNumberAndChildSlideNumbersVisibility(bool isVisible);
void SetDateTimeAndChildDateTimesVisibility(bool isVisible);
These methods allow setting text to master/layout slide footer and date-time placeholder and all child footer placeholders. Child placeholders mean placeholders are contained on depending layout slides and depending slides. Depending layout slides and slides use and depend on master slide:
void SetFooterAndChildFootersText(string text);
void SetDateTimeAndChildDateTimesText(string text);
New properties have been added to access the added types.
IMasterSlideHeaderFooterManager IMasterSlide.HeaderFooterManager { get; }
ILayoutSlideHeaderFooterManager ILayoutSlide.HeaderFooterManager { get; }
ISlideHeaderFooterManager ISlide.HeaderFooterManager { get; }
The type of the property has been changed
IPresentationSlideHeaderFooterManager IPresentation.HeaderFooterManager { get; }
IHeaderFooterManager and class HeaderFooterManager have been marked as Obsolete.
Usage examples:
using (Presentation presentation = new Presentation("presentation.ppt"))
{
IBaseSlideHeaderFooterManager headerFooterManager = presentation.Slides[0].HeaderFooterManager;
if (!headerFooterManager.IsFooterVisible) // Property IsFooterVisible is used for indicating that a slide footer placeholder is not present.
{
headerFooterManager.SetFooterVisibility(true); // Method SetFooterVisibility is used for making a slide footer placeholder visible.
}
if (!headerFooterManager.IsSlideNumberVisible) // Property IsSlideNumberVisible is used for indicating that a slide page number placeholder is not present.
{
headerFooterManager.SetSlideNumberVisibility(true); // Method SetSlideNumberVisibility is used for making a slide page number placeholder visible.
}
if (!headerFooterManager.IsDateTimeVisible) // Property IsDateTimeVisible is used for indicating that a slide date-time placeholder is not present.
{
headerFooterManager.SetDateTimeVisibility(true); // Method SetFooterVisibility is used for making a slide date-time placeholder visible.
}
headerFooterManager.SetFooterText("Footer text"); // Method SetFooterText is used for setting text to slide footer placeholder.
headerFooterManager.SetDateTimeText("Date and time text"); // Method SetDateTimeText is used for setting text to slide date-time placeholder.
}
using (Presentation presentation = new Presentation("presentation.ppt"))
{
IMasterSlideHeaderFooterManager headerFooterManager = presentation.Masters[0].HeaderFooterManager;
headerFooterManager.SetFooterAndChildFootersVisibility(true); // Method SetFooterAndChildFootersVisibility is used for making a master slide and all child footer placeholders visible.
headerFooterManager.SetSlideNumberAndChildSlideNumbersVisibility(true); // Method SetSlideNumberAndChildSlideNumbersVisibility is used for making a master slide and all child page number placeholders visible.
headerFooterManager.SetDateTimeAndChildDateTimesVisibility(true); // Method SetDateTimeAndChildDateTimesVisibility is used for making a master slide and all child date-time placeholders visible.
headerFooterManager.SetFooterAndChildFootersText("Footer text"); // Method SetFooterAndChildFootersText is used for setting text to master slide and all child footer placeholders.
headerFooterManager.SetDateTimeAndChildDateTimesText("Date and time text"); // Method SetDateTimeAndChildDateTimesText is used for setting text to master slide and all child date-time placeholders.
}
Id property has been added to ISvgShape
Id property has been added to ISvgShape to support custom IDs of shapes in generated SVG. Below is the example of custom SVG Shape formatting controller to set custom shape IDs:
class CustomSvgShapeFormattingController : ISvgShapeFormattingController
{
private int m_shapeIndex;
public CustomSvgShapeFormattingController(int shapeStartIndex = 0)
{
m_shapeIndex = shapeStartIndex;
}
public void FormatShape(ISvgShape svgShape, IShape shape)
{
svgShape.Id = string.Format("shape-{0}", m_shapeIndex++);
}
}
New EmbedAllFontsHtmlController has been added
A new HTML Controller has been added: EmbedAllFontsHtmlController. It is used to embed all presentation fonts in HTML document. Here’s an example of using this new controller:
using (Presentation pres = new Presentation("pres.pptx"))
{
// exclude default presentation fonts
string[] fontNameExcludeList = { "Calibri", "Arial" };
EmbedAllFontsHtmlController embedFontsController = new EmbedAllFontsHtmlController(fontNameExcludeList);
HtmlOptions htmlOptionsEmbed = new HtmlOptions
{
HtmlFormatter = HtmlFormatter.CreateCustomFormatter(embedFontsController)
};
pres.Save("pres.html", SaveFormat.Html, htmlOptionsEmbed);
}
Please note that EmbedAllFontsHtmlController has parameterized constructor where an array of font names can be passed to prevent them from embedding. Some fonts, like Calibri or Arial, used in presentation are not needed to be embedded (which leads the resulting HTML document become larger) because almost every system already has them installed.
Another major feature of EmbedAllFontsHtmlController is that it supports inheritance and WriteFont method is intended to be overridden:
public virtual void WriteFont(
IHtmlGenerator generator,
IFontData originalFont,
IFontData substitutedFont,
string fontStyle,
string fontWeight,
byte[] fontData)
{
// todo: serialize font as you need
}
By default, font embedded or serialized in HTML document as bas64 string. But for example, you may create your own controller to dump files somewhere in your own file structure. Below is a sample implementation of LinkAllFontsHtmlController controller intended to write font files on disk and just add link for it in @font-face:
class LinkAllFontsHtmlController : EmbedAllFontsHtmlController
{
private readonly string m_basePath;
public LinkAllFontsHtmlController(string[] fontNameExcludeList, string basePath)
: base(fontNameExcludeList)
{
m_basePath = basePath;
}
public override void WriteFont(
IHtmlGenerator generator,
IFontData originalFont,
IFontData substitutedFont,
string fontStyle,
string fontWeight,
byte[] fontData)
{
string fontName = substitutedFont == null ? originalFont.FontName : substitutedFont.FontName;
string path = string.Format("{0}.woff", fontName); // some path sanitaze may be needed
File.WriteAllBytes(Path.Combine(m_basePath, path), fontData);
generator.AddHtml("<style>");
generator.AddHtml("@font-face { ");
generator.AddHtml(string.Format("font-family: '{0}'; ", fontName));
generator.AddHtml(string.Format("src: url('{0}')", path));
generator.AddHtml(" }");
generator.AddHtml("</style>");
}
}