Aspose.Words for .NET 17.11 Release Notes

Major Features

There are 102 improvements and fixes in this regular monthly release. The most notable are:

  • LINQ Reporting Engine supports dynamic shape background coloring.
  • Improved optional hyphen handling and fixed related infinite loop issue.
  • Improved floating table re-breaking in specific scenarios where content of a table used to be lost outside of a page.
  • Improved table grid computation when cells contain tab characters.
  • Further improved character spacing control handling.
  • PCL documents rendering improved. UCS-2 symbol sets can now be mapped to the printer built-in fonts – it allows to print non-ascii symbols with built-in fonts if supported by printer.
  • A ‘cosmetic’ pen (i.e. pen with fixed 1-pixel width) rendering improved in metafile output documents.
  • Font metrics calculation affecting the vertical positioning of text for GDI+ output rendering improved.
  • Added fallback for strokes with unsupported binary raster operations in metafile rendering.
  • Gamma-correction flag is now taken into account while rendering metafiles brushes.
  • Metafile warnings improved: Added warnings for unsupported binary raster operations. Removed warnings about unsupported metafile records which do not affect the output.

Full List of Issues Covering all Changes in this Release

Key Summary Category
WORDSNET-10454 Contents move down to the page after conversion from Docx to Pdf Bug
WORDSNET-10455 Position of table’s rows is changed after conversion from Docx to Pdf Bug
WORDSNET-12453 Table truncates in PDF - only one page in rendered Bug
WORDSNET-12489 Font changed in saved .rtf document Bug
WORDSNET-12908 Table on edge of page is mangled in PDF Bug
WORDSNET-13313 Multipage table content cutting off on transforming Word to PDF Bug
WORDSNET-13594 Blank pages appear in generated ODT Bug
WORDSNET-13744 /character spacing control/ Chinese text moves to next line after conversion from Doc to HtmlFixed Bug
WORDSNET-13930 Row’s contents are truncated after conversion from Docx to Pdf Bug
WORDSNET-13931 Row’s contents are truncated after conversion from Docx to Pdf Bug
WORDSNET-14119 Docx to Pdf conversion issue with table’s rendering Bug
WORDSNET-14120 Cell’s contents are truncated at the bottom of page in output Pdf Bug
WORDSNET-14252 Table’s cells are completely lost after re-saving Odt Bug
WORDSNET-14340 Html save as Odt - tables display incorrectly Bug
WORDSNET-14885 Distance between list item marker and text increases after saving to HTML Bug
WORDSNET-14927 “DOCX to WML” conversion result has wrong output. Bug
WORDSNET-15108 DOCX to PDF conversion losing pages Bug
WORDSNET-15137 Incorrect table/page layout // DOCX to PDFA: some text is missing in resultant PDFA document Bug
WORDSNET-15147 TOC paragraph spacing difference in Aspose.Words and MS Word Bug
WORDSNET-15205 MS Word 2016 shows page number incorrectly in status bar after saving RTF To DOCX Bug
WORDSNET-15414 Formatting issue in PDF printing Bug
WORDSNET-15551 Process hangs during rendering DOCX to PDF Bug
WORDSNET-15660 /character spacing control/ Position of line break changes in rendered document Bug
WORDSNET-15720 DOCX to PDF conversion issue with Khmer text Bug
WORDSNET-15721 Text is wrapped to next line in table after conversion from DOCX to PDF Bug
WORDSNET-15748 Images are overlapped after conversion from DOCX to HtmlFixed Bug
WORDSNET-15788 List label values are incorrect after joining documents Bug
WORDSNET-15806 DOCX to PDF conversion issue with SmartArt rendering Bug
WORDSNET-15827 DOCX to PNG conversion issue with text formatting Bug
WORDSNET-15853 DOCX to Image conversion issue with text formatting Bug
WORDSNET-15859 Greek letter µ converted to M when DOCX saved as PDF Bug
WORDSNET-15862 Text overlaps on header row border in resultant Image Bug
WORDSNET-15863 DOCX to Image conversion issue with content position Bug
WORDSNET-15864 DOCX to PNG conversion issue with text position inside text-box Bug
WORDSNET-15876 Font color issue in PDF rendering Bug
WORDSNET-15877 Highlighted text issue in Rendered PDF Bug
WORDSNET-15887 /character spacing control/ Incorrect line wrapping in a callout text box Bug
WORDSNET-15888 Aspose.Words generated PCL document is not printing Bug
WORDSNET-15889 Blank Output Produced when Trying to Skip Images or CssStyleSheet during HTML Load Bug
WORDSNET-15894 UTF8 encoding Text to PDF rendering issue Bug
WORDSNET-15901 DOCX to PDF conversion issue with font of chart’s title Bug
WORDSNET-15913 /infinite loop/ DOCX with formatting symbol can’t convert to PDF Bug
WORDSNET-15914 When DOCX is saved as PDF, gradient becomes different. Bug
WORDSNET-15917 Image quality not preserved when saving DOCX to HTML Bug
WORDSNET-15927 DOCX to PDF conversion issue with chart’s rendering Bug
WORDSNET-15930 Adjacent faces of the bevel have different normals in the shared vertices Bug
WORDSNET-15950 Incorrect TOC numbers and index Bug
WORDSNET-15957 Rendering issue of Chinese number list Bug
WORDSNET-15960 Do not read LineSpacing when its Value part is not specified. Bug
WORDSNET-15964 Incorrect exception on password protected document Bug
WORDSNET-15973 MailMergeCleanupOptions.RemoveStaticFields updates the FileName field codes incorrectly Bug
WORDSNET-15976 Document.UpdateFields does not update the TOC field Bug
WORDSNET-15977 Docx to Pdf conversion issue with chart legend items Bug
WORDSNET-15978 Empty PieChart rendering issue Bug
WORDSNET-15983 VML shape fill is lost upon saving to DOCX Bug
WORDSNET-16031 Strange behavior of the text parts in table cells after Mail Merge Bug
WORDSNET-16036 Shape changed during DOC to DOCX conversion Bug
WORDSNET-16056 Support text kerning for ODT Bug
WORDSNET-6624 Extra amount of spacing is added between characters in a word Bug
WORDSNET-7040 Font changes from Arial to Times new Roman during importing nodes Bug
WORDSNET-13098 Applying simple textures (such as Color, Gradient, Picture, etc.) for 3D shapes (hardware rendering) Enhancement
WORDSNET-14901 Issue when loading HTML with incorrect namespace declarations Enhancement
WORDSNET-14948 Incorrect table position in DOM API and resultant HTML Enhancement
WORDSNET-15616 To set file name and extension when inserting ole object using MemoryStream Enhancement
WORDSNET-15903 Support to evaluate IF condition Enhancement
WORDSNET-15915 Shading.BackgroundPatternColor returns incorrect value after updating Theme color Enhancement
WORDSNET-15967 Demo code of Page Splitter has to be simplified and reviewed. Enhancement
WORDSNET-15750 Temporary license implementation issue Exception
WORDSNET-15824 AcceptAllRevisions method thorws InvalidOperationException Exception
WORDSNET-15916 Loading Mhtml file into API is throwing Exception Exception
WORDSNET-15949 Metadata embedding into a document fails when saving Exception
WORDSNET-15953 System.InvalidOperationException throws StructuredDocumentTag.PlaceholderName Exception
WORDSNET-15966 DocumentBuilder.InsertHtml throws System.NullReferenceException when HTML is inserted in table’s cell Exception
WORDSNET-15975 DOCX to DOC conversion throws InvalidOperationException Exception
WORDSNET-15980 Appending document is throwing NullReferenceException Exception
WORDSNET-16014 Calling UpdatePageLayout method throwing exception Exception
WORDSNET-16016 System.InvalidOperationException is thrown while saving DOC to RTF Exception
WORDSNET-16029 Appending RTF documents is throwing NullReferenceException Exception
WORDSNET-16039 Shading formatting of cloned Cell throws NullReferenceException Exception
WORDSNET-13709 Table width is changed after conversion from Docx to Pdf. Feature
WORDSNET-14360 Add feature to include all styles in Resources\AllStyles2007.docx from StyleIdentifier Enum Feature
WORDSNET-14653 Shifted text in a document after conversion from MS Word to PDF Feature
WORDSNET-14722 When DOCX is saved as PDF, table columns have incorrect width Feature
WORDSNET-14970 Add feature to fill shape (text-box) color in Linq Reporting Engine Feature
WORDSNET-15358 Built-in styles in MSW 2013 are different than in MSW 2007. Feature
WORDSNET-15624 Provide method that returns Text in the same order as we see in MS Word, Google Docs, LibreOffice etc Feature
WORDSNET-15739 Applying a radial gradient fill (hardware rendering). Feature
WORDSNET-15740 Applying a rectangular gradient fill (hardware rendering). Feature
WORDSNET-15885 Implement support of transform for radial gradient fill (hardware rendering). Feature
WORDSNET-15893 TOC line spacing is changed in PDF output. Feature
WORDSNET-15900 Empty table appears in ouput PDF Feature
WORDSNET-15981 Get position of floating table in public API Feature
WORDSNET-7575 /revision marks/ Support revision marks upon rendering Feature
WORDSNET-9453 Shape gets overlapped due to its incorrect position Feature
WORDSNET-15746 /performance/ Support to load document partially in DOM Performance
WORDSNET-15910 /infinite loop/ Performance issue with Document.PageCount Performance
WORDSNET-14087 Incorrect table width on page 144 Regression
WORDSNET-14088 Document.UpdateFields does not update page field Regression
WORDSNET-15971 Hebrew text conversion issue in DOCX to MHTML Regression
WORDSNET-16024 IFieldMergingCallback.FieldMerging is not called when mail merge field is inside DISPLAYBARCODE field Regression
WORDSNET-8531 Field.Update method return incorrect value for Page field Regression
WORDSNET-9149 MailMerge.Execute takes very long time to complete Regression

Public API and Backward Incompatible Changes

This section lists public API changes that were introduced in Aspose.Words 17.11. 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.

Supported Dynamic Shape Fill Color Setting for LINQ Reporting Engine

The “Setting Text Background Color Dynamically” section of the engine’s documentation was renamed to “Setting Background Color Dynamically” and updated to describe the change.

Added Word2016 Constant into MsWordVersion Enumeration Type

Related issue WORDSNET-14771.

The following constant is added into the MsWordVersion enumeration type.

/// <summary>
/// Optimize Aspose.Words behavior to match MS Word 2016 version.
/// </summary>
Word2016

It can be passed into the CompatibilityOptions.OptimizeFor method to optimize the document contents as well as Aspose.Words behavior to match MS Word 2016 version.

doc.CompatibilityOptions.OptimizeFor(MsWordVersion.Word2016);

To Set File Name and Extension when Inserting Ole Object using MemoryStream

Related Issue: WORDSNET-15616

The public property OlePackage was added to the OleFormat class to provide ability to set file name, extension and display name for OLE Package. The OlePackage class has 2 public properties:

public class OlePackage
{
    /// <summary>
    /// Gets or sets OLE Package file name.
    /// </summary>
    public string FileName { get; set;}
    /// <summary>
    /// Gets or sets OLE Package display name.
    /// </summary>
    public string DisplayName { get; set;}
}

The example:

//use case
Document document = new Document();
DocumentBuilder builder = new DocumentBuilder(document);
byte[] bs = File.ReadAllBytes(@"D:\downloads\aaa.zip");
using (Stream stream = new MemoryStream(bs))
{
    Shape shape = builder.InsertOleObject(stream, "Package", true, null);
    OlePackage olePackage = shape.OleFormat.OlePackage;
    olePackage.FileName = "bbb.zip";
    olePackage.DisplayName = "bbb.zip";
    document.Save(@"D:\downloads\testInsertZip.docx");
}

Changed Behavior of Range.Replace Methods

Related issue WORDSNET-15624

Behaviour of the following methods of the Range class is changed.

public int Replace(string pattern, string replacement, FindReplaceOptions options);
public int Replace(Regex pattern, string replacement, FindReplaceOptions options)

Now headers/footers of a section are processed in this order:

  • If Section.PageSetup.DifferentFirstPageHeaderFooter is ‘True’:
    • First header
    • First footer
    • Even header
    • Even footer
    • Primary header
    • Primary footer
  • If Section.PageSetup.DifferentFirstPageHeaderFooter is ‘False’:
    • Primary header
    • Primary footer
    • Even header
    • Even footer

Remove Obsolete Methods in DigitalSignatureUtil

Related issue: WORDSNET-15712

Removed obsolete public methods from DigitalSignatureUtil class:

public static void Sign(string srcFileName, string dstFileName, System.Security.Cryptography.X509Certificates.X509Certificate2 certificate, string comments, DateTime signTime);
public static void Sign(string srcFileName, string dstFileName, CertificateHolder certHolder, string comments,DateTime signTime);
public static void Sign(string srcFileName, string dstFileName, CertificateHolder certHolder, string comments, DateTime signTime, string srcPassword);
public static void Sign(Stream srcStream, Stream dstStream, System.Security.Cryptography.X509Certificates.X509Certificate2 certificate, string comments, DateTime signTime);
public static void Sign(Stream srcStream, Stream dstStream, CertificateHolder certHolder, string comments, DateTime signTime);
public static void Sign(Stream srcStream, Stream dstStream, CertificateHolder certHolder, string comments, DateTime signTime, string srcPassword);

Instead, the methods with SignOptions class should be used. See following headings:

Metafile Warnings Improved

Related issue: WORDSNET-15969

  • Added warnings for unsupported binary raster operations. Also added fallback to bitmap rendering in this case on .NET platform.
  • Removed warnings about unsupported metafile records which do not affect the output.
  • Changed type of warnings about unsupported metafile records from DataLoss/UnexpectedContent to more appropriate MinorFormattingLoss.

Get Position of Floating Table in Public API

Related issue: WORDSNET-15981 

Added new public property for floating tables in Table class:

/// <summary>
/// Gets the base object from which the horizontal positioning in the <see cref="AbsoluteHorizontalDistance"/>
/// and/or <see cref="RelativeHorizontalAlignment"/> attribute should be calculated.
/// Default value is <see cref="RelativeHorizontalPosition.Column"/>.
/// </summary>
public RelativeHorizontalPosition HorizontalAnchor
/// <summary>
/// Gets the base object from which the vertical positioning in the <see cref="AbsoluteVerticalDistance"/>
/// attribute should be calculated.
/// Default value is <see cref="RelativeVerticalPosition.Margin"/>.
/// </summary>
public RelativeVerticalPosition VerticalAnchor
/// <summary>
/// Gets table absolute horizontal position relative to the horizontal anchor
/// specified by the <see cref="HorizontalAnchor"/>, in points.
/// Default value is 0.
/// </summary>
public double AbsoluteHorizontalDistance
/// <summary>
/// Gets table absolute vertical position relative to the vertical anchor
/// specified by the <see cref="VerticalAnchor"/>, in points.
/// Default value is 0.
/// </summary>
public double AbsoluteVerticalDistance
/// <summary>
/// Gets whether a floating table shall allow other floating tables in the document
/// to overlap its extents when displayed.
/// Default value is <c>true</c>.
/// </summary>
public bool AllowOverlap

UC:

Document doc = new Document(@"Path\to\document.xml");
foreach (Table table in doc.FirstSection.Body.Tables)
{
    // If table is floating type then print its positioning properties.
    if (table.TextWrapping == TextWrapping.Around)
    {
        Console.WriteLine(table.HorizontalAnchor);
        Console.WriteLine(table.VerticalAnchor);
        Console.WriteLine(table.AbsoluteHorizontalDistance);
        Console.WriteLine(table.AbsoluteVerticalDistance);
        Console.WriteLine(table.AllowOverlap);
    }
}

Added the FieldIf.EvaluateCondition() Method

Related issue: WORDSNET-15903

Customer wanted to evaluate IF condition after mail merge and was requesting some API for it. Since the ComparisonOperator, LeftExpression and RightExpression properties of FieldIf did not fulfill customer requirements, we have introduced the FieldIf.EvaluateCondition() method that immediately returns the result of expression’s evaluation.

/// <summary>
/// Evaluates the condition.
/// </summary>
/// <returns>
/// A <see cref="FieldIfComparisonResult"/> value that represents the result of the condition evaluation.
/// </returns>
public FieldIfComparisonResult EvaluateCondition()

FieldIfComparisonResult enumeration:

/// <summary>
/// Specifies result of the IF field condition evaluation.
/// </summary>
public enum FieldIfComparisonResult
{
    /// <summary>
    /// There is an error in condition.
    /// </summary>
    Error,
    /// <summary>
    /// The condition is <c>true</c>.
    /// </summary>
    True,
    /// <summary>
    /// The condition is <c>false</c>.
    /// </summary>
    False
}

Usage:

DocumentBuilder builder = new DocumentBuilder();
FieldIf field = (FieldIf)builder.InsertField("IF 1 = 1", null);
FieldIfComparisonResult actualResult = field.EvaluateCondition();
Assert.AreEqual(FieldIfComparisonResult.True, actualResult);