Aspose.Words for .NET 17.5 Release Notes
Major Features
There are 84 improvements and fixes in this regular monthly release. The most notable are:
- MailMerge and Metafile rendering performance are improved.
- Support TOA, IMPORT, INCLUDE, SHAPE fields.
- API to bind SDT to CustomXML properties is provided.
- Implemented support for ShapeLayoutLikeWW8 compatibility option.
- Improved calculation of width of spaces in Asian text.
- Improved text wrapping for lines consisting of many tabs.
- Improved layout of multi-column sections when column ends with page break followed by paragraph break.
- A low resolution text rendering to images improved.
- Underlined text in EMF+ images are now rendered into fixed page formats.
- HtmlFixed output file rendering improved (removing zero-sized text boxes).
- Image crop is now taken into account while rendering HtmlFixed.
- Shaded DrawingML images rendering fixed.
- DrawingML Charts rendering improved (axis label placement).
Full List of Issues Covering all Changes in this Release
Key | Summary | Category |
---|---|---|
WORDSNET-10427 | Doc to fixed file format conversion issue with STYLEREF | Bug |
WORDSNET-10833 | non-breaking space. Text position is changed after conversion from Docx to Doc/Pdf | Bug |
WORDSNET-12367 | Aspose.Words does not import the Run nodes correctly in DOM | Bug |
WORDSNET-12544 | space width + BalanceSingleByteDoubleByteWidth. Cell’s text moves to next line in output Pdf | Bug |
WORDSNET-14200 | Rtf to Docx conversion issue with spaces’s width. | Bug |
WORDSNET-14348 | ShapeLayoutLikeWW8. Doc to Pdf conversion issue with content’s position | Bug |
WORDSNET-14349 | Veracode vulnerabilities in running Aspose.Words API code | Bug |
WORDSNET-14355 | ShapeLayoutLikeWW8. Doc to Pdf conversion issue with shape’s position | Bug |
WORDSNET-14408 | Bookmark.Remove() removes only some bookmarks. | Bug |
WORDSNET-14647 | Chart is corrupted after conversion from MS WORD to PDF | Bug |
WORDSNET-14661 | List labels are lost after conversion from RTF to PNG | Bug |
WORDSNET-14667 | Image is lost after modifying the output Doc with MS Word 2003. | Bug |
WORDSNET-14682 | Document.AcceptAllRevisions does not accept all tracked changes | Bug |
WORDSNET-14706 | Chart image size seems bigger than original when exporting to HTML | Bug |
WORDSNET-14874 | Embedded Fonts are gone when printing Aspose.Words generated PDF | Bug |
WORDSNET-14881 | If saving to HTML and CssSavingArgs.CssStream is provided, CSS outputs both to the stream and to a file | Bug |
WORDSNET-14928 | Slope of Drawing Line is inversed when opening and saving the document | Bug |
WORDSNET-14952 | Pictures are shifted in rendered documents | Bug |
WORDSNET-14987 | Chart rendering is not accurate. | Bug |
WORDSNET-14992 | Vertical Axis of chart does not render correctly | Bug |
WORDSNET-14997 | Accept revisions cause a text deletion in Cell | Bug |
WORDSNET-15034 | Paragraph space after is changed after mail merge | Bug |
WORDSNET-15040 | Docx to Pdf conversion issue with Shape’s text formatting | Bug |
WORDSNET-15055 | FontSettings are not document-bound during import from HTML | Bug |
WORDSNET-15067 | STYLEREF fields in headers resolve in Error when rendering Word document with revisions to PDF | Bug |
WORDSNET-15083 | SVG is not exported in output DOC/PDF | Bug |
WORDSNET-15105 | The stroke of SVG image is lost in output PDF | Bug |
WORDSNET-15118 | Inline styles are used when styles are set to be saved separately | Bug |
WORDSNET-15139 | Html to Docx/Pdf conversion issue with SVG image | Bug |
WORDSNET-15171 | Text color is changed in DOCX to JPG conversion | Bug |
WORDSNET-15177 | Range.Replace method does not replace text in footnote | Bug |
WORDSNET-15182 | Text in DrawingML textboxes missing when converting to PDF | Bug |
WORDSNET-15184 | Paragraph’s text is rendered on previous page in output HtmlFixed/Pdf | Bug |
WORDSNET-15202 | Document.AcceptAllRevisions removes the empty paragraph that causes incorrect page layout | Bug |
WORDSNET-15208 | Pages are truncated in output HtmlFixed/PDF | Bug |
WORDSNET-15210 | API throws InvalidCastException upon loading DOCX | Bug |
WORDSNET-15213 | Date field is incorrectly formatted when FieldUpdateCultureSource.FieldCode is used | Bug |
WORDSNET-15227 | Chart’s vertical axis are in correct in output PNG | Bug |
WORDSNET-15228 | Chart’s vertical axis are rendered as decimal instead of integer | Bug |
WORDSNET-15230 | The minimum axis bound is changed in output PNG | Bug |
WORDSNET-15232 | Axis bounds and units of chart are changed in output PNG | Bug |
WORDSNET-15237 | Incorrect conversion of x-axis data of a Chart | Bug |
WORDSNET-15242 | Docx to PDF conversion issue with image rendering | Bug |
WORDSNET-15254 | Horizontal axis of chart does not render correctly | Bug |
WORDSNET-6061 | decimal tab. Table column text aligned incorrectly while doc to png/bmp format. | Bug |
WORDSNET-6126 | Background of Shape becomes black upon converting to EPUB/HTML | Bug |
WORDSNET-6538 | Shapes are misplaced when rendering to TIFF | Bug |
WORDSNET-7377 | decimal tabs. A Run of text splits into three lines in Cell when rendering to Pdf | Bug |
WORDSNET-9371 | Hebrew (RTL) characters are turned into garbage characters during rendering to PDF | Bug |
WORDSNET-9606 | A nested floating table is not rendering in Pdf | Bug |
WORDSNET-11781 | Incorrect text wrapping when a line starts with a huge space | Enhancement |
WORDSNET-14782 | Outline is incorrect upon converting VML to DML | Enhancement |
WORDSNET-15014 | Aspose.Words Objects are very verbose | Enhancement |
WORDSNET-15038 | MHTML import. Image format EMZ is not supported. | Enhancement |
WORDSNET-15052 | Simplifiy OMath when copying it into toc entry | Enhancement |
WORDSNET-15135 | Take image crop in account when render to HtmlFixed. | Enhancement |
WORDSNET-15155 | Documents rendered incorrectly | Enhancement |
WORDSNET-15200 | Obtain the correct distance between list label and content of list item | Enhancement |
WORDSNET-7252 | Backslashes and double quotes are not processed properly by the FieldTokenDecoder | Enhancement |
WORDSNET-7302 | An odd space added between spans at export to PNG | Enhancement |
WORDSNET-8436 | Rendering RTL tables to GDI/PNG is wrong | Enhancement |
WORDSNET-14880 | Exception when Saving Words document and CSS to Stream | Exception |
WORDSNET-14926 | When open .MOBI file, the Aspose.Words.FileCorruptedException occurs. | Exception |
WORDSNET-14996 | AcceptAllRevisions throws System.ArgumentException | Exception |
WORDSNET-15068 | Document.UpdateFields throws System.IndexOutOfRangeException | Exception |
WORDSNET-15079 | Document.UpdateFields throws System.ArgumentException | Exception |
WORDSNET-15160 | Document.UpdateFields throws System.InvalidOperationException | Exception |
WORDSNET-15189 | Aspose.Words.FileCorruptedException is thrown while loading DOCX | Exception |
WORDSNET-15194 | Bookmark.Text throws System.ArgumentException when it is set to empty string | Exception |
WORDSNET-15267 | Document.Save throws System.InvalidOperationException | Exception |
WORDSNET-14363 | Support TOA field | Feature |
WORDSNET-15243 | Support IMPORT field | Feature |
WORDSNET-15244 | Support INCLUDE field | Feature |
WORDSNET-15245 | Support SHAPE field | Feature |
WORDSNET-4738 | Provide an API to bind SDT to CustomXML properties. | Feature |
WORDSNET-15089 | performance. slow Document.MailMerge.Execute | Performance |
WORDSNET-13424 | Odt appears to be corrupted with 16.2.0 and Mono 2.10.8 | Regression |
WORDSNET-15114 | HtmlFixed file size is increased after conversion from DOC | Regression |
WORDSNET-15122 | Escaping problem of double quotes in latest version | Regression |
WORDSNET-15143 | Changing of BackgroundPatternColor doesn’t work. | Regression |
WORDSNET-15146 | Table border can’t be changed. | Regression |
WORDSNET-15149 | DOC to HTML conversion results a big HTML | Regression |
WORDSNET-15161 | Table borders disappear after Paragraph removal | Regression |
WORDSNET-15199 | Header content becomes visible from behind a floating Frame with shading during rendering | Regression |
Public API and Backward Incompatible Changes
This section lists public API changes that were introduced in Aspose.Words 17.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 a regression and modifies existing behavior is especially important and is documented here.
Added Public Method CustomXmlPartCollection.Add(string id, string xml)
A public method is added into the CustomXmlPartCollection class to help in creation of a custom XML part by specifying its XML:
/// <summary>
/// Creates a new XML part with the specified XML and adds it to the collection.
/// </summary>
/// <param name="id">Identifier of a new custom XML part.</param>
/// <param name="xml">XML data of the part.</param>
/// <returns>Created custom XML part.</returns>
public CustomXmlPart Add(string id, string xml)
Value of the ‘xml’ parameter is encoded as UTF8 and is stored in creating XML part.
UC for creating a custom XML part by specifying its XML
Document doc = new Document();
CustomXmlPart xmlPart = doc.CustomXmlParts.Add(Guid.NewGuid().ToString("B"), "<root><text>Hello, World!</text></root>");
StructuredDocumentTag sdt = new StructuredDocumentTag(doc, SdtType.PlainText, MarkupLevel.Block);
sdt.XmlMapping.SetMapping(xmlPart, "/root[1]/text[1]", "");
doc.FirstSection.Body.AppendChild(sdt);
Implemented API to Bind StructuredDocumentTag to Node of Custom XML Part
WORDSNET-4738 has been resolved. The following public property is added into the StructuredDocumentTag class:
/// <summary>
/// Gets an object that represents the mapping of this structured document tag to XML data
/// in a custom XML part of the current document.
/// </summary>
/// <remarks>
/// You can use the <see cref="Markup.XmlMapping.SetMapping"/> method of this object to map
/// a structured document tag to XML data.
/// </remarks>
public XmlMapping XmlMapping { get; }
Public methods of the XmlMapping class:
/// <summary>
/// Specifies the information that is used to establish a mapping between the parent
/// structured document tag and an XML element stored within a custom XML data part in the document.
/// </summary>
public class XmlMapping
{
/// <summary>
/// Sets a mapping between the parent structured document tag and an XML node of a custom XML data part.
/// </summary>
/// <param name="customXmlPart">A custom XML data part to map to.</param>
/// <param name="xPath">An XPath expression to find the XML node.</param>
/// <param name="prefixMapping">XML namespace prefix mappings to evaluate the XPath.</param>
/// <returns>A flag indicating whether the parent structured document tag is successfully mapped to
/// the XML node.</returns>
public bool SetMapping(CustomXmlPart customXmlPart, string xPath, string prefixMapping);
/// <summary>
/// Deletes mapping of the parent structured document to XML data.
/// </summary>
public void Delete();
/// <summary>
/// Returns the custom XML data part to which the parent structured document tag is mapped.
/// </summary>
public CustomXmlPart CustomXmlPart { get; }
/// <summary>
/// Returns the XPath expression, which is evaluated to find the custom XML node
/// that is mapped to the parent structured document tag.
/// </summary>
public string XPath { get; }
/// <summary>
/// Returns XML namespace prefix mappings to evaluate the <see cref="XPath"/>.
/// </summary>
/// <remarks>
/// Specifies the set of prefix mappings, which shall be used to interpret the XPath expression
/// when the XPath expression is evaluated against the custom XML data parts in the document.
/// </remarks>
public string PrefixMappings { get; }
/// <summary>
/// Returns <b>true</b> if the parent structured document tag is successfully mapped to XML data.
/// </summary>
public bool IsMapped { get; }
}
UC for creation of an XML part and binding a content control to it
Document doc = new Document();
CustomXmlPart xmlPart = doc.CustomXmlParts.Add(Guid.NewGuid().ToString("B"), "<root><text>Hello, World!</text></root>");
StructuredDocumentTag sdt = new StructuredDocumentTag(doc, SdtType.PlainText, MarkupLevel.Block);
doc.FirstSection.Body.AppendChild(sdt);
sdt.XmlMapping.SetMapping(xmlPart, "/root[1]/text[1]", "");
doc.Save(fileName);
CellFormat.SetPaddings Method was Introduced.
WORDSNET-15014 (Enhancement) has been resolved. We have added a simple method allowing to set all cell paddings in one line of code.
/// <summary>
/// Sets the amount of space (in points) to add to the left/top/right/bottom of the contents of cell.
/// </summary>
public void SetPaddings(double leftPadding, double topPadding, double rightPadding, double bottomPadding)
You can use this method instead of using four properties:
// Set all cell paddings.
builder.CellFormat.SetPaddings(30, 40, 50, 60);