MathObjectType

MathObjectType enumeration

Specifies type of an Office Math object.

public enum MathObjectType

Values

NameValueDescription
OMath0Instance of mathematical text.
OMathPara1Math paragraph, or display math zone, that contains one or more OMath elements that are in display mode.
Accent2Accent function, consisting of a base and a combining diacritical mark.
Bar3Bar function, consisting of a base argument and an overbar or underbar.
BorderBox4Border Box object, consisting of a border drawn around an instance of mathematical text (such as a formula or equation)
Box5Box object, which is used to group components of an equation or other instance of mathematical text.
Delimiter6Delimiter object, consisting of opening and closing delimiters (such as parentheses, braces, brackets, and vertical bars), and an element contained inside.
Degree7Degree in the mathematical radical.
Argument8Argument object. Encloses Office Math entities when they are used as arguments to other Office Math entities.
Array9Array object, consisting of one or more equations, expressions, or other mathematical text runs that can be vertically justified as a unit with respect to surrounding text on the line.
Fraction10Fraction object, consisting of a numerator and denominator separated by a fraction bar.
Denominator11Denominator of a fraction object.
Numerator12Numerator of the Fraction object.
Function13Function-Apply object, which consists of a function name and an argument element acted upon.
FunctionName14Name of the function. For example, function names are sin and cos.
GroupCharacter15Group-Character object, consisting of a character drawn above or below text, often with the purpose of visually grouping items
Limit16Lower limit of the LowerLimit object and the upper limit of the UpperLimit function.
LowerLimit17Lower-Limit object, consisting of text on the baseline and reduced-size text immediately below it.
UpperLimit18Upper-Limit object, consisting of text on the baseline and reduced-size text immediately above it.
Matrix19Matrix object, consisting of one or more elements laid out in one or more rows and one or more columns.
MatrixRow20Single row of the matrix.
NAry21N-ary object, consisting of an n-ary object, a base (or operand), and optional upper and lower limits.
Phantom22Phantom object.
Radical23Radical object, consisting of a radical, a base element, and an optional degree .
SubscriptPart24Subscript of the object that can have subscript part.
SuperscriptPart25Superscript of the superscript object.
PreSubSuperscript26Pre-Sub-Superscript object, which consists of a base element and a subscript and superscript placed to the left of the base.
Subscript27Subscript object, which consists of a base element and a reduced-size script placed below and to the right.
SubSuperscript28Sub-superscript object, which consists of a base element, a reduced-size script placed below and to the right, and a reduced-size script placed above and to the right.
Supercript29Superscript object, which consists of a base element and a reduced-size script placed above and to the right.

Examples

Shows how to print the node structure of every office math node in a document.

public void OfficeMathToText()
{
    Document doc = new Document(MyDir + "DocumentVisitor-compatible features.docx");
    OfficeMathStructurePrinter visitor = new OfficeMathStructurePrinter();

    // When we get a composite node to accept a document visitor, the visitor visits the accepting node,
    // and then traverses all the node's children in a depth-first manner.
    // The visitor can read and modify each visited node.
    doc.Accept(visitor);

    Console.WriteLine(visitor.GetText());
}

/// <summary>
/// Traverses a node's non-binary tree of child nodes.
/// Creates a map in the form of a string of all encountered OfficeMath nodes and their children.
/// </summary>
public class OfficeMathStructurePrinter : DocumentVisitor
{
    public OfficeMathStructurePrinter()
    {
        mBuilder = new StringBuilder();
        mVisitorIsInsideOfficeMath = false;
    }

    /// <summary>
    /// Gets the plain text of the document that was accumulated by the visitor.
    /// </summary>
    public string GetText()
    {
        return mBuilder.ToString();
    }

    /// <summary>
    /// Called when a Run node is encountered in the document.
    /// </summary>
    public override VisitorAction VisitRun(Run run)
    {
        if (mVisitorIsInsideOfficeMath) IndentAndAppendLine("[Run] \"" + run.GetText() + "\"");

        return VisitorAction.Continue;
    }

    /// <summary>
    /// Called when an OfficeMath node is encountered in the document.
    /// </summary>
    public override VisitorAction VisitOfficeMathStart(OfficeMath officeMath)
    {
        IndentAndAppendLine("[OfficeMath start] Math object type: " + officeMath.MathObjectType);
        mDocTraversalDepth++;
        mVisitorIsInsideOfficeMath = true;

        return VisitorAction.Continue;
    }

    /// <summary>
    /// Called after all the child nodes of an OfficeMath node have been visited.
    /// </summary>
    public override VisitorAction VisitOfficeMathEnd(OfficeMath officeMath)
    {
        mDocTraversalDepth--;
        IndentAndAppendLine("[OfficeMath end]");
        mVisitorIsInsideOfficeMath = false;

        return VisitorAction.Continue;
    }

    /// <summary>
    /// Append a line to the StringBuilder and indent it depending on how deep the visitor is into the document tree.
    /// </summary>
    /// <param name="text"></param>
    private void IndentAndAppendLine(string text)
    {
        for (int i = 0; i < mDocTraversalDepth; i++) mBuilder.Append("|  ");

        mBuilder.AppendLine(text);
    }

    private bool mVisitorIsInsideOfficeMath;
    private int mDocTraversalDepth;
    private readonly StringBuilder mBuilder;
}

See Also