Browse our Products
Aspose.Words for C++ 20.5 Release Notes
Major Features
We have added the following features from Aspose.Words for .NET on this regular monthly release:
- Provided ability to show/hide Grammatical and Spelling errors.
- New helper class to work with watermark inside document was introduced.
- Added feature to set the compression level for OOXML documents.
Limitations and API Differences
Aspose.Words for C++ has some differences as compared to its equivalent .NET version of the API. This section contains information about all such functionality that is not available in the current release. The missing features will be added in future releases.
- The current release does not support the Metered license.
- The current release does not support a multipage TIFF format.
- The current release does not support LINQ and Reporting features.
- The current release does not support OpenGL 3D Shapes rendering.
- The current release does not support advanced typography based on the HarfBuzz shaper.
- The current release does not support loading PDF documents.
- The current release has limited support for database features - C++ does not have a common API for DB like .NET System.Data.
- The current release only supports Microsoft Visual C++ version 2017 or higher and only for the x64 platform.
Full List of Issues Covering all Changes in this Release
Key | Summary | Category |
---|---|---|
WORDSNET-10403 | Add feature to ‘Hide spelling errors in this document only’ | New Feature |
WORDSNET-4879 | Add a helper method to insert a watermark into the header | New Feature |
WORDSNET-10404 | Add feature to ‘Hide grammar errors in this document only’ | New Feature |
WORDSNET-20094 | Add an option to remove duplicate styles to Document.Cleanup feature | New Feature |
WORDSNET-20169 | Aspose.Words writes incorrect bytes for DOCX | New Feature |
WORDSNET-13640 | Font “Simplified Arabic” is changed to “Arial” in output PDF | Bug |
WORDSNET-20352 | Spaces with the font DotumChe are not shrunk | Bug |
WORDSNET-19093 | Follow up for WORDSNET-18543, implement the notification | Bug |
WORDSNET-19105 | Arabic words take up more horizontal space | Bug |
WORDSNET-20187 | UpdateFields does not process TOC fields ( formatting changed & an entry missing) | Bug |
WORDSNET-19240 | Improve markdown emphases parsing | Bug |
WORDSNET-20257 | Import of complex StructuredDocumentTag | Bug |
WORDSNET-15509 | Arabic text is not rendered correctly in output PDF | Bug |
WORDSNET-18294 | Some characters look different in the PDF rendition | Bug |
WORDSNET-12125 | Locales should be expanded from document defaults when exported to DOC format | Bug |
WORDSNET-19254 | Incorrect inline shape height causes layout differences | Bug |
WORDSNET-13162 | RTF to PDF conversion issue with Thai text rendering | Bug |
WORDSNET-20208 | Rendering of the fraction. Height calculation of the fraction | Bug |
WORDSNET-18923 | Paragraph shading is stretched up to TextBox bottom | Bug |
WORDSNET-20211 | DOCX is corrupted after re-saving it | Bug |
WORDSNET-20212 | Range.Replace does not replace the numbers | Bug |
WORDSNET-20353 | ArgumentOutOfRangeException is thrown while exporting document with multiple numbered paragraphs inside a cell into Markdown | Bug |
WORDSNET-19920 | Document.UpdateFields does not update Index entries under the Swedish language | Bug |
WORDSNET-13133 | TXT to PDF conversion issue with Thai Characters | Bug |
WORDSNET-20219 | Extra data points appear in the chart in the output PDF | Bug |
WORDSNET-20222 | Convert to PDF output font issue | Bug |
WORDSNET-19038 | Content-control missing after resave | Bug |
WORDSNET-15446 | Font formatting of Arabic text is changed in output PDF | Bug |
WORDSNET-15858 | Traditional Arabic font is not rendered correctly in output PDF | Bug |
WORDSNET-17001 | Equations have an incorrect layout in PDF | Bug |
WORDSNET-20168 | On conversion from MHTML to PDF the exception “Parameter is not valid” has been thrown | Bug |
WORDSNET-20046 | Document.UpdateFields does not update the IF field correctly | Bug |
WORDSNET-20052 | Line shape is lost after DOC to PDF conversion | Bug |
WORDSNET-20229 | GetStartPageIndex returns incorrect page number for table | Bug |
WORDSNET-20234 | Reading PDF documents does not work with Aspose.Words for .NET 20.4 (.NET 4.6.1.) | Bug |
WORDSNET-20236 | Diagram text is cropped if the paragraph line spacing less then one | Bug |
WORDSNET-20237 | LayoutCollector incorrectly returns page index | Bug |
WORDSNET-20238 | LayoutCollector incorrectly returns page index | Bug |
WORDSNET-20224 | Inline images being shifted in HTML Fixed format | Bug |
WORDSNET-19826 | CPU hangs during processing Mail Merge involving INCLUDETEXT fields | Bug |
WORDSNET-19405 | DOCX to PDF file conversion gets one page more | Bug |
WORDSNET-20244 | Image’s height width change during open save an RTF | Bug |
WORDSNET-19202 | Extra step numbers are being generated in Word to PDF transformation | Bug |
WORDSNET-20116 | Hyperlinks in the Table of Contents do not work | Bug |
WORDSNET-20249 | Unsupported EOT fonts from DOC format during roundtrip conversion | Bug |
WORDSNET-20251 | After conversion to PDF, some text with radio buttons is mixed up | Bug |
WORDSNET-20247 | Document.Compare throws System.InvalidOperationException | Bug |
WORDSNET-20186 | Document.Range.Replace regex string anchors not working | Bug |
WORDSNET-20104 | WordArt Shape turns into boxes in the rendered document | Bug |
WORDSNET-20232 | Image renders incorrectly after DOC to HtmlFixed conversion | Bug |
WORDSNET-20028 | Conversion to HTML results in wrong spacing | Bug |
WORDSNET-20172 | On conversion from MHTML to PDF, the exception “NotSupportedException” has been thrown | Bug |
WORDSNET-20268 | Offset shapes in SmartArt when using the Advanced mode | Bug |
WORDSNET-20118 | Second attempt to save in RTF file format seems to hang | Bug |
WORDSNET-19863 | SVG is rendered incorrectly in output DOCX/PDF | Bug |
WORDSNET-19352 | DOCX to PDF conversion issue with heading numbers | Bug |
WORDSNET-19647 | SVG images not displayed correctly | Bug |
WORDSNET-20069 | A table header is repeated after conversion from DOTX to DOCX | Bug |
WORDSNET-19885 | HTML file load wrong encoding | Bug |
WORDSNET-20288 | Chinese text is overlapping in icon caption of OleObject | Bug |
WORDSNET-20290 | The width of the fraction is incorrect after converting to PDF | Bug |
WORDSNET-20292 | Number of type string unexpectedly changes the value in LINQ Reporting Engine | Bug |
WORDSNET-20223 | System.ArgumentOutOfRangeException when saving the document on Xamarin | Bug |
WORDSNET-20134 | A Pageref appearing in PDF Table of Contents | Bug |
WORDSNET-20139 | Infinite loop while converting DOCX to PDF | Bug |
WORDSNET-19929 | An Arial bold formatting has been invalidated in PDF | Bug |
WORDSNET-20152 | Ignore fonts from %WINDIR%\Fonts\Deleted folder | Bug |
WORDSNET-20271 | Invalid “d” attribute value of SVG Path leads to an exception | Bug |
WORDSNET-20153 | DOCX to HTML conversion issue with image position | Bug |
WORDSNET-20163 | Word file containing images doesn’t get properly converted to PDF file | Bug |
WORDSNET-19664 | IncludePicture Image does not scale properly | Bug |
WORDSNET-20164 | NullReferenceException is thrown upon converting HTML to MD | Bug |
WORDSNET-20181 | System.InvalidOperationException is thrown while inserting a document into another | Bug |
WORDSNET-20320 | Aspose.Words.Document constructor hangs for ODT under netcoreapp3.1 | Bug |
WORDSNET-20171 | On conversion from MHTML to PDF, the exception “NullReferenceException” has been thrown | Bug |
WORDSNET-18360 | Text is overlapped after conversion from DOCX to PDF | Bug |
WORDSNET-11448 | Thai Text rendering issue in output TIFF/PDF | Bug |
WORDSNET-19688 | Paragraph spacing has been automatically changed to 10 | Bug |
WORDSNET-15503 | Paragraph’ line is rendered on the previous page in output PDF | Bug |
WORDSNET-19603 | Just open and save DOCX document, the style is modified | Bug |
WORDSNET-15463 | DOC to PDF - Output is incorrect on long content | Bug |
WORDSNET-15928 | The blank page is inserted after conversion from DOCX to PDF | Bug |
WORDSNET-14528 | Shapes do not render correctly in output HtmlFixed | Bug |
Public API and Backward Incompatible Changes
This section lists public API changes that were introduced in Aspose.Words 20.5. It includes not only new and obsoleted public methods, but also a description of any changes in the behavior behind the scenes in Aspose.Words which may affect existing code. Any behavior introduced that could be seen as regression and modifies the existing behavior is especially important and is documented here.
Added a new public property OoxmlSaveOptions.CompressionLevel
Related issue: WORDSNET-20169
A new public option has been added to the ‘OoxmlSaveOptions’ class:
.NET
/// <summary>
/// Specifies the compression level used to save document.
/// </summary>
public CompressionLevel CompressionLevel
The corresponding public ‘CompressionLevel’ enum has been added to the ‘Aspose.Words.Saving’ namespace:
.NET
/// <summary>
/// The compression level for OOXML files.
/// <para>
/// (DOCX and DOTX files are internally a ZIP-archive, this property controls the compression level of the archive.
/// </para>
/// <para>
/// Note, that FlatOpc file is not a ZIP-archive, therefore, this property does not affect the FlatOpc files.)
/// </para>
/// </summary>
public enum CompressionLevel
{
/// <summary>
/// Normal compression level. Default compression level used by Aspose.Words.
/// </summary>
Normal = 0,
/// <summary>
/// Maximum compression level.
/// </summary>
Maximum = 1,
/// <summary>
/// Fast compression level.
/// </summary>
Fast = 2,
/// <summary>
/// Super Fast compression level. Microsoft Word uses this compression level.
/// </summary>
SuperFast = 3
}
Use Case: Explains how to specify the compression level ‘SuperFast’ (used by Microsoft Word) to save the document.
.NET
Document doc = new Document("in.docx");
OoxmlSaveOptions so = new OoxmlSaveOptions(SaveFormat.Docx);
so.CompressionLevel = CompressionLevel.SuperFast;
doc.Save("out.docx", so);
Added page layout callback
Related issue WORDSNET-19093
Document.LayoutOptions.Callback property
.NET
/// <summary>
/// Gets or sets <see cref="IPageLayoutCallback"/> implementation used by page layout model.
/// </summary>
public IPageLayoutCallback Callback
An interface implemented by application:
.NET
public interface IPageLayoutCallback
{
/// <summary>
/// This is called to notify of layout build and rendering progress.
/// </summary>
/// <remarks>
/// Exception when thrown by implementation aborts layout build process.<para />
/// </remarks>
void Notify(PageLayoutCallbackArgs args);
}
Event arguments
.NET
public class PageLayoutCallbackArgs
{
/// <summary>
/// Gets event.
/// </summary>
public PageLayoutEvent Event { get; }
/// <summary>
/// Gets document.
/// </summary>
public Document Document
{
get { return _Document; }
}
/// <summary>
/// Gets 0-based index of the page in the document this event relates to.
/// Returns negative value if there is no associated page, or if page was removed during reflow.
/// </summary>
public int PageIndex
{
get { return Part != null ? Part.GetPage().GetIndex() : -1; }
}
}
Event codes
.NET
public enum PageLayoutEvent
{
/// <summary>
/// Default value
/// </summary>
None,
/// <summary>
/// Corresponds to a checkpoint in code which is often visited and which is suitable to abort process.<para/>
/// While inside <see cref="IPageLayoutCallback.Notify(PageLayoutCallbackArgs)"/> throw custom exception to abort process.<para/>
/// You can throw when handling any callback event to abort process.<para/>
/// Note that if process is aborted the page layout model remains in undefined state. If process is aborted upon reflow of a complete page,
/// however, it should be possible to use layout model up to the end of that page.<para/>
/// </summary>
WatchDog,
/// <summary>
/// Build of the page layout has started. Fired once.
/// This is the first event which occurs when <see cref="Document.UpdatePageLayout"/> is called.
/// </summary>
BuildStarted,
/// <summary>
/// Build of the page layout has finished. Fired once.
/// This is the last event which occurs when <see cref="Document.UpdatePageLayout"/> is called.
/// </summary>
BuildFinished,
/// <summary>
/// Conversion of document model to page layout has started. Fired once.
/// This occurs when layout model starts pulling document content.
/// </summary>
ConversionStarted,
/// <summary>
/// Conversion of document model to page layout has finished. Fired once.
/// This occurs when layout model stops pulling document content.
/// </summary>
ConversionFinished,
/// <summary>
/// Reflow of the page layout has started. Fired once.
/// This occurs when layout model starts reflowing document content.
/// </summary>
ReflowStarted,
/// <summary>
/// Reflow of the page layout has finished. Fired once.
/// This occurs when layout model stops reflowing document content.
/// </summary>
ReflowFinished,
/// <summary>
/// Reflow of the page has started.
/// Note that page may reflow multiple times and that reflow may restart before it is finished.
/// <seealso cref="PageLayoutCallbackArgs.PageIndex"/>
/// </summary>
PartReflowStarted,
/// <summary>
/// Reflow of the page has finished.
/// Note that page may reflow multiple times and that reflow may restart before it is finished.
/// <seealso cref="PageLayoutCallbackArgs.PageIndex"/>
/// </summary>
PartReflowFinished,
/// <summary>
/// Rendering of page has started. This is fired once per page.
/// </summary>
PartRenderingStarted,
/// <summary>
/// Rendering of page has finished. This is fired once per page.
/// </summary>
PartRenderingFinished,
}
Added public property CleanupOptions.DuplicateStyle
A new public property DuplicateStyle has been added into the CleanupOptions class:
.NET
/// <summary>
/// Gets/sets a flag indicating whether duplicate styles should be removed from document.
/// Default value is <b>false</b>.
/// </summary>
public bool DuplicateStyle { get; set; }
Use Case:
.NET
Document doc = new Document(fileName);
CleanupOptions options = new CleanupOptions();
options.DuplicateStyle = true;
doc.Cleanup(options);
doc.Save(outFileName);
Added а new public method FontInfo.GetEmbeddedFontAsOpenType()
Related issue: WORDSNET-20249
A new method GetEmbeddedFontAsOpenType() has been added to FontInfo class. It allows to convert embedded fonts in Embedded OpenType format (which comes from .doc documents) to OpenType.
.NET
/// <summary>
/// Gets an embedded font file in OpenType format. Fonts in Embedded OpenType format are converted to OpenType.
/// </summary>
/// <param name="style">Specifies the font style to retrieve.</param>
/// <returns>Returns <c>null</c> if the specified font is not embedded.</returns>
public byte[] GetEmbeddedFontAsOpenType(EmbeddedFontStyle style)
New helper class to work with Watermark inside document was introduced
Related issue: WORDSNET-4879.
The new property Watermark has been added to the Document class.
.NET
/// <summary>
/// Provides access to the document watermark.
/// </summary>
public Watermark Watermark { get; }
The new Watermark class allows adding/removing the watermark from the document. A watermark can be created from a text or from an image.
.NET
/// <summary>
/// Represents class to work with document watermark.
/// </summary>
public sealed class Watermark
{
/// <summary>
/// Adds Text watermark into the document.
/// </summary>
/// <param name="text">Text that displays as a watermark.</param>
/// <remarks>
/// The text length should be in the range from 1 to 200 inclusive.
/// The text cannot be null or consist only of whitespaces.
/// </remarks>
/// <exception cref="ArgumentOutOfRangeException">
/// Throws when the text length is out of range or the text consists only of whitespaces.
/// </exception>
/// <exception cref="ArgumentNullException">
/// Throws when the text is null.
/// </exception>
public void SetText(string text)
/// <summary>
/// Adds Text watermark into the document.
/// </summary>
/// <param name="text">Text that displays as a watermark.</param>
/// <param name="options">Defines additional options for the text watermark.</param>
/// <remarks>
/// The text length should be in the range from 1 to 200 inclusive.
/// The text cannot be null or consist only of whitespaces.
/// </remarks>
/// <exception cref="ArgumentOutOfRangeException">
/// Throws when the text length is out of range or the text consists only of whitespaces.
/// </exception>
/// <exception cref="ArgumentNullException">
/// Throws when the text is null.
/// </exception>
/// <remarks>If options is null, the watermark will be set with default properties.</remarks>
public void SetText(string text, TextWatermarkOptions options)
/// <summary>
/// Adds Image watermark into the document.
/// </summary>
/// <param name="image">Image that displays as a watermark.</param>
/// <exception cref="ArgumentNullException">
/// Throws when the image is null.
/// </exception>
public void SetImage(Image image)
/// <summary>
/// Adds Image watermark into the document.
/// </summary>
/// <param name="image">Image that displays as a watermark.</param>
/// <param name="options">Defines additional options for the image watermark.</param>
/// <exception cref="ArgumentNullException">
/// Throws when the image is null.
/// </exception>
/// <remarks>If options is null, the watermark will be set with default properties.</remarks>
public void SetImage(Image image, ImageWatermarkOptions options)
/// <summary>
/// Removes watermark.
/// </summary>
public void Remove()
/// <summary>
/// Returns watermark type.
/// </summary>
public WatermarkType Type { get; }
}
The new enum is provided to determine the type of watermark inside the document.
.NET
/// <summary>
/// Specifies the watermark type.
/// </summary>
public enum WatermarkType
{
/// <summary>
/// Indicates that the text will be used as a watermark.
/// <p>Such a watermark corresponds to a WordArt object.</p>
/// </summary>
Text,
/// <summary>
/// Indicates that the image will be used as a watermark.
/// <p>Such a watermark corresponds to a shape with image.</p>
/// </summary>
Image,
/// <summary>
/// Indicates watermark is no set.
/// </summary>
None
}
The following option classes are provided to customize the watermark.
For Text watermark.
.NET
/// <summary>
/// Contains options that can be specified when adding a watermark with text.
/// </summary>
public class TextWatermarkOptions
{
/// <summary>
/// Gets or sets font family name. The default value is "Calibri".
/// </summary>
public string FontFamily { get; set; }
/// <summary>
/// Gets or sets font color. The default value is Color.Silver.
/// </summary>
public Color Color { get; set; }
/// <summary>
/// Gets or sets a font size. The default value is 0 - auto.
/// </summary>
/// <remarks>
/// <p>Valid values range from 0 to 65.5 inclusive.</p>
/// <p> Auto font size means that the watermark will be scaled to its max width and max height relative to
/// the page margins.</p>
/// </remarks>
/// <exception cref="ArgumentOutOfRangeException">
/// Throws when argument was out of the range of valid values.
/// </exception>
public float FontSize { get; set; }
/// <summary>
/// Gets or sets a boolean value which is responsible for opacity of the watermark.
/// The default value is <code>true</code>.
/// </summary>
public bool IsSemitrasparent { get; set; }
/// <summary>
/// Gets or sets layout of the watermark. The default value is <see cref="WatermarkLayout.Diagonal"/>.
/// </summary>
public WatermarkLayout Layout { get; set; }
}
The new enum is provided to set the text watermark in a diagonal or horizontal layout.
.NET
/// <summary>
/// Defines layout of the watermark relative to the watermark center.
/// </summary>
public enum WatermarkLayout
{
/// <summary>
/// Horizontal watermark layout. Corresponds to 0 degrees of rotation.
/// </summary>
Horizontal = 0,
/// <summary>
/// Diagonal watermark layout. Corresponds to 315 degrees of rotation.
/// </summary>
Diagonal = 315
}
For Image watermark:
.NET
/// <summary>
/// Contains options that can be specified when adding a watermark with image.
/// </summary>
public class ImageWatermarkOptions
{
/// <summary>
/// Gets or sets the scale factor expressed as a fraction of the image. The default value is 0 - auto.
/// </summary>
/// <remarks>
/// <p>Valid values range from 0 to 65.5 inclusive.</p>
/// <p>Auto scale means that the watermark will be scaled to its max width and max height relative to
/// the page margins.</p>
/// </remarks>
/// <exception cref="ArgumentOutOfRangeException">
/// Throws when argument was out of the range of valid values.
/// </exception>
public double Scale { get; set; }
/// <summary>
/// Gets or sets a boolean value which is responsible for washout effect of the watermark.
/// The default value is <code>true</code>.
/// </summary>
public bool IsWashout { get; set; }
}
Use Case: Add Text watermark with specific options.
.NET
Document doc = new Document(pathFile);
TextWatermarkOptions options = new TextWatermarkOptions()
{
FontFamily = "Arial",
FontSize = 36,
Color = Color.Black,
Layout = WatermarkLayout.Horizontal,
IsSemitrasparent = false
};
doc.Watermark.SetText("Test", options);
Use Case: Add Image watermark with specific options.
.NET
Document doc = new Document(pathFile);
ImageWatermarkOptions options = new ImageWatermarkOptions()
{
Scale = 5,
IsWashout = false
};
doc.Watermark.SetImage(Image.FromFile(filePath), options);
Use Case: Remove the watermark from the document.
.NET
Document doc = new Document(pathFile);
if (doc.Watermark.Type == WatermarkType.Text)
doc.Watermark.Remove();
New public property Document.ShowGrammaticalErrors has been added
Related issue: WORDSNET-10404
A new public option has been added to the ‘Document’ class:
.NET
/// <summary>
/// Specifies whether to display grammar errors in this document.
/// </summary>
public bool ShowGrammaticalErrors
Use Case: Explains how to show grammar errors.
.NET
Document doc = new Document("in.doc");
doc.ShowGrammaticalErrors = true;
doc.Save("out.doc");
New public property Document.ShowSpellingErrors has been added
Related issue: WORDSNET-10403
A new public option has been added to the ‘Document’ class:
.NET
/// <summary>
/// Specifies whether to display spelling errors in this document.
/// </summary>
public bool ShowSpellingErrors
Use Case: Explains how to show spelling errors.
.NET
Document doc = new Document("in.doc");
doc.ShowSpellingErrors = true;
doc.Save("out.doc");