mirror of
https://github.com/jkriege2/JKQtPlotter.git
synced 2024-11-16 02:25:50 +08:00
7d686f0c9a
- BREAKING/REWORKED: The \\verb!...!-command now works the same as in LaTeX - NEW: added support for \\begin{verbatim}...\\end{verbatim}, \\begin{verbatim*}...\\end{verbatim*}
176 lines
8.8 KiB
C++
176 lines
8.8 KiB
C++
/*
|
|
Copyright (c) 2008-2022 Jan W. Krieger (<jan@jkrieger.de>)
|
|
with contributions from: Razi Alavizadeh
|
|
|
|
|
|
|
|
This software is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU Lesser General Public License (LGPL) as published by
|
|
the Free Software Foundation, either version 2.1 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU Lesser General Public License (LGPL) for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public License (LGPL)
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
|
|
|
|
|
|
#ifndef JKQTMATHTEXTTEXTNODE_H
|
|
#define JKQTMATHTEXTTEXTNODE_H
|
|
#include "jkqtmathtext/jkqtmathtext_imexport.h"
|
|
#include "jkqtmathtext/jkqtmathtexttools.h"
|
|
#include "jkqtmathtext/nodes/jkqtmathtextnode.h"
|
|
#include <QPainter>
|
|
|
|
class JKQTMathText; // forward
|
|
// JKQTMATHTEXT_LIB_EXPORT
|
|
|
|
|
|
/** \brief base class for nodes representing text in the syntax tree
|
|
* \ingroup jkqtmathtext_items
|
|
*
|
|
* This node is a collection of tools, necessary to draw text. It
|
|
* is the base for nodes, such as:
|
|
* - JKQTMathTextTextNode
|
|
* - JKQTMathTextVerbatimNode
|
|
* .
|
|
*/
|
|
class JKQTMATHTEXT_LIB_EXPORT JKQTMathTextTextBaseNode: public JKQTMathTextNode {
|
|
public:
|
|
explicit JKQTMathTextTextBaseNode(JKQTMathText* parent, const QString& text);
|
|
virtual ~JKQTMathTextTextBaseNode() override;
|
|
/** \copydoc JKQTMathTextNode::toHtml() */
|
|
virtual bool toHtml(QString& html, JKQTMathTextEnvironment currentEv, JKQTMathTextEnvironment defaultEv) override;
|
|
/** \copydoc text */
|
|
QString getText() const;
|
|
protected:
|
|
/** \brief text-contents of the node */
|
|
QString text;
|
|
/** \brief draw a given \a txt in the font defined by \a currentEv at (\a x , \a y ) using the given \a painter
|
|
*
|
|
* This function implements drawing of synthesized fonts, e.g. MTEblackboard when JKQTMathText::isFontBlackboardSimulated() is \c true .
|
|
*/
|
|
void drawString(QPainter& painter, const JKQTMathTextEnvironment& currentEv, double x, double y, const QString& txt) const;
|
|
/** \brief draw a given \a txt in the font \a f using additional informaion (but not currentEv::getFont() ) from \a currentEv at (\a x , \a y ) using the given \a painter
|
|
*
|
|
* This function implements drawing of synthesized fonts, e.g. MTEblackboard when JKQTMathText::isFontBlackboardSimulated() is \c true .
|
|
*/
|
|
void drawString(QPainter& painter, const JKQTMathTextEnvironment ¤tEv, const QFont& f, double x, double y, const QString& txt) const;
|
|
/** \brief transforms the \a text before sizing/drawing (may e.g. exchange special letters for other unicode symbols etc.) */
|
|
virtual QString textTransform(const QString& text, const JKQTMathTextEnvironment& currentEv) const;
|
|
};
|
|
|
|
|
|
/** \brief subclass representing one text node in the syntax tree
|
|
* \ingroup jkqtmathtext_items
|
|
*/
|
|
class JKQTMATHTEXT_LIB_EXPORT JKQTMathTextTextNode: public JKQTMathTextTextBaseNode {
|
|
public:
|
|
explicit JKQTMathTextTextNode(JKQTMathText* parent, const QString& text, bool addWhitespace, bool stripInnerWhitepace=false);
|
|
virtual ~JKQTMathTextTextNode() override;
|
|
/** \copydoc JKQTMathTextNode::draw() */
|
|
virtual double draw(QPainter& painter, double x, double y, JKQTMathTextEnvironment currentEv, const JKQTMathTextNodeSize* prevNodeSize=nullptr) override;
|
|
/** \copydoc JKQTMathTextNode::getTypeName() */
|
|
virtual QString getTypeName() const override ;
|
|
protected:
|
|
/** \copydoc JKQTMathTextNode::getSizeInternal() */
|
|
virtual void getSizeInternal(QPainter& painter, JKQTMathTextEnvironment currentEv, double& width, double& baselineHeight, double& overallHeight, double& strikeoutPos, const JKQTMathTextNodeSize* prevNodeSize=nullptr) override;
|
|
/** \brief calculates the size of the node, much like JKQTMathTextNode::getSizeInternal(), but returns additional properties that can be reused for drawing */
|
|
void getSizeInternalAndData(QPainter& painter, JKQTMathTextEnvironment currentEv, double& width, double& baselineHeight, double& overallHeight, double& strikeoutPos, QStringList& textpart, QList<bool>& fontForcedUpright, QList<double>& textpartXPos) ;
|
|
/** \brief split text for Math-Mode into section with "normal" text and "forced upright" text */
|
|
static void splitTextForMathMode(const QString& txt, QStringList& textpart, QList<bool>& fontForcedUpright);
|
|
/** \brief transforms the \a text before sizing/drawing (may e.g. exchange special letters for other unicode symbols etc.) */
|
|
virtual QString textTransform(const QString& text, const JKQTMathTextEnvironment& currentEv) const override;
|
|
};
|
|
|
|
|
|
/** \brief subclass representing a verbatim (plain-text) node with support for line-breaks in the syntax tree
|
|
* \ingroup jkqtmathtext_items
|
|
*
|
|
* The layout of the lines can left-aligned, right-aligned or centered.
|
|
*
|
|
* \image html jkqtmathtext_verticallist.png
|
|
*
|
|
* \image html jkqtmathtext_verticalalignment.png
|
|
*
|
|
* \image html jkqtmathtext_horizontalalignment.png
|
|
*/
|
|
class JKQTMATHTEXT_LIB_EXPORT JKQTMathTextVerbatimNode: public JKQTMathTextTextBaseNode {
|
|
public:
|
|
explicit JKQTMathTextVerbatimNode(JKQTMathText* parent, const QString& text, bool visibleWhitespace=false, JKQTMathTextHorizontalAlignment _alignment=MTHALeft, double _linespacingFactor=1.0, JKQTMathTextVerticalOrientation _verticalOrientation=MTVOFirstLine);
|
|
/** \copydoc JKQTMathTextNode::getTypeName() */
|
|
virtual QString getTypeName() const override;
|
|
/** \copydoc alignment */
|
|
JKQTMathTextHorizontalAlignment getAlignment() const;
|
|
/** \copydoc verticalOrientation */
|
|
JKQTMathTextVerticalOrientation getVerticalOrientation() const;
|
|
/** \copydoc lineSpacingFactor */
|
|
double getLineSpacingFactor() const;
|
|
/** \copydoc visibleWhitespace */
|
|
bool getVisibleWhitespace() const;
|
|
/** \copydoc JKQTMathTextNode::draw() */
|
|
virtual double draw(QPainter& painter, double x, double y, JKQTMathTextEnvironment currentEv, const JKQTMathTextNodeSize* prevNodeSize=nullptr) override;
|
|
/** \copydoc JKQTMathTextNode::toHtml() */
|
|
virtual bool toHtml(QString& html, JKQTMathTextEnvironment currentEv, JKQTMathTextEnvironment defaultEv) override;
|
|
protected:
|
|
/** \brief alignment scheme used to lay out all lines
|
|
*
|
|
* \image html jkqtmathtext_horizontalalignment.png
|
|
*/
|
|
JKQTMathTextHorizontalAlignment alignment;
|
|
/** \brief spacing of the separate lines, as factor of the default line-spacing [Default: 1].
|
|
*
|
|
* This property can be used to move the lines closer together or farther apart.
|
|
*
|
|
* \image html jkqtmathtext_verticallist.png
|
|
*/
|
|
double lineSpacingFactor;
|
|
/** \brief vertical orientation of the baseline of the whole block (with respect to the single lines)
|
|
*
|
|
* \image html jkqtmathtext_verticalorientation.png
|
|
*/
|
|
JKQTMathTextVerticalOrientation verticalOrientation;
|
|
/** \brief when \c true, whitespaces are displayed with a visible character */
|
|
bool visibleWhitespace;
|
|
|
|
/** \copydoc JKQTMathTextNode::getSizeInternal() */
|
|
virtual void getSizeInternal(QPainter& painter, JKQTMathTextEnvironment currentEv, double& width, double& baselineHeight, double& overallHeight, double& strikeoutPos, const JKQTMathTextNodeSize* prevNodeSize=nullptr) override;
|
|
/** \brief sets all necessary settings in \a currentEv for drawing this node */
|
|
virtual void transformEnvironment(JKQTMathTextEnvironment& currentEv) const;
|
|
|
|
/** \brief describes the layout of the whole node */
|
|
struct LayoutInfo: public JKQTMathTextNodeSize {
|
|
LayoutInfo();
|
|
/** \brief the text from JKQTMathTextVerbatimNode::text, split into lines */
|
|
QStringList lines;
|
|
/** \brief drawing position for each line */
|
|
QList<QPointF> X;
|
|
};
|
|
/** \brief calclates the layout of the whole block/node
|
|
*
|
|
* \note This function does NOT call transformEnvironment();
|
|
* it has to be called before calling this!
|
|
*/
|
|
LayoutInfo calcLayout(QPainter& painter, const JKQTMathTextEnvironment& currentEv) const;
|
|
/** \brief transforms the \a text before sizing/drawing (may e.g. exchange special letters for other unicode symbols etc.) */
|
|
virtual QString textTransform(const QString& text, const JKQTMathTextEnvironment& currentEv) const override;
|
|
};
|
|
|
|
|
|
#endif // JKQTMATHTEXTTEXTNODE_H
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|