CompatibilityOptions

CompatibilityOptions class

包含兼容性选项(即在兼容性 选项卡选项Microsoft Word 中的对话框).

要了解更多信息,请访问检测文件格式并检查格式兼容性文档文章。

public class CompatibilityOptions

特性

姓名描述
AdjustLineHeightInTable { get; set; }将文档网格线间距添加到表格单元格中的线。
AlignTablesRowByRow { get; set; }独立对齐表行。
AllowSpaceOfSameStyleInTable { get; set; }允许表中段落的上下文间距。
ApplyBreakingRules { get; set; }使用旧版埃塞俄比亚语和阿姆哈拉语断线规则。
AutofitToFirstFixedWidthCell { get; set; }允许表格列超过组成单元格的首选宽度。
AutoSpaceLikeWord95 { get; set; }模拟 Word 95 全角字符间距。
BalanceSingleByteDoubleByteWidth { get; set; }平衡单字节和双字节字符。
CachedColBalance { get; set; }使用缓存的段落信息进行列平衡。
ConvMailMergeEsc { get; set; }将反斜杠引号分隔符视为两个引号。
DisableOpenTypeFontFormattingFeatures { get; set; }指定禁用 OpenType 字体格式化功能。
DisplayHangulFixedWidth { get; set; }始终对韩文字符使用固定宽度。
DoNotAutofitConstrainedTables { get; set; }不要自动调整表格以适合包裹对象旁边。
DoNotBreakConstrainedForcedTable { get; set; }不要破坏浮动表周围的表行。
DoNotBreakWrappedTables { get; set; }不允许浮动表跨页中断。
DoNotExpandShiftReturn { get; set; }不要调整以软换行符结尾的行。
DoNotLeaveBackslashAlone { get; set; }输入时将反斜杠转换为日元符号。
DoNotSnapToGridInCell { get; set; }不要与对象的表格单元格中的文档网格对齐。
DoNotSuppressIndentation { get; set; }计算段落缩进时不要忽略浮动对象。
DoNotSuppressParagraphBorders { get; set; }不要隐藏框架旁边的段落边框。
DoNotUseEastAsianBreakRules { get; set; }使用文档网格时不要压缩可压缩字符。
DoNotUseHTMLParagraphAutoSpacing { get; set; }使用固定段落间距进行 HTML 自动设置。
DoNotUseIndentAsNumberingTabStop { get; set; }在编号后创建制表位时忽略悬挂缩进。
DoNotVertAlignCellWithSp { get; set; }不要垂直对齐包含浮动对象的单元格。
DoNotVertAlignInTxbx { get; set; }忽略文本框中的垂直对齐方式。
DoNotWrapTextWithPunct { get; set; }不允许使用字符网格悬挂标点符号。
FootnoteLayoutLikeWW8 { get; set; }模拟 Word 6.x/95/97 脚注位置。
ForgetLastTabAlignment { get; set; }如果段落未左对齐,则在对齐段落时忽略最后一个制表位的宽度。
GrowAutofit { get; set; }允许表格自动适应页边距。
LayoutRawTableWidth { get; set; }决定表是否应包裹浮动对象时忽略表之前的空间。
LayoutTableRowsApart { get; set; }允许表行独立换行内联对象。
LineWrapLikeWord6 { get; set; }模拟东亚文本的 Word 6.0 换行。
MWSmallCaps { get; set; }模拟 Macintosh 小型大写字母格式的 Word 5.x。
NoColumnBalance { get; set; }不要平衡节内的文本列。
NoExtraLineSpacing { get; set; }不要将内容集中在具有精确行高的行上。
NoLeading { get; set; }不要在文本行之间添加前导。
NoSpaceRaiseLower { get; set; }不要增加升高/降低文本的行高。
NoTabHangInd { get; set; }不要为悬挂缩进创建自定义制表位。
OverrideTableStyleFontSizeAndJustification { get; set; }指定如何评估文档的样式层次结构。
PrintBodyTextBeforeHeader { get; set; }在页眉/页脚内容之前打印正文文本。
PrintColBlack { get; set; }将颜色打印为黑白,无抖动。
SelectFldWithFirstOrLastChar { get; set; }选择第一个或最后一个字符时选择字段。
ShapeLayoutLikeWW8 { get; set; }模拟 Word 97 文本环绕浮动对象。
ShowBreaksInFrames { get; set; }显示框架中存在的分页/分栏符。
SpaceForUL { get; set; }在基线下方为带下划线的东亚文本添加额外的空格。
SpacingInWholePoints { get; set; }仅按整点展开/压缩文本。
SplitPgBreakAndParaMark { get; set; }始终将段落标记移至分页符后的页面。
SubFontBySize { get; set; }在字体替换期间增加字体大小的优先级。
SuppressBottomSpacing { get; set; }忽略页面上最后一行的精确行高。
SuppressSpacingAtTopOfPage { get; set; }忽略页面第一行的最小行高。
SuppressSpBfAfterPgBrk { get; set; }在分页符之后的第一行之前不要使用空格。
SuppressTopSpacing { get; set; }忽略页面第一行的最小和精确行高。
SuppressTopSpacingWP { get; set; }模拟 WordPerfect 5.x 行距。
SwapBordersFacingPgs { get; set; }交换奇数页上的段落边框。
SwapInsideAndOutsideForMirrorIndentsAndRelativePositioning { get; set; }指定交换内部和外部以实现镜像缩进和相对定位。
TransparentMetafiles { get; set; }指定不将图元文件图片后面的区域清空。
TruncateFontHeightsLikeWP6 { get; set; }模拟 WordPerfect 6.x 字体高度计算。
UICompat97To2003 { get; set; }True 则禁用与 Word97-2003 不兼容的 UI 功能。 默认值为错误的.
UlTrailSpace { get; set; }为所有尾随空格添加下划线。
UnderlineTabInNumList { get; set; }在编号后面的字符下划线。
UseAltKinsokuLineBreakRules { get; set; }使用东亚断线规则的备用集。
UseAnsiKerningPairs { get; set; }使用字体中的 ANSI 字距调整对。
UseFELayout { get; set; }不要绕过东亚/复杂脚本布局代码。
UseNormalStyleForList { get; set; }不自动将列表段落样式应用于带项目符号/编号的文本。
UsePrinterMetrics { get; set; }使用打印机指标显示文档。
UseSingleBorderforContiguousCells { get; set; }对表格边框冲突使用简化规则。
UseWord2002TableStyleRules { get; set; }模拟 Word 2002 表格样式规则。
UseWord2010TableStyleRules { get; set; }指定使用 Word2010 表格样式规则。
UseWord97LineBreakRules { get; set; }模拟 Word 97 东亚换行符。
WPJustification { get; set; }模拟 WordPerfect 6.x 段落对齐。
WPSpaceWidth { get; set; }指定是否像 WordPerfect 5.x. 中那样设置空格宽度
WrapTrailSpaces { get; set; }换行尾随空格。

方法

姓名描述
OptimizeFor(MsWordVersion)允许优化文档内容以及针对特定版本的 MS Word 的默认 Aspose.Words 行为。

例子

演示如何垂直对齐文本框的文本内容。

Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);

Shape shape = builder.InsertShape(ShapeType.TextBox, 200, 200);

// 将“VerticalAnchor”属性设置为“TextBoxAnchor.Top”
// 将此文本框中的文本与形状的顶部对齐。
// 将“VerticalAnchor”属性设置为“TextBoxAnchor.Middle”
// 将此文本框中的文本与形状的中心对齐。
// 将“VerticalAnchor”属性设置为“TextBoxAnchor.Bottom”
// 将此文本框中的文本与形状的底部对齐。
shape.TextBox.VerticalAnchor = verticalAnchor;

builder.MoveTo(shape.FirstParagraph);
builder.Write("Hello world!");

// 从 Microsoft Word 2007 开始,文本框中文本的垂直对齐功能可用。
doc.CompatibilityOptions.OptimizeFor(MsWordVersion.Word2007);
doc.Save(ArtifactsDir + "Shape.VerticalAnchor.docx");

演示如何为保存的文档设置要遵守的 OOXML 合规性规范。

Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);

// 如果我们配置兼容性选项以符合 Microsoft Word 2003,
// 插入图像将使用 VML 定义其形状。
doc.CompatibilityOptions.OptimizeFor(MsWordVersion.Word2003);
builder.InsertImage(ImageDir + "Transparent background logo.png");

Assert.AreEqual(ShapeMarkupLanguage.Vml, ((Shape)doc.GetChild(NodeType.Shape, 0, true)).MarkupLanguage);

// “ISO/IEC 29500:2008”OOXML 标准不支持 VML 形状。
// 如果我们将 SaveOptions 对象的“Compliance”属性设置为“OoxmlCompliance.Iso29500_2008_Strict”,
 // 我们在传递此对象时保存的任何文档都必须遵循该标准。
OoxmlSaveOptions saveOptions = new OoxmlSaveOptions
{
    Compliance = OoxmlCompliance.Iso29500_2008_Strict,
    SaveFormat = SaveFormat.Docx
};

doc.Save(ArtifactsDir + "OoxmlSaveOptions.Iso29500Strict.docx", saveOptions);

// 我们保存的文档使用 DML 定义形状,以遵守“ISO/IEC 29500:2008”OOXML 标准。
doc = new Document(ArtifactsDir + "OoxmlSaveOptions.Iso29500Strict.docx");

Assert.AreEqual(ShapeMarkupLanguage.Dml, ((Shape)doc.GetChild(NodeType.Shape, 0, true)).MarkupLanguage);

演示如何针对不同版本的 Microsoft Word 优化文档。

public void OptimizeFor()
{
    Document doc = new Document();

    // 该对象包含每个文档特有的广泛标志列表
    // 这使我们能够促进与旧版本 Microsoft Word 的向后兼容性。
    CompatibilityOptions options = doc.CompatibilityOptions;

    // 打印空白文档的默认设置。
    Console.WriteLine("\nDefault optimization settings:");
    PrintCompatibilityOptions(options);

    // 我们可以通过“文件”-> 在 Microsoft Word 中访问这些设置“选项”-> “高级”-> “兼容选项...”。
    doc.Save(ArtifactsDir + "CompatibilityOptions.OptimizeFor.DefaultSettings.docx");

    // 我们可以使用 OptimizeFor 方法来确保与特定 Microsoft Word 版本的最佳兼容性。
    doc.CompatibilityOptions.OptimizeFor(MsWordVersion.Word2010);
    Console.WriteLine("\nOptimized for Word 2010:");
    PrintCompatibilityOptions(options);

    doc.CompatibilityOptions.OptimizeFor(MsWordVersion.Word2000);
    Console.WriteLine("\nOptimized for Word 2000:");
    PrintCompatibilityOptions(options);
}

/// <summary>
/// 按状态对文档兼容性选项对象中的所有标志进行分组,然后打印每个组。
/// </summary>
private static void PrintCompatibilityOptions(CompatibilityOptions options)
{
    for (int i = 1; i >= 0; i--)
    {
        Console.WriteLine(Convert.ToBoolean(i) ? "\tEnabled options:" : "\tDisabled options:");
        SortedSet<string> optionNames = new SortedSet<string>();

        foreach (System.ComponentModel.PropertyDescriptor descriptor in System.ComponentModel.TypeDescriptor.GetProperties(options))
        {
            if (descriptor.PropertyType == Type.GetType("System.Boolean") && i == Convert.ToInt32(descriptor.GetValue(options)))
            {
                optionNames.Add(descriptor.Name);
            }
        }

        foreach (string s in optionNames)
        {
            Console.WriteLine($"\t\t{s}");
        }
    }
}

也可以看看