2015-07-11 18:56:02 +08:00
/*
2020-08-26 18:58:23 +08:00
Copyright ( c ) 2008 - 2020 Jan W . Krieger ( < jan @ jkrieger . de > )
2018-12-14 05:33:42 +08:00
with contributions from : Razi Alavizadeh
2015-07-11 18:56:02 +08:00
2015-07-12 22:34:27 +08:00
2015-07-11 18:56:02 +08:00
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
2019-02-08 00:24:46 +08:00
the Free Software Foundation , either version 2.1 of the License , or
2015-07-11 18:56:02 +08:00
( 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/>.
*/
/*
Name : jkqtmathtext . h
2019-01-19 16:40:52 +08:00
Copyright : ( c ) 2010 - 2019
2015-07-11 18:56:02 +08:00
Author : Jan krieger < jan @ jkrieger . de > , http : //www.jkrieger.de/
*/
# ifndef JKQTMATHTEXT_H
# define JKQTMATHTEXT_H
# include <QObject>
# include <QSettings>
# include <QPainter>
# include <QString>
# include <QSet>
# include <QFile>
2019-06-22 20:21:32 +08:00
# include "jkqtmathtext/jkqtmathtext_imexport.h"
2015-07-11 18:56:02 +08:00
# include <QWidget>
# include <QLabel>
# include <QHash>
2018-12-03 01:30:12 +08:00
2019-01-20 17:49:29 +08:00
/** \brief initialized Qt-ressources necessary for JKQTMathText
2019-01-10 04:23:24 +08:00
* \ ingroup jkqtmathtext
*/
2019-06-22 20:21:32 +08:00
JKQTMATHTEXT_LIB_EXPORT void initJKQTMathTextResources ( ) ;
2018-12-03 01:30:12 +08:00
2022-06-03 03:02:23 +08:00
/*! \brief represents a font specifier for JKQTMathText. The font consists of two parts: the actual font and the font used for math output (which may be empty)
\ ingroup jkqtmathtext
\ section JKQTMathTextFontSpecifier_specialNames Special FOnt Names
This object also implements replacing special font names with actual fonts . Supported special font names are :
- \ c default / \ c app / \ c application - the applications default font
- \ c times / \ c serif - a general serif font
- \ c sans - serif - a general sans - serif font
- \ c typewriter - a general typewrter / monospaced font
- \ c cursive
- \ c decorative
- \ c fantasy
- \ c monospace
- \ c system
.
If copiled with Qt > 5.3 you can also use these :
- \ c fixed
- \ c smallest_readable
- \ c title
- \ c general
.
*/
struct JKQTMATHTEXT_LIB_EXPORT JKQTMathTextFontSpecifier {
JKQTMathTextFontSpecifier ( ) ;
JKQTMathTextFontSpecifier ( const QString & fontName , const QString & mathFontName ) ;
/** \brief construct a JKQTMathTextFontSpecifier, by parsing a \a fontSpec string with the form \c "FONT_NAME[+MATH_FONT_NAME]". */
static JKQTMathTextFontSpecifier fromFontSpec ( const QString & fontSpec ) ;
/** \brief initialises the object with values from parsing a \a fontSpec string with the form \c "FONT_NAME[+MATH_FONT_NAME]". */
void setFontSpec ( const QString & fontSpec ) ;
/** \brief returns the object's constents as a fontSpec string with the form \c "FONT_NAME[+MATH_FONT_NAME]". */
QString getFontSpec ( ) const ;
/** \copydoc m_fontName */
QString fontName ( ) const ;
/** \copydoc m_mathFontName */
QString mathFontName ( ) const ;
/** \copydoc m_fontName */
void setFontName ( const QString & name ) ;
/** \copydoc m_mathFontName */
void setmathFontName ( const QString & name ) ;
/** \brief finds actual fonts for some predefined special font names, as listed in \ref JKQTMathTextFontSpecifier_specialNames */
static QString transformFontName ( const QString & fontName ) ;
/** \brief same as transformFontName(), but also finds the actual name for XITS, STIX, ASANA,... */
static QString transformFontNameAndDecodeSpecialFonts ( const QString & fontName ) ;
/** \brief leiefert \c true, wenn ein fontName() verfügbar ist */
bool hasFontName ( ) const ;
/** \brief leiefert \c true, wenn ein mathFontName() verfügbar ist */
bool hasMathFontName ( ) const ;
/** \brief initialize with the font-families from the XITS package for text and math */
static JKQTMathTextFontSpecifier getXITSFamilies ( ) ;
/** \brief initialize with the font-families from the XITS package for text and math */
static JKQTMathTextFontSpecifier getASANAFamilies ( ) ;
/** \brief initialize with the font-families from the STIX package for text and math */
static JKQTMathTextFontSpecifier getSTIXFamilies ( ) ;
private :
/** \brief specifies the main font name */
QString m_fontName ;
/** \brief specifies the math font to use in addition to fontName */
QString m_mathFontName ;
} ;
2019-01-26 20:00:40 +08:00
/*! \brief this class parses a LaTeX string and can then draw the contained text/equation onto a <a href="http://doc.qt.io/qt-5/qpainter.html">QPainter</a>
2015-07-11 18:56:02 +08:00
\ ingroup jkqtmathtext
2019-01-19 16:40:52 +08:00
2019-01-20 17:49:29 +08:00
JKQTMathText is a self - contained LaTeX - renderer for Qt . It is used to renderer
2019-01-20 23:15:10 +08:00
labels in JKQTPlotter / JKQTBasePlotter , but can be used independently .
2019-01-19 23:54:31 +08:00
The class does not depend on any library , except Qt .
In particular it actually parses a LaTeX string and draws it in pure C + + . It does NOT rely
on an installed LaTeX for the rendering !
2019-01-20 17:49:29 +08:00
\ section JKQTMathTextUsage Usage
\ subsection JKQTMathTextUsageDirect Direct Usage
2019-01-19 23:54:31 +08:00
This small piece of C + + code may serve as an example of the usage and capabilities of the class :
2019-01-19 16:40:52 +08:00
\ code
2019-01-20 17:49:29 +08:00
// create a JKQTMathText object.
JKQTMathText mathText ;
2019-01-19 16:40:52 +08:00
// configure its properties to influence the rendering (e.g. fonts to use, font size, ...)
mathText . useXITS ( ) ;
2019-01-26 03:16:04 +08:00
mathText . setFontSize ( 20 ) ;
2019-01-19 16:40:52 +08:00
// parse some LaTeX code (the Schroedinger's equation)
mathText . parse ( " $ \\ left[- \\ frac{ \\ hbar^2}{2m} \\ frac{ \\ partial^2}{ \\ partial x^2}+V(x) \\ right] \\ Psi(x)= \\ mathrm{i} \\ hbar \\ frac{ \\ partial}{ \\ partial t} \\ Psi(x)$ " ) ;
// use the draw() methods to draw the equation using a QPainter (here onto a QPixmap)
QPainter painter ;
QPixmap pix ( 600 , 400 ) ;
painter . begin ( & pix ) ;
mathText . draw ( painter , Qt : : AlignCenter , QRectF ( 0 , 0 , pix . width ( ) , pix . height ( ) ) , false ) ;
painter . end ( ) ;
\ endcode
2019-01-19 23:54:31 +08:00
2019-01-20 17:49:29 +08:00
\ subsection JKQTMathTextSizing Determining the size of an equation
2019-01-19 23:54:31 +08:00
In addition there are also functions that allow to calculate the size of the equation , before drawing it ( just like the functions in < a href = " http://doc.qt.io/qt-5/qfontmetrics.html " > QFontMetrics < / a > and < a href = " http://doc.qt.io/qt-5/qfontmetricsf.html " > QFontMetricsF < / a > ) :
- getSizeDetail ( )
- getSize ( )
- getAscent ( ) , getDescent ( )
.
2019-01-20 17:49:29 +08:00
\ subsection JKQTMathTextErrorHandling Error Handling
2019-01-19 23:54:31 +08:00
The class is designed to be as robust as possible and will still return some output , even if the equation contains some errors .
2019-01-26 20:00:40 +08:00
Nevertheless , several errors are detected while parsing . You can get a list of error messages using getErrorList ( ) after calling parse ( ) .
2019-01-19 23:54:31 +08:00
Also parse ( ) will return \ c false if an error occured while parsing .
2019-01-20 17:49:29 +08:00
\ subsection JKQTMathTextUsageQLabel Usage within a QLabel class JKQTMathTextLabel
2019-01-19 23:54:31 +08:00
2019-01-20 17:49:29 +08:00
Finally , there is also a QLabel - derived class JKQTMathTextLabel which can be used for drawing a LaTeX string onto a Qt form .
2019-01-19 23:54:31 +08:00
2019-01-20 17:49:29 +08:00
\ see JKQTMathTextLabel
2019-01-19 23:54:31 +08:00
2019-01-20 17:49:29 +08:00
\ section JKQTMathTextExamples Examples
2019-01-19 23:54:31 +08:00
Examples for the usage of this class can be found here :
2019-01-20 17:49:29 +08:00
- \ ref JKQTMathTextSimpleExample
2019-01-19 23:54:31 +08:00
.
2019-01-20 17:49:29 +08:00
\ section JKQTMathTextSuppoertedLaTeX Supported LaTeX Subset
2019-01-20 23:15:10 +08:00
\ subsection JKQTMathTextSuppoertedLaTeXSimple Simple Instructions
2015-07-11 18:56:02 +08:00
The supported LaTeX subset is listes below . Please note that some commands are used differently than in actual LaTeX .
For example \ c \ \ bf is just a renamed form of \ c \ \ textbf and used as \ c \ \ bf { . . . } and NOT as \ c { \ \ bf . . . } .
- \ c $ : enter / leave math mode
2019-01-20 23:15:10 +08:00
- \ c \ \ bf { . . . } \ c \ \ textbf { . . . } \ c \ \ mathbf { . . . } : draw the contained text in bold face \ image html jkqtmathtext_bold . png
- \ c \ \ it { . . . } \ c \ \ textit { . . . } \ c \ \ mathit { . . . } : draw the contained text in italic face \ image html jkqtmathtext_italic . png
- \ c \ \ rm { . . . } \ c \ \ textrm { . . . } \ c \ \ mathrm { . . . } \ c \ \ mbox { . . . } : draw the contained text in normal upright roman font face \ image html jkqtmathtext_fonts . png
- \ c \ \ sf { . . . } \ c \ \ textsf { . . . } \ c \ \ mathsf { . . . } : draw the contained text in normal upright sans - serif font face \ image html jkqtmathtext_fonts . png
- \ c \ \ script { . . . } \ c \ \ textscript { . . . } \ c \ \ mathscript { . . . } : draw the contained text in a script font face \ image html jkqtmathtext_fonts . png
- \ c \ \ sc { . . . } : draw the text in small caps \ image html jkqtmathtext_sc . png
- \ c \ \ ul { . . . } \ c \ \ underline { . . . } \ c \ \ underlined { . . . } : draw the text with underlining \ image html jkqtmathtext_ul . png
- \ c \ \ ol { . . . } \ c \ \ overline { . . . } \ c \ \ overlined { . . . } : draw the text with overlining \ image html jkqtmathtext_ol . png
- \ c \ \ tt { . . . } \ c \ \ texttt { . . . } \ c \ \ mathtt { . . . } : draw text in typewriter font \ image html jkqtmathtext_fonts . png
- \ c \ \ textcolor { color } { . . . } \ c \ \ color { color } \ c \ \ mathcolor { color } { . . . } : draw colored text \ image html jkqtmathtext_colored . png
- \ c \ \ boxed { . . . } : draw text with a box around it \ image html jkqtmathtext_boxed . png
- \ c \ \ colorbox { color } { . . . } : draw a colored box around text \ image html jkqtmathtext_colorbox . png
- \ c \ \ alpha . . . : display the according greek letter \ image html jkqtmathtext_greek . png
- \ c ^ { . . . } \ c _ { . . . } : display the contents of braces in superscript / subscript \ image html jkqtmathtext_supersub . png
< br > Special subscript / superscript typesetting applies , when the sub / super follows \ c \ \ sum \ c \ \ Prod . . . : \ image html jkqtmathtext_specialsubsuper . png
2015-07-11 18:56:02 +08:00
- \ c \ \ { / \ \ } : display opening / closing brace
- \ c \ \ _ : display underscore
- \ c \ \ sum \ c \ \ prod \ c \ \ int . . . : plot special symbol . Note that depending on the fontEncoding the available
symbols may differ ( there are not all symbols defined in the MS Windows Symbol
font ! ) . Best coverage should be given by Unicode font encoding with a good
2019-01-20 23:15:10 +08:00
unicode font installed ! < br > \ image html jkqtmathtext_symbols . png
- < code > \ \ vec { x } \ \ dot { x } \ \ ddot { x } \ \ overline { x } \ \ underline { x } \ \ hat { x } \ \ tilde { x } \ \ uul { x } \ \ ool { x } \ \ bar { x } \ \ arrow { x } < / code > : Decorations over / under symbols \ image html jkqtmathtext_mathdeco . png
2022-04-24 19:23:59 +08:00
- < code > \ \ verb { don ' t parse this _aaa \ \ LaTeX } < / code > : interpret enclosed text as verbose \ image html jkqtmathtext_verb . png
2015-07-11 18:56:02 +08:00
.
2019-01-20 23:15:10 +08:00
\ subsection JKQTMathTextSuppoertedLaTeXBraces Braces . . .
2015-07-11 18:56:02 +08:00
Braces in math mode are adjusted in size , so they are a small bit ( factor \ c brace_factor ) larger than the contents .
To enable this you have to write braces with \ c \ \ left and \ c \ \ right . These types of braces are defined ( slight
differences to LaTeX standard ) :
2019-01-20 23:15:10 +08:00
- \ c \ \ left ( \ c \ \ right ) : default meaning ( ) , \ image html jkqtmathtext_brace_round . png
- \ c \ \ left [ \ c \ \ right ] : default meaning [ ] , \ image html jkqtmathtext_brace_rect . png
- \ c \ \ left \ \ { \ c \ \ right \ \ } : default meaning { } , \ image html jkqtmathtext_brace_curly . png
- \ c \ \ left < \ c \ \ right > : " averaging " braces , \ image html jkqtmathtext_brace_tri . png
- \ c \ c \ \ left \ \ lfloor \ c \ \ right \ \ rfloor : floor braces , \ image html jkqtmathtext_brace_floor . png
- \ c \ \ left ~ \ c \ \ right ~ \ c \ \ left \ \ lceil \ c \ \ right \ \ rceil : ceil braces , \ image html jkqtmathtext_brace_ceil . png
- \ c \ \ left | \ c \ \ right | : absolute value braces | | , \ image html jkqtmathtext_brace_oneline . png
2022-04-24 19:23:59 +08:00
- \ code \ left \ | \ right \ | \ endcode : norm braces | | | | , \ image html jkqtmathtext_brace_dblline . png
2019-01-20 23:15:10 +08:00
- You can use \ c \ \ left . or \ c \ \ right . to have only right or only left brace
.
\ subsection JKQTMathTextSuppoertedLaTeXUnderOver Undersetting , Oversetting , Underbraces , Overbraces . . .
There are also instructions that allow to under / overset braces , arrows , . . . :
2022-04-24 19:23:59 +08:00
- < code > $ \ \ underbrace { x + x + . . . + x } { k \ \ \ \ mathrm { times } } $ < / code > \ image html jkqtmathtext_brace_underbrace . png
- < code > $ \ \ overbrace { x + x + . . . + x } { k \ \ \ \ mathrm { times } } $ < / code > \ image html jkqtmathtext_brace_overbrace . png
- < code > $ \ \ overset { main } { over } $ < / code > \ image html jkqtmathtext_brace_overset . png
- < code > $ \ \ underset { main } { under } $ < / code > \ image html jkqtmathtext_brace_underset . png
2019-01-20 23:15:10 +08:00
.
\ subsection JKQTMathTextSuppoertedLaTeXMatrix Matrix / Array Type Instructions
Several Matrix / Array - typed LaTeX instructions are supported :
2022-04-24 19:23:59 +08:00
- < code > $ \ \ frac { . . . } { . . . } $ < / code > , < code > $ \ \ tfrac { . . . } { . . . } $ < / code > ( 70 % smaller font ) , < code > $ \ \ dfrac { . . . } { . . . } $ < / code > \ image html jkqtmathtext_brace_frac . png
- < code > $ \ \ sfrac { . . . } { . . . } $ < / code > \ image html mathparser / MTFMsfrac . png
- < code > $ \ \ stfrac { . . . } { . . . } $ < / code > ( 70 % smaller font ) \ image html mathparser / MTFMstfrac . png
- < code > $ \ \ stackrel { . . . } { . . . } $ $ \ \ binom { . . . } { . . . } $ < / code > \ image html jkqtmathtext_brace_stackrel . png
- < code > $ \ \ begin { cases } . . . & . . . \ \ \ \ . . . & . . . \ \ end { cases } $ < / code > \ image html jkqtmathtext_brace_begincases . png
- < code > $ \ \ begin { array } a & b & . . . \ \ \ \ c & d & . . . \ \ end { array } $ < / code > < code > $ \ \ begin { matrix } a & b & . . . \ \ \ \ c & d & . . . \ \ end { matrix } $ < / code > \ image html jkqtmathtext_array . png
- < code > $ \ \ begin { pmatrix } a & b & . . . \ \ \ \ c & d & . . . \ \ end { pmatrix } $ < / code > \ image html jkqtmathtext_pmatrix . png
- < code > $ \ \ begin { bmatrix } a & b & . . . \ \ \ \ c & d & . . . \ \ end { bmatrix } $ < / code > \ image html jkqtmathtext_bmatrix . png
- < code > $ \ \ begin { Bmatrix } a & b & . . . \ \ \ \ c & d & . . . \ \ end { Bmatrix } $ < / code > \ image html jkqtmathtext_bbmatrix . png
- < code > $ \ \ begin { vmatrix } a & b & . . . \ \ \ \ c & d & . . . \ \ end { vmatrix } $ < / code > \ image html jkqtmathtext_vmatrix . png
- < code > $ \ \ begin { Vmatrix } a & b & . . . \ \ \ \ c & d & . . . \ \ end { Vmatrix } $ < / code > \ image html jkqtmathtext_vvmatrix . png
2015-07-11 18:56:02 +08:00
.
2019-01-20 17:49:29 +08:00
\ section JKQTMathTextSuppoertedFonts Font Handling
2019-01-19 23:54:31 +08:00
2015-07-11 18:56:02 +08:00
Several fonts are defined as properties to the class :
2019-03-07 06:18:29 +08:00
- A " roman " font used as the standard font ( setFontRoman ( ) )
- A " sans-serif " font which may be activated with \ c \ \ sf . . . ( setFontSans ( ) )
2019-01-26 03:16:04 +08:00
- A " typewriter " font which may be activated with \ c \ \ tt . . . ( setFontTypewriter ( ) )
- A " script " font which may be activated with \ c \ \ script . . . ( setFontScript ( ) )
2019-06-30 23:34:41 +08:00
- A greek font which is used to display greek letters \ c \ \ alpha . . . ( setSymbolfontGreek ( ) )
- A symbol font used to display special ( math ) symbols . ( setSymbolfontSymbol ( ) )
- A " roman " font used as the standard font in math mode ( setFontMathRoman ( ) )
- A " sans-serif " used as sans serif font in math mode ( setFontMathSans ( ) )
2022-04-24 19:23:59 +08:00
- A " blackboard " font used to display double stroked characters ( setFontBlackboard ( ) )
2019-01-26 03:16:04 +08:00
- A " caligraphic " font used to display caligraphic characters ( setFontCaligraphic ( ) )
2015-07-11 18:56:02 +08:00
.
2019-01-19 23:54:31 +08:00
2019-01-26 20:00:40 +08:00
These fonts are generic font classes , which font is actually used can be configured in JKQTMathText class with the \ c set . . . ( ) functions mentioned above . You can also use these functions to set the fonts used for math rendering in math - mode :
2019-01-19 16:40:52 +08:00
- useSTIX ( ) use the STIX fonts from < a href = " https://www.stixfonts.org/ " > https : //www.stixfonts.org/</a> in math-mode<br>\image html jkqtmathparser_stix.png
- useXITS ( ) use the XITS fonts from < a href = " https://github.com/alif-type/xits " > https : //github.com/alif-type/xits</a> in math-mode. These are included by default in this library and also activated by default.<br>\image html jkqtmathparser_xits.png
- useASANA ( ) use the ASANA fonts from < a href = " https://ctan.org/tex-archive/fonts/Asana-Math/ " > https : //ctan.org/tex-archive/fonts/Asana-Math/</a> in math-mode<br>\image html jkqtmathparser_asana.png
- useAnyUnicode ( ) use generic Unicode fonts , e . g . " Arial " and " Times New Roman " in math - mode . You should use fonts that contain as many of the mathematical symbols as possible to ensure good rendering results . < br > using " Times New Roman " : \ image html jkqtmathparser_timesnewroman . png
< br > using " Arial " : \ image html jkqtmathparser_arial . png
2019-01-19 23:54:31 +08:00
< br > using " Courier New " : \ image html jkqtmathparser_couriernew . png
< br > using " Comic Sans MS " : \ image html jkqtmathparser_comicsans . png
2019-01-19 23:24:19 +08:00
.
2019-01-19 16:40:52 +08:00
2019-01-19 23:54:31 +08:00
Math - mode is activated by enclosing your equation in \ c $ . . . $ or \ c \ \ [ . . . \ \ ] . This mode is optimized for mathematical equations . Here is an example of the difference :
- < b > math - mode ( XITS fonts are used , whitespaces are mostly not drawn directly , symbol spacing is different ) < / b > \ c $ . . . $ : < br > \ image html jkqtmathparser_schreq_mathmode . png
- < b > normal mode ( Times new Roman is used , whitespaces are evaluated directly ) < / b > : < br > \ image html jkqtmathparser_schreq_normalmode . png
.
2019-01-19 16:40:52 +08:00
2019-01-20 17:49:29 +08:00
\ section JKQTMathTextToHTML Convert to HTML
2019-01-19 23:54:31 +08:00
2015-07-11 18:56:02 +08:00
The method toHtml ( ) may be used to get a HTML representation of the LaTeX string , if possible ( only for simple LaTeX equations ! ) . Whether
the transformation was possible is returned as a call by value argument !
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT JKQTMathText : public QObject {
2015-07-11 18:56:02 +08:00
Q_OBJECT
public :
2019-02-08 00:24:46 +08:00
/** \brief minimum linewidth allowed in a JKQTMathText (given in pt) */
static const double ABS_MIN_LINEWIDTH ;
2022-06-03 03:02:23 +08:00
2015-07-11 18:56:02 +08:00
/** \brief class constructor */
2019-01-20 17:49:29 +08:00
JKQTMathText ( QObject * parent = nullptr ) ;
2015-07-11 18:56:02 +08:00
/** \brief class destructor */
2019-01-20 17:49:29 +08:00
~ JKQTMathText ( ) ;
2015-07-11 18:56:02 +08:00
/** \brief load the object settings from the given QSettings object with the given name prefix */
2019-02-08 00:24:46 +08:00
void loadSettings ( const QSettings & settings , const QString & group = QString ( " mathtext/ " ) ) ;
2015-07-11 18:56:02 +08:00
/** \brief store the object settings to the given QSettings object with the given name prefix */
2019-02-08 00:24:46 +08:00
void saveSettings ( QSettings & settings , const QString & group = QString ( " mathtext/ " ) ) const ;
2022-06-03 05:24:41 +08:00
/** \brief parse the given enhanced string. If \c addSpaceBeforeAndAfter==true a little bit of space is added before and after the text. Returns \c true on success. */
bool parse ( const QString & text , bool addSpaceBeforeAndAfter = false ) ;
2015-07-11 18:56:02 +08:00
/** \brief get the size of the drawn representation. returns an invalid size if no text has been parsed. */
QSizeF getSize ( QPainter & painter ) ;
/** \brief return the descent, i.e. the distance from the baseline to the lowest part of the representation */
double getDescent ( QPainter & painter ) ;
/** \brief return the ascentt, i.e. the distance from the baseline to the highest part of the representation */
double getAscent ( QPainter & painter ) ;
/** \brief return the detailes sizes of the text */
void getSizeDetail ( QPainter & painter , double & width , double & ascent , double & descent , double & strikeoutPos ) ;
2019-01-26 20:00:40 +08:00
/** \brief draw a representation to the <a href="http://doc.qt.io/qt-5/qpainter.html">QPainter</a> object at the specified position */
2015-07-11 18:56:02 +08:00
void draw ( QPainter & painter , double x , double y , bool drawBoxes = false ) ;
/** \brief overloaded version of draw(QPainter& painter, double x, double y).
*
* This version draws the text inside the given rectangle according to the specified flags .
*/
2019-05-01 20:58:19 +08:00
void draw ( QPainter & painter , unsigned int flags , QRectF rect , bool drawBoxes = false ) ;
2015-07-11 18:56:02 +08:00
2019-06-30 23:34:41 +08:00
/** \brief convert LaTeX to HTML. returns \c ok=true on success and \c ok=false else. */
QString toHtml ( bool * ok = nullptr , double fontPointSize = 10 ) ;
/*! \brief used to specify the font encoding used for drawing
*/
enum MTfontEncoding {
MTFEwinSymbol , /*!< \brief This assumes that symbols shall be taken from a MS Windows style Symbol font */
MTFEunicode , /*!< \brief This assumes that symbols shall be taken from a Unicode font (e.g. the STIX fonts from <a href="http://www.stixfonts.org/">http://www.stixfonts.org/</a>)*/
MTFEunicodeLimited , /*!< \brief This assumes that the fonts used are Unicode, but only offer a limited set of symbols. Especially math symbols are missing from this encoding */
MTFEStandard , /*!< \brief the encoding of a standard TTF font (i.e. we can only expect letters,number and not many special characters) */
} ;
/** \brief convert MTfontEncoding to a string */
static QString encoding2String ( MTfontEncoding e ) ;
/** \brief the available logical fonts (default is MTEroman) */
enum MTenvironmentFont {
MTEroman , /*!< \brief roman font, e.g. <code>\\rm{}</code> */
MTEsans , /*!< \brief sans-serif font, e.g. <code>\\sf{}</code> */
MTEmathRoman , /*!< \brief math-mode roman font, e.g. <code>\\mathrm{}</code> */
MTEmathSans , /*!< \brief math-mode sans-serif font, e.g. <code>\\mathsf{}</code> */
MTEtypewriter , /*!< \brief typewriter font, e.g. <code>\\tt{},\\mathtt{}</code> */
MTEscript , /*!< \brief script font, e.g. <code>\\script{},\\mathscript{}</code> */
MTEblackboard , /*!< \brief blackboard font, e.g. <code>\\mathbb{}</code> */
MTEcaligraphic , /*!< \brief caligraphic font, e.g. <code>\\mathcal{}</code> */
MTEfraktur , /*!< \brief fraktur font, e.g. <code>\\mathfrak{}</code> */
MTenvironmentFontCount /*!< \brief internal enum value that allows to iterate over MTenvironmentFont \internal */
} ;
2020-09-21 19:47:54 +08:00
/** \copydoc fontColor */
2019-06-30 23:34:41 +08:00
void setFontColor ( const QColor & __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc fontColor */
2019-06-30 23:34:41 +08:00
QColor getFontColor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc fontSize */
2019-06-30 23:34:41 +08:00
void setFontSize ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc fontSize */
2019-06-30 23:34:41 +08:00
double getFontSize ( ) const ;
/** \brief add a font pair to the table with font replacements
*
* e . g . if it is known that a certain font is not good for rendering , you can add an alternative with this function .
* These are automatically applied , when setting a new font name !
*
* \ param nonUseFont the font not to use
* \ param useFont replacement font for nonUseFont
*
* The entry in the encodings for this font is kept empty ( or even deleted ) , so the default encoding of the font to be replaced is used !
*/
void addReplacementFont ( const QString & nonUseFont , const QString & useFont ) ;
/** \brief add a font pair to the table with font replacements
*
* e . g . if it is known that a certain font is not good for rendering , you can add an alternative with this function .
* These are automatically applied , when setting a new font name !
*
* \ param nonUseFont the font not to use
* \ param useFont replacement font for nonUseFont
* \ param useFontEncoding encoding of the replacement font
*/
void addReplacementFont ( const QString & nonUseFont , const QString & useFont , MTfontEncoding useFontEncoding ) ;
/** \brief retrieves a replacement for the given font name \a nonUseFont, including its encoding. Returns the given default values \a defaultFont and/or \a defaultFontEncoding if one of the two is not found */
QPair < QString , MTfontEncoding > getReplacementFont ( const QString & nonUseFont , const QString & defaultFont , MTfontEncoding defaultFontEncoding ) const ;
enum class FontSubclass {
Text ,
Default = Text ,
Symbols ,
Greek ,
} ;
/** \brief retrieve the font and encoding to be used for \a font, which might optionally be typeset inside a math environment, specified by in_math_environment, possibly for the given font subclass \a subclass */
QPair < QString , MTfontEncoding > getFontData ( MTenvironmentFont font , bool in_math_environment = false , FontSubclass subclass = FontSubclass : : Default ) const ;
/*! \brief calls setFontRoman(), or calls useXITS() if \a __value \c =="XITS". calls useSTIX() if \a __value \c =="STIX", ...
\ see setFontRoman ( ) , useXITS ( ) , useSTIX ( ) for more information */
2022-06-03 03:02:23 +08:00
void setFontRomanOrSpecial ( const QString & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
/*! \brief calls setFontRoman(), or calls useXITS() if \a __value \c =="XITS". calls useSTIX() if \a __value \c =="STIX", ...
\ see setFontRoman ( ) , useXITS ( ) , useSTIX ( ) for more information */
void setFontRomanOrSpecial ( const JKQTMathTextFontSpecifier & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
2019-06-30 23:34:41 +08:00
2020-09-21 19:47:54 +08:00
/** \brief set the font \a fontName and it's encoding \a encoding to be used for text in the logical font MTEroman */
2019-06-30 23:34:41 +08:00
void setFontRoman ( const QString & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the font to be used for text in the logical font MTEroman */
2019-06-30 23:34:41 +08:00
QString getFontRoman ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief set the font \a fontName and it's encoding \a encoding to be used for text in the logical font MTEsans */
2019-06-30 23:34:41 +08:00
void setFontSans ( const QString & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the font to be used for text in the logical font MTEsans */
2019-06-30 23:34:41 +08:00
QString getFontSans ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief set the font \a fontName and it's encoding \a encoding to be used for text in the logical font MTEtypewriter */
2019-06-30 23:34:41 +08:00
void setFontTypewriter ( const QString & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the font to be used for text in the logical font MTEtypewriter */
2019-06-30 23:34:41 +08:00
QString getFontTypewriter ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief set the font \a fontName and it's encoding \a encoding to be used for text in the logical font MTEscript */
2019-06-30 23:34:41 +08:00
void setFontScript ( const QString & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the font to be used for text in the logical font MTEscript */
2019-06-30 23:34:41 +08:00
QString getFontScript ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief set the font \a fontName and it's encoding \a encoding to be used for text in the logical font MTEfraktur */
2019-06-30 23:34:41 +08:00
void setFontFraktur ( const QString & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the font to be used for text in the logical font MTEfraktur */
2019-06-30 23:34:41 +08:00
QString getFontFraktur ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief set the font \a fontName and it's encoding \a encoding to be used for text in the logical font MTEcaligraphic */
2019-06-30 23:34:41 +08:00
void setFontCaligraphic ( const QString & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the font to be used for text in the logical font MTEcaligraphic */
2019-06-30 23:34:41 +08:00
QString getFontCaligraphic ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief set the font \a fontName and it's encoding \a encoding to be used for text in the logical font MTEblackboard */
2019-06-30 23:34:41 +08:00
void setFontBlackboard ( const QString & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
2020-09-21 19:47:54 +08:00
/** \brief blackboard font is simulated by using roman with outlines only */
2019-06-30 23:34:41 +08:00
void setFontBlackboardSimulated ( bool doSimulate ) ;
2020-09-21 19:47:54 +08:00
/** \brief is blackboard font simulated by using roman with outlines only */
2019-06-30 23:34:41 +08:00
bool isFontBlackboardSimulated ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the font to be used for text in the logical font MTEblackboard */
2019-06-30 23:34:41 +08:00
QString getFontBlackboard ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief set the font \a fontName and it's encoding \a encoding to be used for greek letters in the logical font \a font */
2019-06-30 23:34:41 +08:00
void setSymbolfontGreek ( MTenvironmentFont font , const QString & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
2020-09-21 19:47:54 +08:00
/** \brief set the font \a fontName and it's encoding \a encoding to be used for integrals in all logical fonts */
2019-06-30 23:34:41 +08:00
void setSymbolfontGreek ( const QString & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the font to be used for greek letters in the logical font \a font */
2019-06-30 23:34:41 +08:00
QString getSymbolfontGreek ( MTenvironmentFont font ) const ;
2020-09-21 19:47:54 +08:00
/** \brief set the font \a fontName and it's encoding \a encoding to be used for symbols in the logical font \a font */
2019-06-30 23:34:41 +08:00
void setSymbolfontSymbol ( MTenvironmentFont font , const QString & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
2020-09-21 19:47:54 +08:00
/** \brief set the font \a fontName and it's encoding \a encoding to be used for integrals in all logical fonts */
2019-06-30 23:34:41 +08:00
void setSymbolfontSymbol ( const QString & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the font to be used for symbols in the logical font \a font */
2019-06-30 23:34:41 +08:00
QString getSymbolfontSymbol ( MTenvironmentFont font ) const ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the encoding used for the symbol font to be used for symbols in the logical font \a font */
2019-06-30 23:34:41 +08:00
MTfontEncoding getSymbolfontEncodingSymbol ( MTenvironmentFont font ) const ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the encoding used for the greek letter font to be used for symbols in the logical font \a font */
2019-06-30 23:34:41 +08:00
MTfontEncoding getSymbolfontEncodingGreek ( MTenvironmentFont font ) const ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the encoding used for the script font */
2019-06-30 23:34:41 +08:00
MTfontEncoding getFontEncodingScript ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the encoding used for the Fraktur font */
2019-06-30 23:34:41 +08:00
MTfontEncoding getFontEncodingFraktur ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the encoding used for the typewriter font */
2019-06-30 23:34:41 +08:00
MTfontEncoding getFontEncodingTypewriter ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the encoding used for the sans-serif font */
2019-06-30 23:34:41 +08:00
MTfontEncoding getFontEncodingSans ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the encoding used for the roman font */
2019-06-30 23:34:41 +08:00
MTfontEncoding getFontEncodingRoman ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the encoding used for the blackboard font */
2019-06-30 23:34:41 +08:00
MTfontEncoding getFontEncodingBlackboard ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the encoding used for the caligraphic font */
2019-06-30 23:34:41 +08:00
JKQTMathText : : MTfontEncoding getFontEncodingCaligraphic ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief set the font \a fontName and it's encoding \a encoding to be used for text in the logical font MTEmathRoman */
2019-06-30 23:34:41 +08:00
void setFontMathRoman ( const QString & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the font to be used for text in the logical font MTEroman */
2019-06-30 23:34:41 +08:00
QString getFontMathRoman ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief set the font \a fontName and it's encoding \a encoding to be used for text in the logical font MTEmathSans */
2019-06-30 23:34:41 +08:00
void setFontMathSans ( const QString & fontName , MTfontEncoding encoding = MTfontEncoding : : MTFEStandard ) ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the font to be used for text in the logical font MTEsans */
2019-06-30 23:34:41 +08:00
QString getFontMathSans ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the encoding used for the math-mode sans-serif font */
2019-06-30 23:34:41 +08:00
MTfontEncoding getFontEncodingMathSans ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief retrieves the encoding used for the math-mode roman font */
2019-06-30 23:34:41 +08:00
MTfontEncoding getFontEncodingMathRoman ( ) const ;
2019-01-19 16:40:52 +08:00
/** \brief configures the class to use the STIX fonts in mathmode
*
* use STIX ( 1. x / 2. x ) fonts from < a href = " https://www.stixfonts.org/ " > https : //www.stixfonts.org/</a> in math-mode
*
* \ image html jkqtmathparser_stix . png
*/
2019-06-30 23:34:41 +08:00
bool useSTIX ( bool mathModeOnly = true ) ;
2015-07-11 18:56:02 +08:00
2019-01-19 16:40:52 +08:00
/** \brief configures the class to use the XITS fonts in mathmode
*
* use XITS fonts from < a href = " https://github.com/alif-type/xits " > https : //github.com/alif-type/xits</a> in math-mode.
* These are included by default in this library and also activated by default .
*
* \ image html jkqtmathparser_xits . png
2020-06-28 15:49:20 +08:00
*
* \ note The XITS fonts can be compiled into JKQTPlotter , when the CMake - option \ c is set to ON ( default : ON ) .
* Then the XITS fonts are added as Qt - Ressources to the library binary .
* If this is not the case , you have to provide the XITS fonts on the target system by other means , if you want
* to use them .
2019-01-19 16:40:52 +08:00
*/
2019-06-30 23:34:41 +08:00
bool useXITS ( bool mathModeOnly = true ) ;
2015-07-11 18:56:02 +08:00
2019-01-19 16:40:52 +08:00
/** \brief configures the class to use the ASANA fonts in mathmode
*
* use the ASANA fonts from < a href = " https://ctan.org/tex-archive/fonts/Asana-Math/ " > https : //ctan.org/tex-archive/fonts/Asana-Math/</a> in math-mode
*
* \ image html jkqtmathparser_asana . png
*/
2019-06-30 23:34:41 +08:00
bool useASANA ( bool mathModeOnly = true ) ;
2015-07-11 18:56:02 +08:00
2019-06-30 23:34:41 +08:00
/** \brief sets \a timesFont (with its encoding \a encodingTimes ) for serif-text and \a sansFont (with its encoding \a encodingSans ) for both mathmode and textmode fonts
2019-01-19 16:40:52 +08:00
*
* use generic Unicode fonts , e . g . " Arial " and " Times New Roman " in math - mode .
* You should use fonts that contain as many of the mathematical symbols as possible to ensure good rendering results .
*
2019-06-30 23:34:41 +08:00
* < code > setAnyUnicode ( " Times New Roman " , " Times New Roman " ) < / code > : < br > \ image html jkqtmathparser_timesnewroman . png < br > < br >
* < code > setAnyUnicode ( " Arial " , " Arial " ) < / code > : < br > \ image html jkqtmathparser_arial . png < br > < br >
* < code > setAnyUnicode ( " Courier New " , " Courier New " ) < / code > : < br > \ image html jkqtmathparser_couriernew . png < br > < br >
* < code > setAnyUnicode ( " Comic Sans MS " , " Comic Sans MS " ) < / code > : < br > \ image html jkqtmathparser_comicsans . png < br > < br >
2019-03-07 06:18:29 +08:00
*
2019-01-19 16:40:52 +08:00
*/
2019-06-30 23:34:41 +08:00
void useAnyUnicode ( QString timesFont = QString ( " " ) , const QString & sansFont = QString ( " " ) , MTfontEncoding encodingTimes = MTfontEncoding : : MTFEunicode , MTfontEncoding encodingSans = MTfontEncoding : : MTFEunicode ) ;
2015-07-11 18:56:02 +08:00
2020-09-21 19:47:54 +08:00
/** \copydoc brace_factor */
2019-06-30 23:34:41 +08:00
void setBraceFactor ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc brace_factor */
2019-06-30 23:34:41 +08:00
double getBraceFactor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc subsuper_size_factor */
2019-06-30 23:34:41 +08:00
void setSubsuperSizeFactor ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc subsuper_size_factor */
2019-06-30 23:34:41 +08:00
double getSubsuperSizeFactor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc italic_correction_factor */
2019-06-30 23:34:41 +08:00
void setItalicCorrectionFactor ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc italic_correction_factor */
2019-06-30 23:34:41 +08:00
double getItalicCorrectionFactor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc operatorsubsuper_size_factor */
2019-06-30 23:34:41 +08:00
void setOperatorsubsuperSizeFactor ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc operatorsubsuper_size_factor */
2019-06-30 23:34:41 +08:00
double getOperatorsubsuperSizeFactor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc mathoperator_width_factor */
2019-06-30 23:34:41 +08:00
void setMathoperatorWidthFactor ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc mathoperator_width_factor */
2019-06-30 23:34:41 +08:00
double getMathoperatorWidthFactor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc super_shift_factor */
2019-06-30 23:34:41 +08:00
void setSuperShiftFactor ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc super_shift_factor */
2019-06-30 23:34:41 +08:00
double getSuperShiftFactor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc sub_shift_factor */
2019-06-30 23:34:41 +08:00
void setSubShiftFactor ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc sub_shift_factor */
2019-06-30 23:34:41 +08:00
double getSubShiftFactor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc brace_shrink_factor */
2019-06-30 23:34:41 +08:00
void setBraceShrinkFactor ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc brace_shrink_factor */
2019-06-30 23:34:41 +08:00
double getBraceShrinkFactor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc underbrace_factor */
2019-06-30 23:34:41 +08:00
void setUnderbraceFactor ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc underbrace_factor */
2019-06-30 23:34:41 +08:00
double getUnderbraceFactor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc undersetFactor */
2019-06-30 23:34:41 +08:00
void setUndersetFactor ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc undersetFactor */
2019-06-30 23:34:41 +08:00
double getUndersetFactor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc frac_factor */
2019-06-30 23:34:41 +08:00
void setFracFactor ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc frac_factor */
2019-06-30 23:34:41 +08:00
double getFracFactor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc frac_shift_factor */
2019-06-30 23:34:41 +08:00
void setFracShiftFactor ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc frac_shift_factor */
2019-06-30 23:34:41 +08:00
double getFracShiftFactor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc brace_y_shift_factor */
2019-06-30 23:34:41 +08:00
void setBraceYShiftFactor ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc brace_y_shift_factor */
2019-06-30 23:34:41 +08:00
double getBraceYShiftFactor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc decoration_height_factor */
2019-06-30 23:34:41 +08:00
void setDecorationHeightFactor ( double __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc decoration_height_factor */
2019-06-30 23:34:41 +08:00
double getDecorationHeightFactor ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc expensiveRendering */
2019-06-30 23:34:41 +08:00
void setExpensiveRendering ( bool __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc expensiveRendering */
2019-06-30 23:34:41 +08:00
bool getExpensiveRendering ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc useUnparsed */
2019-06-30 23:34:41 +08:00
void setUseUnparsed ( bool __value ) ;
2020-09-21 19:47:54 +08:00
/** \copydoc useUnparsed */
2019-06-30 23:34:41 +08:00
bool isUsingUnparsed ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc error_list */
2019-06-30 23:34:41 +08:00
QStringList getErrorList ( ) const ;
2015-07-11 18:56:02 +08:00
protected :
/** \brief describes the current drawing environment (base fontname ...) */
struct MTenvironment {
MTenvironment ( ) ;
2019-02-11 05:21:19 +08:00
/** \brief current font color */
2015-07-11 18:56:02 +08:00
QColor color ;
2019-02-11 05:21:19 +08:00
/** \brief current font */
2015-07-11 18:56:02 +08:00
MTenvironmentFont font ;
2019-02-11 05:21:19 +08:00
/** \brief current font size [pt] */
2015-07-11 18:56:02 +08:00
double fontSize ;
2019-02-11 05:21:19 +08:00
/** \brief is the text currently bold? */
2015-07-11 18:56:02 +08:00
bool bold ;
2019-02-11 05:21:19 +08:00
/** \brief is the text currently italic? */
2015-07-11 18:56:02 +08:00
bool italic ;
2019-02-11 05:21:19 +08:00
/** \brief is the text currently in small caps? */
2015-07-11 18:56:02 +08:00
bool smallCaps ;
2019-02-11 05:21:19 +08:00
/** \brief is the text currently underlined? */
2015-07-11 18:56:02 +08:00
bool underlined ;
2019-02-11 05:21:19 +08:00
/** \brief is the text currently overlined? */
2015-07-11 18:56:02 +08:00
bool overline ;
2019-02-11 05:21:19 +08:00
/** \brief is the text currently stroke through? */
2015-07-11 18:56:02 +08:00
bool strike ;
2019-02-11 05:21:19 +08:00
/** \brief is the text currently are we inside a math environment? */
2015-07-11 18:56:02 +08:00
bool insideMath ;
2019-02-11 05:21:19 +08:00
/** \brief build a QFont object from the settings in this object */
2019-01-20 17:49:29 +08:00
QFont getFont ( JKQTMathText * parent ) const ;
2019-02-11 05:21:19 +08:00
/** \brief generate a HTML prefix that formats the text after it according to the settings in this object
*
* \ param defaultEv environment before applying the current object ( to detect changes )
* \ see toHtmlAfter ( )
*/
2015-07-11 18:56:02 +08:00
QString toHtmlStart ( MTenvironment defaultEv ) const ;
2019-02-11 05:21:19 +08:00
/** \brief generate a HTML postfix that formats the text in front of it according to the settings in this object
*
* \ param defaultEv environment before applying the current object ( to detect changes )
* \ see toHtmlAfter ( )
*/
2015-07-11 18:56:02 +08:00
QString toHtmlAfter ( MTenvironment defaultEv ) const ;
} ;
2019-02-11 05:21:19 +08:00
/** \brief beschreibt die Größe eines Knotens */
2019-06-22 20:21:32 +08:00
struct JKQTMATHTEXT_LIB_EXPORT MTnodeSize {
2019-02-11 05:21:19 +08:00
MTnodeSize ( ) ;
double width ;
double baselineHeight ;
double overallHeight ;
double strikeoutPos ;
} ;
2015-07-11 18:56:02 +08:00
public :
2019-02-11 05:21:19 +08:00
/** \brief subclass representing one node in the syntax tree
2019-05-31 20:01:49 +08:00
* \ ingroup jkqtmathtext_items
2019-02-11 05:21:19 +08:00
*
* \ image html jkqtmathtext_node_geo . png
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT MTnode {
2015-07-11 18:56:02 +08:00
public :
2019-06-30 23:34:41 +08:00
explicit MTnode ( JKQTMathText * parent ) ;
MTnode ( const MTnode & ) = delete ;
MTnode & operator = ( const MTnode & ) = delete ;
2019-01-10 04:23:24 +08:00
virtual ~ MTnode ( ) ;
2019-02-11 05:21:19 +08:00
/** \brief determine the size of the node, calls getSizeInternal() implementation of the actual type \see getSizeInternal()
*
* \ param painter painter to use for determining the size
* \ param currentEv current environment object
* \ param [ out ] width width of the block / node
* \ param [ out ] baselineHeight distance from the bottom of the block / node - box to the baseline
* \ param [ out ] overallHeight overall height ( bottom to top ) of the node , the ascent is \ c overallHeight - baselineHeight
* \ param [ out ] strikeoutPos position of the strikeout - line
* \ param [ in ] prevNodeSize optional parameter , describing the size of the previous node ( on the left ) . This may be used for layout of some nodes ( e . g . sub / super to move correctly next to large parantheses . . . )
*
*/
void getSize ( QPainter & painter , MTenvironment currentEv , double & width , double & baselineHeight , double & overallHeight , double & strikeoutPos , const MTnodeSize * prevNodeSize = nullptr ) ;
/** \brief draw the contents at the designated position
*
* \ param painter QPainter to use
* \ param x x - position , where the drawing starts [ Pixel ]
* \ param y Y - position of the baseline , where the drawing starts [ Pixel ]
* \ param currentEv JKQTMathText : : MTenvironment object describing the current drawing environment / settings
* \ param [ in ] prevNodeSize optional parameter , describing the size of the previous node ( on the left ) . This may be used for layout of some nodes ( e . g . sub / super to move correctly next to large parantheses . . . )
* \ return the x position which to use for the next part of the text
*/
virtual double draw ( QPainter & painter , double x , double y , MTenvironment currentEv , const MTnodeSize * prevNodeSize = nullptr ) = 0 ;
/** \brief convert node to HTML and returns \c true on success
* \ param [ out ] html new HTML code is APPENDED to this string
* \ param currentEv JKQTMathText : : MTenvironment object describing the current drawing environment / settings
* \ param defaultEv JKQTMathText : : MTenvironment object describing the default drawing environment / settings when starting to interpret a node tree
* \ return \ c true on success
*/
2019-01-20 17:49:29 +08:00
virtual bool toHtml ( QString & html , JKQTMathText : : MTenvironment currentEv , JKQTMathText : : MTenvironment defaultEv ) ;
2015-07-11 18:56:02 +08:00
2019-02-11 05:21:19 +08:00
/** \brief returns the drawing of colored boxes (for DEBUGGING) around the actual output of the node is enabled */
bool getDrawBoxes ( ) const ;
/** \brief enables the drawing of colored boxes (for DEBUGGING) around the actual output of the node */
2019-01-26 20:00:40 +08:00
virtual void setDrawBoxes ( bool draw ) ;
2019-02-11 05:21:19 +08:00
/** \brief return the name of this class as a string */
2018-11-25 21:53:26 +08:00
virtual QString getTypeName ( ) const ;
2015-07-11 18:56:02 +08:00
protected :
2019-02-10 01:46:12 +08:00
/** \brief determine the size of the node, overwrite this function in derived classes
*
* \ param painter painter to use for determining the size
* \ param currentEv current environment object
* \ param [ out ] width width of the block / node
* \ param [ out ] baselineHeight distance from the bottom of the block / node - box to the baseline
* \ param [ out ] overallHeight overall height ( bottom to top ) of the node , the ascent is \ c overallHeight - baselineHeight
* \ param [ out ] strikeoutPos position of the strikeout - line
2019-02-11 05:21:19 +08:00
* \ param [ in ] prevNodeSize optional parameter , describing the size of the previous node ( on the left ) . This may be used for layout of some nodes ( e . g . sub / super to move correctly next to large parantheses . . . )
2019-02-10 01:46:12 +08:00
*
*/
2019-02-11 05:21:19 +08:00
virtual void getSizeInternal ( QPainter & painter , MTenvironment currentEv , double & width , double & baselineHeight , double & overallHeight , double & strikeoutPos , const MTnodeSize * prevNodeSize = nullptr ) = 0 ;
2019-02-10 01:46:12 +08:00
2019-02-11 05:21:19 +08:00
/** \brief parent JKQTMathText object (required for several drawing operations */
2019-01-20 17:49:29 +08:00
JKQTMathText * parent ;
2019-02-11 05:21:19 +08:00
/** \brief enables the drawing of colored boxes (for DEBUGGING) around the actual output of the node */
2015-07-11 18:56:02 +08:00
bool drawBoxes ;
2019-02-11 05:21:19 +08:00
/** \brief draws colored boxes (for DEBUGGING) around the actual output of the node
*
* \ param painter QPainter to use
* \ param x x - position , where the drawing starts [ Pixel ]
* \ param y Y - position of the baseline , where the drawing starts [ Pixel ]
* \ param currentEv JKQTMathText : : MTenvironment object describing the current drawing environment / settings
*/
2019-01-20 17:49:29 +08:00
void doDrawBoxes ( QPainter & painter , double x , double y , JKQTMathText : : MTenvironment currentEv ) ;
2015-07-11 18:56:02 +08:00
} ;
2019-05-31 20:01:49 +08:00
/** \brief subclass representing one text node in the syntax tree
* \ ingroup jkqtmathtext_items
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT MTtextNode : public MTnode {
2015-07-11 18:56:02 +08:00
public :
2019-06-30 23:34:41 +08:00
explicit MTtextNode ( JKQTMathText * parent , const QString & text , bool addWhitespace , bool stripInnerWhitepace = false ) ;
2019-02-11 05:21:19 +08:00
virtual ~ MTtextNode ( ) override ;
/** \copydoc MTnode::draw() */
virtual double draw ( QPainter & painter , double x , double y , MTenvironment currentEv , const MTnodeSize * prevNodeSize = nullptr ) override ;
/** \copydoc MTnode::toHtml() */
virtual bool toHtml ( QString & html , JKQTMathText : : MTenvironment currentEv , JKQTMathText : : MTenvironment defaultEv ) override ;
2020-09-21 19:47:54 +08:00
/** \copydoc text */
2019-06-21 04:24:47 +08:00
QString getText ( ) const ;
2019-01-10 04:23:24 +08:00
virtual QString getTypeName ( ) const override ;
2015-07-11 18:56:02 +08:00
protected :
2019-02-10 01:46:12 +08:00
/** \copydoc MTnode::getSizeInternal() */
2019-02-11 05:21:19 +08:00
virtual void getSizeInternal ( QPainter & painter , MTenvironment currentEv , double & width , double & baselineHeight , double & overallHeight , double & strikeoutPos , const MTnodeSize * prevNodeSize = nullptr ) override ;
2015-07-11 18:56:02 +08:00
QString text ;
2019-02-11 05:21:19 +08:00
/** \brief transforms the text before sizing/drawing (may e.g. exchange special letters for other unicode symbols etc.) */
2019-01-20 17:49:29 +08:00
virtual QString textTransform ( const QString & text , JKQTMathText : : MTenvironment currentEv , bool forSize = false ) ;
2015-07-11 18:56:02 +08:00
} ;
2019-05-31 20:01:49 +08:00
/** \brief subclass representing one text node in the syntax tree
* \ ingroup jkqtmathtext_items
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT MTplainTextNode : public MTtextNode {
2015-07-11 18:56:02 +08:00
public :
2019-06-30 23:34:41 +08:00
explicit MTplainTextNode ( JKQTMathText * parent , const QString & text , bool addWhitespace , bool stripInnerWhitepace = false ) ;
2019-02-11 05:21:19 +08:00
/** \copydoc MTnode::getTypeName() */
virtual QString getTypeName ( ) const override ;
2015-07-11 18:56:02 +08:00
protected :
2019-02-11 05:21:19 +08:00
/** \copydoc MTtextNode::textTransform() */
virtual QString textTransform ( const QString & text , JKQTMathText : : MTenvironment currentEv , bool forSize = false ) override ;
2015-07-11 18:56:02 +08:00
} ;
2019-05-31 20:01:49 +08:00
/** \brief subclass representing one whitepsace node in the syntax tree
* \ ingroup jkqtmathtext_items
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT MTwhitespaceNode : public MTtextNode {
2015-07-11 18:56:02 +08:00
public :
2019-06-30 23:34:41 +08:00
explicit MTwhitespaceNode ( JKQTMathText * parent ) ;
2019-02-11 05:21:19 +08:00
virtual ~ MTwhitespaceNode ( ) override ;
/** \copydoc MTnode::getTypeName() */
virtual QString getTypeName ( ) const override ;
2015-07-11 18:56:02 +08:00
/** \brief convert node to HTML and returns \c true on success */
2019-02-11 05:21:19 +08:00
/** \copydoc MTnode::toHtml() */
virtual bool toHtml ( QString & html , JKQTMathText : : MTenvironment currentEv , JKQTMathText : : MTenvironment defaultEv ) override ;
2015-07-11 18:56:02 +08:00
} ;
2019-05-31 20:01:49 +08:00
/** \brief subclass representing one symbol (e.g. \c \\alpha , \c \\cdot ...) node in the syntax tree
* \ ingroup jkqtmathtext_items
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT MTsymbolNode : public MTnode {
2015-07-11 18:56:02 +08:00
public :
2019-06-30 23:34:41 +08:00
explicit MTsymbolNode ( JKQTMathText * parent , const QString & name , bool addWhitespace ) ;
2019-02-11 05:21:19 +08:00
virtual ~ MTsymbolNode ( ) override ;
/** \copydoc MTnode::getTypeName() */
virtual QString getTypeName ( ) const override ;
/** \copydoc MTnode::draw() */
virtual double draw ( QPainter & painter , double x , double y , MTenvironment currentEv , const MTnodeSize * prevNodeSize = nullptr ) override ;
/** \copydoc MTnode::toHtml() */
virtual bool toHtml ( QString & html , JKQTMathText : : MTenvironment currentEv , JKQTMathText : : MTenvironment defaultEv ) override ;
2020-09-21 19:47:54 +08:00
/** \copydoc symbolName */
2019-06-21 04:24:47 +08:00
QString getSymbolName ( ) const ;
2019-06-30 23:34:41 +08:00
QString getSymbolfontName ( ) const ;
bool getAddWhitespace ( ) const ;
2015-07-11 18:56:02 +08:00
protected :
2019-02-10 01:46:12 +08:00
/** \copydoc MTnode::getSizeInternal() */
2019-02-11 05:21:19 +08:00
virtual void getSizeInternal ( QPainter & painter , MTenvironment currentEv , double & width , double & baselineHeight , double & overallHeight , double & strikeoutPos , const MTnodeSize * prevNodeSize = nullptr ) override ;
2019-06-30 23:34:41 +08:00
2015-07-11 18:56:02 +08:00
/** \brief this string will be sent to the drawText method with properly set fonts */
QString symbolName ;
2019-06-30 23:34:41 +08:00
/** \brief add a whitespace to the symbol? */
bool addWhitespace ;
struct SymbolProps {
/** \brief the symbol name supplied to the constructor */
QString symbol ;
/** \brief font to use for output */
QString font ;
/** \brief magnification factor for the font size */
double fontFactor ;
/** \brief 0: leave italic setting as is, >0: set italic, <0 set italic to false */
char italic ;
/** \brief 0: leave bold setting as is, >0: set bold, <0 set bold to false */
char bold ;
/** \brief this corrects the y position of a symbol: draws at y <- y+ height*yfactor) */
double yfactor ;
/** \brief indicates whether to draw a bar (like for \c \\hbar ) */
bool drawBar ;
bool heightIsAscent ;
bool exactAscent ;
bool extendWidthInMathmode ;
} ;
/** \brief retrieve the properties to render the given symbol \a symName in the current environment \a currentEv */
SymbolProps getSymbolProp ( const QString & symName , const MTenvironment & currentEv ) const ;
/** \brief fill \a props for the symbol named \a n in the given environment \a currentEv and with the given \a mathFontFactor , returns \c true if the symbol can be drawn using Unicode font (or WinSymbol as Fallback)*/
bool getSymbolProp ( JKQTMathText : : MTsymbolNode : : SymbolProps & props , const QString & n , const MTenvironment & currentEv , double mathFontFactor ) const ;
/** \brief fill \a props for the greek letter symbol named \a n in the given environment \a currentEv and with the given \a mathFontFactor , returns \c true if the symbol can be drawn using Unicode font (or WinSymbol as Fallback) */
bool getGreekSymbolProp ( JKQTMathText : : MTsymbolNode : : SymbolProps & props , const QString & n , const MTenvironment & currentEv , double mathFontFactor ) const ;
/** \brief fill \a props for the symbol named \a n in the given environment \a currentEv and with the given \a mathFontFactor , returns \c true if the symbol can be drawn using WinSymbol font */
bool getWinSymbolProp ( JKQTMathText : : MTsymbolNode : : SymbolProps & props , const QString & n , const MTenvironment & currentEv , double mathFontFactor ) const ;
/** \brief fill \a props for the symbol named \a n , returns \c true if the symbol can be drawn using any font, does not alter the font name!!! */
bool getStandardTextSymbolProp ( JKQTMathText : : MTsymbolNode : : SymbolProps & props , const QString & n ) const ;
/** \brief fill \a props for the symbol named \a n , returns \c true if the symbol can be drawn using any unicode font, does not alter the font name!!! */
bool getUnicodeBaseSymbolProp ( JKQTMathText : : MTsymbolNode : : SymbolProps & props , const QString & n ) const ;
/** \brief fill \a props for the symbol named \a n , returns \c true if the symbol can be drawn using a full unicode font, does not alter the font name!!! */
bool getUnicodeFullSymbolProp ( JKQTMathText : : MTsymbolNode : : SymbolProps & props , const QString & n , double mathFontFactor ) const ;
2015-07-11 18:56:02 +08:00
} ;
2019-02-10 01:46:12 +08:00
/** \brief subclass representing a list of nodes in the syntax tree
2019-05-31 20:01:49 +08:00
* \ ingroup jkqtmathtext_items
2019-02-10 01:46:12 +08:00
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT MTlistNode : public MTnode {
2015-07-11 18:56:02 +08:00
public :
2019-06-30 23:34:41 +08:00
explicit MTlistNode ( JKQTMathText * parent ) ;
2019-02-11 05:21:19 +08:00
virtual ~ MTlistNode ( ) override ;
/** \copydoc MTnode::getTypeName() */
virtual QString getTypeName ( ) const override ;
/** \copydoc MTnode::draw() */
virtual double draw ( QPainter & painter , double x , double y , MTenvironment currentEv , const MTnodeSize * prevNodeSize = nullptr ) override ;
2015-07-11 18:56:02 +08:00
void addNode ( MTnode * n ) { nodes . append ( n ) ; }
2019-02-11 05:21:19 +08:00
/** \copydoc MTnode::toHtml() */
virtual bool toHtml ( QString & html , JKQTMathText : : MTenvironment currentEv , JKQTMathText : : MTenvironment defaultEv ) override ;
/** \copydoc MTnode::setDrawBoxes() */
virtual void setDrawBoxes ( bool draw ) override ;
2020-09-21 19:47:54 +08:00
/** \copydoc nodes */
2019-06-21 04:24:47 +08:00
QList < MTnode * > getNodes ( ) const ;
2015-07-11 18:56:02 +08:00
protected :
2019-02-10 01:46:12 +08:00
/** \copydoc MTnode::getSizeInternal() */
2019-02-11 05:21:19 +08:00
virtual void getSizeInternal ( QPainter & painter , MTenvironment currentEv , double & width , double & baselineHeight , double & overallHeight , double & strikeoutPos , const MTnodeSize * prevNodeSize = nullptr ) override ;
2015-07-11 18:56:02 +08:00
QList < MTnode * > nodes ;
QSet < QString > subsupOperations ;
} ;
2019-05-31 20:01:49 +08:00
/** \brief subclass representing an instruction node with exactly one argument in the syntax tree
* \ ingroup jkqtmathtext_items
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT MTinstruction1Node : public MTnode {
2015-07-11 18:56:02 +08:00
public :
2019-06-30 23:34:41 +08:00
explicit MTinstruction1Node ( JKQTMathText * parent , const QString & name , MTnode * child , const QStringList & parameters = QStringList ( ) ) ;
2019-02-11 05:21:19 +08:00
virtual ~ MTinstruction1Node ( ) override ;
/** \copydoc MTnode::getTypeName() */
virtual QString getTypeName ( ) const override ;
/** \copydoc MTnode::draw() */
virtual double draw ( QPainter & painter , double x , double y , MTenvironment currentEv , const MTnodeSize * prevNodeSize = nullptr ) override ;
2015-07-11 18:56:02 +08:00
/** \brief convert node to HTML and returns \c true on success */
2019-02-11 05:21:19 +08:00
/** \copydoc MTnode::toHtml() */
virtual bool toHtml ( QString & html , JKQTMathText : : MTenvironment currentEv , JKQTMathText : : MTenvironment defaultEv ) override ;
/** \copydoc MTnode::setDrawBoxes() */
virtual void setDrawBoxes ( bool draw ) override ;
2020-09-21 19:47:54 +08:00
/** \brief returns the child node */
2019-06-21 04:24:47 +08:00
MTnode * getChild ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc name */
2019-06-21 04:24:47 +08:00
QString getName ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc parameters */
2019-06-21 04:24:47 +08:00
QStringList getParameters ( ) const ;
2015-07-11 18:56:02 +08:00
protected :
2019-02-10 01:46:12 +08:00
/** \copydoc MTnode::getSizeInternal() */
2019-02-11 05:21:19 +08:00
virtual void getSizeInternal ( QPainter & painter , MTenvironment currentEv , double & width , double & baselineHeight , double & overallHeight , double & strikeoutPos , const MTnodeSize * prevNodeSize = nullptr ) override ;
2019-01-20 17:49:29 +08:00
bool setupMTenvironment ( JKQTMathText : : MTenvironment & ev ) ;
2018-12-08 21:19:52 +08:00
2015-07-11 18:56:02 +08:00
MTnode * child ;
QString name ;
QStringList parameters ;
} ;
2019-02-11 05:21:19 +08:00
/** \brief subclass representing an subscript node with exactly one argument in the syntax tree
2019-05-31 20:01:49 +08:00
* \ ingroup jkqtmathtext_items
2019-02-11 05:21:19 +08:00
*
* \ image html jkqtmathtext_subscriptnode_getSizeInternal . png
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT MTsubscriptNode : public MTnode {
2015-07-11 18:56:02 +08:00
public :
2019-06-30 23:34:41 +08:00
explicit MTsubscriptNode ( JKQTMathText * parent , MTnode * child ) ;
2019-02-11 05:21:19 +08:00
virtual ~ MTsubscriptNode ( ) override ;
/** \copydoc MTnode::draw() */
virtual double draw ( QPainter & painter , double x , double y , MTenvironment currentEv , const MTnodeSize * prevNodeSize = nullptr ) override ;
/** \copydoc MTnode::getTypeName() */
2020-09-21 19:47:54 +08:00
virtual QString getTypeName ( ) const override ; /** \brief returns the child node */
2019-06-30 23:34:41 +08:00
MTnode * getChild ( ) const ;
2019-02-11 05:21:19 +08:00
/** \copydoc MTnode::toHtml() */
virtual bool toHtml ( QString & html , JKQTMathText : : MTenvironment currentEv , JKQTMathText : : MTenvironment defaultEv ) override ;
/** \copydoc MTnode::setDrawBoxes() */
virtual void setDrawBoxes ( bool draw ) override ;
2015-07-11 18:56:02 +08:00
protected :
2019-02-10 01:46:12 +08:00
/** \copydoc MTnode::getSizeInternal() */
2019-02-11 05:21:19 +08:00
virtual void getSizeInternal ( QPainter & painter , MTenvironment currentEv , double & width , double & baselineHeight , double & overallHeight , double & strikeoutPos , const MTnodeSize * prevNodeSize = nullptr ) override ;
2015-07-11 18:56:02 +08:00
MTnode * child ;
} ;
2019-02-11 05:21:19 +08:00
/** \brief subclass representing an superscript node with exactly one argument in the syntax tree
2019-05-31 20:01:49 +08:00
* \ ingroup jkqtmathtext_items
2019-02-11 05:21:19 +08:00
*
* \ image html jkqtmathtext_subscriptnode_getSizeInternal . png
*
* \ note a MTlistNode might modify the positioning slightly for special cases ( e . g . \ c \ \ int , \ c \ \ sum . . . or after braces )
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT MTsuperscriptNode : public MTnode {
2015-07-11 18:56:02 +08:00
public :
2019-06-30 23:34:41 +08:00
explicit MTsuperscriptNode ( JKQTMathText * parent , MTnode * child ) ;
2019-02-11 05:21:19 +08:00
virtual ~ MTsuperscriptNode ( ) override ;
/** \copydoc MTnode::draw() */
virtual double draw ( QPainter & painter , double x , double y , MTenvironment currentEv , const MTnodeSize * prevNodeSize = nullptr ) override ;
2020-09-21 19:47:54 +08:00
/** \brief returns the child node */
2019-06-30 23:34:41 +08:00
MTnode * getChild ( ) const ;
2019-02-11 05:21:19 +08:00
/** \copydoc MTnode::getTypeName() */
virtual QString getTypeName ( ) const override ;
/** \copydoc MTnode::toHtml() */
virtual bool toHtml ( QString & html , JKQTMathText : : MTenvironment currentEv , JKQTMathText : : MTenvironment defaultEv ) override ;
/** \copydoc MTnode::setDrawBoxes() */
virtual void setDrawBoxes ( bool draw ) override ;
2015-07-11 18:56:02 +08:00
protected :
2019-02-10 01:46:12 +08:00
/** \copydoc MTnode::getSizeInternal() */
2019-02-11 05:21:19 +08:00
virtual void getSizeInternal ( QPainter & painter , MTenvironment currentEv , double & width , double & baselineHeight , double & overallHeight , double & strikeoutPos , const MTnodeSize * prevNodeSize = nullptr ) override ;
2015-07-11 18:56:02 +08:00
MTnode * child ;
} ;
2019-05-31 20:01:49 +08:00
/** \brief subclass representing a brace node
* \ ingroup jkqtmathtext_items
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT MTbraceNode : public MTnode {
2015-07-11 18:56:02 +08:00
public :
2019-01-26 19:28:44 +08:00
MTbraceNode ( JKQTMathText * parent , const QString & openbrace , const QString & closebrace , MTnode * child , bool showRightBrace = true ) ;
2019-02-11 05:21:19 +08:00
virtual ~ MTbraceNode ( ) override ;
/** \copydoc MTnode::draw() */
virtual double draw ( QPainter & painter , double x , double y , MTenvironment currentEv , const MTnodeSize * prevNodeSize = nullptr ) override ;
/** \copydoc MTnode::toHtml() */
virtual bool toHtml ( QString & html , JKQTMathText : : MTenvironment currentEv , JKQTMathText : : MTenvironment defaultEv ) override ;
/** \copydoc MTnode::setDrawBoxes() */
virtual void setDrawBoxes ( bool draw ) override ;
/** \copydoc MTnode::getTypeName() */
virtual QString getTypeName ( ) const override ;
2020-09-21 19:47:54 +08:00
/** \brief returns the child node */
2019-02-11 05:21:19 +08:00
inline MTnode * getChild ( ) const {
2019-01-10 04:23:24 +08:00
return this - > child ;
}
2020-09-21 19:47:54 +08:00
/** \copydoc openbrace */
2019-01-26 20:00:40 +08:00
inline QString getOpenbrace ( ) const {
2019-01-10 04:23:24 +08:00
return this - > openbrace ;
}
2020-09-21 19:47:54 +08:00
/** \copydoc closebrace */
2019-01-26 20:00:40 +08:00
inline QString getClosebrace ( ) const {
2019-01-10 04:23:24 +08:00
return this - > closebrace ;
}
2020-09-21 19:47:54 +08:00
/** \copydoc showRightBrace */
2019-01-26 03:16:04 +08:00
inline bool getShowRightBrace ( ) const {
2019-01-10 04:23:24 +08:00
return this - > showRightBrace ;
}
2015-07-11 18:56:02 +08:00
protected :
2019-02-10 01:46:12 +08:00
/** \copydoc MTnode::getSizeInternal() */
2019-02-11 05:21:19 +08:00
virtual void getSizeInternal ( QPainter & painter , MTenvironment currentEv , double & width , double & baselineHeight , double & overallHeight , double & strikeoutPos , const MTnodeSize * prevNodeSize = nullptr ) override ;
2015-07-11 18:56:02 +08:00
MTnode * child ;
QString openbrace ;
QString closebrace ;
bool showRightBrace ;
void getBraceWidth ( QPainter & painter , MTenvironment currentEv , double baselineHeight , double overallHeight , double & bracewidth , double & braceheight ) ;
} ;
2019-05-31 20:01:49 +08:00
/** \brief subclass representing a sqrt node
* \ ingroup jkqtmathtext_items
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT MTsqrtNode : public MTnode {
2015-07-11 18:56:02 +08:00
public :
2019-01-20 17:49:29 +08:00
MTsqrtNode ( JKQTMathText * parent , MTnode * child , int degree = 2 ) ;
2019-02-11 05:21:19 +08:00
virtual ~ MTsqrtNode ( ) override ;
/** \copydoc MTnode::draw() */
virtual double draw ( QPainter & painter , double x , double y , MTenvironment currentEv , const MTnodeSize * prevNodeSize = nullptr ) override ;
/** \copydoc MTnode::toHtml() */
virtual bool toHtml ( QString & html , JKQTMathText : : MTenvironment currentEv , JKQTMathText : : MTenvironment defaultEv ) override ;
/** \copydoc MTnode::setDrawBoxes() */
virtual void setDrawBoxes ( bool draw ) override ;
2019-05-01 20:58:19 +08:00
virtual QString getTypeName ( ) const override ;
2020-09-21 19:47:54 +08:00
/** \brief returns the child node */
2019-06-30 23:34:41 +08:00
MTnode * getChild ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc degree */
2019-06-30 23:34:41 +08:00
int getDegree ( ) const ;
2015-07-11 18:56:02 +08:00
protected :
2019-02-10 01:46:12 +08:00
/** \copydoc MTnode::getSizeInternal() */
2019-02-11 05:21:19 +08:00
virtual void getSizeInternal ( QPainter & painter , MTenvironment currentEv , double & width , double & baselineHeight , double & overallHeight , double & strikeoutPos , const MTnodeSize * prevNodeSize = nullptr ) override ;
2015-07-11 18:56:02 +08:00
MTnode * child ;
int degree ;
} ;
enum MTfracMode {
2019-05-18 17:41:17 +08:00
MTFMfrac , /*!< \brief normal fraction \image html mathparser/MTFMfrac.png */
MTFMdfrac , /*!< \brief normal fraction, without scaling of under/over text \image html mathparser/MTFMdfrac.png */
MTFMtfrac , /*!< \brief text fraction (smaller than MTFMfrac) \image html mathparser/MTFMtfrac.png */
MTFMsfrac , /*!< \brief slanted fraction \image html mathparser/MTFMsfrac.png */
MTFMstfrac , /*!< \brief slanted text fraction \image html mathparser/MTFMstfrac.png */
MTFMunderbrace , /*!< \brief curly underbrace \image html mathparser/MTFMunderbrace.png */
MTFMoverbrace , /*!< \brief curly overbrace \image html mathparser/MTFMoverbrace.png */
MTFMstackrel , /*!< \brief binom/fraction without line \image html mathparser/MTFMstackrel.png */
MTFMunderset , /*!< \brief underset text \image html mathparser/MTFMunderset.png */
MTFMoverset /*!< \brief overset text \image html mathparser/MTFMoverset.png */
2015-07-11 18:56:02 +08:00
} ;
static QString fracModeToString ( MTfracMode mode ) ;
2019-05-31 20:01:49 +08:00
/** \brief subclass representing a \\frac node
* \ ingroup jkqtmathtext_items
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT MTfracNode : public MTnode {
2015-07-11 18:56:02 +08:00
public :
2019-01-20 17:49:29 +08:00
MTfracNode ( JKQTMathText * parent , MTnode * child_top , MTnode * child_bottom , MTfracMode mode ) ;
2019-02-11 05:21:19 +08:00
virtual ~ MTfracNode ( ) override ;
2019-05-01 20:58:19 +08:00
virtual QString getTypeName ( ) const override ;
2019-02-11 05:21:19 +08:00
/** \copydoc MTnode::draw() */
virtual double draw ( QPainter & painter , double x , double y , MTenvironment currentEv , const MTnodeSize * prevNodeSize = nullptr ) override ;
/** \copydoc MTnode::toHtml() */
virtual bool toHtml ( QString & html , JKQTMathText : : MTenvironment currentEv , JKQTMathText : : MTenvironment defaultEv ) override ;
/** \copydoc MTnode::setDrawBoxes() */
virtual void setDrawBoxes ( bool draw ) override ;
2020-09-21 19:47:54 +08:00
/** \brief returns the 1st child node */
2019-06-30 23:34:41 +08:00
MTnode * getChild1 ( ) const ;
2020-09-21 19:47:54 +08:00
/** \brief returns the 2nd child node */
2019-06-30 23:34:41 +08:00
MTnode * getChild2 ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc mode */
2019-06-30 23:34:41 +08:00
MTfracMode getMode ( ) const ;
2015-07-11 18:56:02 +08:00
protected :
2019-02-10 01:46:12 +08:00
/** \copydoc MTnode::getSizeInternal() */
2019-02-11 05:21:19 +08:00
virtual void getSizeInternal ( QPainter & painter , MTenvironment currentEv , double & width , double & baselineHeight , double & overallHeight , double & strikeoutPos , const MTnodeSize * prevNodeSize = nullptr ) override ;
2015-07-11 18:56:02 +08:00
MTnode * child1 ;
MTnode * child2 ;
MTfracMode mode ;
} ;
2019-05-31 20:01:49 +08:00
/** \brief subclass representing a \\begin{matrix} node
* \ ingroup jkqtmathtext_items
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT MTmatrixNode : public MTnode {
2015-07-11 18:56:02 +08:00
public :
2019-01-20 17:49:29 +08:00
MTmatrixNode ( JKQTMathText * parent , QVector < QVector < MTnode * > > children ) ;
2019-02-10 01:46:12 +08:00
virtual ~ MTmatrixNode ( ) override ;
2019-02-11 05:21:19 +08:00
/** \copydoc MTnode::getTypeName() */
2019-02-10 01:46:12 +08:00
virtual QString getTypeName ( ) const override ;
2019-02-11 05:21:19 +08:00
virtual double draw ( QPainter & painter , double x , double y , MTenvironment currentEv , const MTnodeSize * prevNodeSize = nullptr ) override ;
2019-02-10 01:46:12 +08:00
virtual bool toHtml ( QString & html , JKQTMathText : : MTenvironment currentEv , JKQTMathText : : MTenvironment defaultEv ) override ;
2020-09-21 19:47:54 +08:00
/** \brief returns the child nodes */
2019-06-30 23:34:41 +08:00
QVector < QVector < MTnode * > > getChildren ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc columns */
2019-06-30 23:34:41 +08:00
int getColumns ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc lines */
2019-06-30 23:34:41 +08:00
int getLines ( ) const ;
2015-07-11 18:56:02 +08:00
protected :
2019-02-10 01:46:12 +08:00
/** \copydoc MTnode::getSizeInternal() */
2019-02-11 05:21:19 +08:00
virtual void getSizeInternal ( QPainter & painter , MTenvironment currentEv , double & width , double & baselineHeight , double & overallHeight , double & strikeoutPos , const MTnodeSize * prevNodeSize = nullptr ) override ;
/** \copydoc MTnode::setDrawBoxes() */
virtual void setDrawBoxes ( bool draw ) override ;
2015-07-11 18:56:02 +08:00
QVector < QVector < MTnode * > > children ;
int columns ;
int lines ;
} ;
enum MTdecoration {
2019-05-18 17:41:17 +08:00
MTDvec , /*!< \brief vector arrow over block \image html mathparser/MTDvec.png */
MTDhat , /*!< \brief hat over block \image html mathparser/MTDhat.png */
MTDdot , /*!< \brief single dot over block \image html mathparser/MTDvec.png */
MTDddot , /*!< \brief double dot over block \image html mathparser/MTDddot.png */
MTDbar , /*!< \brief bar over block \image html mathparser/MTDbar.png */
MTDarrow , /*!< \brief arrow over block \image html mathparser/MTDarrow.png */
MTDoverline , /*!< \brief overline over block \image html mathparser/MTDoverline.png */
MTDdoubleoverline , /*!< \brief double overline over block \image html mathparser/MTDdoubleoverline.png */
MTDunderline , /*!< \brief underline under block \image html mathparser/MTDunderline.png */
MTDdoubleunderline , /*!< \brief double underline under block \image html mathparser/MTDdoubleunderline.png */
MTDtilde /*!< \brief tilde over block \image html mathparser/MTDtilde.png */
2015-07-11 18:56:02 +08:00
} ;
2019-06-21 16:46:13 +08:00
static QString decorationToString ( MTdecoration mode ) ;
2015-07-11 18:56:02 +08:00
2019-05-31 20:01:49 +08:00
/** \brief subclass representing a decorated text m (e.g. \c \\vec \c \\hat ...) node
* \ ingroup jkqtmathtext_items
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT MTdecoratedNode : public MTnode {
2015-07-11 18:56:02 +08:00
public :
2019-01-20 17:49:29 +08:00
MTdecoratedNode ( JKQTMathText * parent , MTdecoration decoration , MTnode * child ) ;
2019-02-11 05:21:19 +08:00
virtual ~ MTdecoratedNode ( ) override ;
/** \copydoc MTnode::draw() */
virtual double draw ( QPainter & painter , double x , double y , MTenvironment currentEv , const MTnodeSize * prevNodeSize = nullptr ) override ;
/** \copydoc MTnode::toHtml() */
virtual bool toHtml ( QString & html , JKQTMathText : : MTenvironment currentEv , JKQTMathText : : MTenvironment defaultEv ) override ;
/** \copydoc MTnode::setDrawBoxes() */
virtual void setDrawBoxes ( bool draw ) override ;
2019-05-01 20:58:19 +08:00
virtual QString getTypeName ( ) const override ;
2020-09-21 19:47:54 +08:00
/** \brief returns the child node */
2019-06-30 23:34:41 +08:00
MTnode * getChild ( ) const ;
2020-09-21 19:47:54 +08:00
/** \copydoc decoration */
2019-06-30 23:34:41 +08:00
MTdecoration getDecoration ( ) const ;
2015-07-11 18:56:02 +08:00
protected :
2019-02-10 01:46:12 +08:00
/** \copydoc MTnode::getSizeInternal() */
2019-02-11 05:21:19 +08:00
virtual void getSizeInternal ( QPainter & painter , MTenvironment currentEv , double & width , double & baselineHeight , double & overallHeight , double & strikeoutPos , const MTnodeSize * prevNodeSize = nullptr ) override ;
2015-07-11 18:56:02 +08:00
MTnode * child ;
MTdecoration decoration ;
} ;
protected :
2019-05-06 01:31:20 +08:00
/** \brief table with font replacements to use (e.g. if it is known that a certain font is not good for rendering, you can add
* an alternative using addReplacementFont ( ) . These are automatically applied , when setting a new font name ! */
QMap < QString , QString > fontReplacements ;
2019-06-30 23:34:41 +08:00
/** \brief acompanies fontReplacements and collects the encodings of the replacement fonts, if no entry is present, the default encoding is used, as given to the setter! */
QMap < QString , MTfontEncoding > fontEncodingReplacements ;
2015-07-11 18:56:02 +08:00
/** \brief font color */
2019-01-10 04:23:24 +08:00
QColor fontColor ;
2015-07-11 18:56:02 +08:00
/** \brief base font size in points */
2019-01-10 04:23:24 +08:00
double fontSize ;
2019-06-30 23:34:41 +08:00
/*! \brief summarizes all information available on a font for a specific MTenvironmentFont
\ see fontDefinitions */
struct FontDefinition {
FontDefinition ( ) ;
/** \brief name of the font */
QString fontName ;
/** \brief specifies the encoding of the font (default is \c MTFEwinSymbol ) */
MTfontEncoding fontEncoding ;
/** \brief symbol font used for greek symbols, or empty when \a fontName shall be used */
QString symbolfontGreek ;
/** \brief specifies the encoding of symbolfontGreek */
MTfontEncoding symbolfontGreekEncoding ;
/** \brief symbol font, used for math symbols, or empty when \a fontName shall be used */
QString symbolfontSymbol ;
/** \brief specifies the encoding of symbolfontSymbol */
MTfontEncoding symbolfontSymbolEncoding ;
} ;
/** \brief stores information about the different fonts used by LaTeX markup */
QHash < MTenvironmentFont , FontDefinition > fontDefinitions ;
/** \brief if enabled, the blackboard-characters are simulated by using font outlines only */
bool blackboardSimulated ;
2015-07-11 18:56:02 +08:00
/** \brief resizing factor for braces in math mode */
2019-01-10 04:23:24 +08:00
double brace_factor ;
2015-07-11 18:56:02 +08:00
/** \brief shrinking the width of braces in math mode 0: reduce to 0 pixel width, 1: leave unchanged*/
2019-01-10 04:23:24 +08:00
double brace_shrink_factor ;
2015-07-11 18:56:02 +08:00
/** \brief resizing factor for font size in sub-/superscript */
2019-01-10 04:23:24 +08:00
double subsuper_size_factor ;
2015-07-11 18:56:02 +08:00
/** \brief fraction of a whitespace by which to shift a sub-/superscript left/right when the previous text is italic */
2019-01-10 04:23:24 +08:00
double italic_correction_factor ;
2015-07-11 18:56:02 +08:00
/** \brief like subsuper_size_factor, but for operators (\\sum, \\int) where the text is placed above/below the symbol */
2019-01-10 04:23:24 +08:00
double operatorsubsuper_size_factor ;
2015-07-11 18:56:02 +08:00
/** \brief factor, used to extend the size of an operator in math mode */
2019-01-10 04:23:24 +08:00
double mathoperator_width_factor ;
2015-07-11 18:56:02 +08:00
/** \brief relative shift of text in superscript to normal text:
* 0 = baseline kept , 1 : baseline shifted to top of normal text */
2019-01-10 04:23:24 +08:00
double super_shift_factor ;
2015-07-11 18:56:02 +08:00
/** \brief relative shift of text in subscript to normal text:
* 0 = baseline kept , 1 : baseline shifted to bottom of normal text */
2019-01-10 04:23:24 +08:00
double sub_shift_factor ;
2019-06-30 23:34:41 +08:00
2015-07-11 18:56:02 +08:00
/** \brief scaling factor for font of nominator and denominator of a fraction */
2019-01-10 04:23:24 +08:00
double frac_factor ;
2015-07-11 18:56:02 +08:00
/** \brief shift of denominator/nummerator away from central line of a frac */
2019-01-10 04:23:24 +08:00
double frac_shift_factor ;
2015-07-11 18:56:02 +08:00
/** \brief scaling factor for font of underbrace/overbrace text */
2019-01-10 04:23:24 +08:00
double underbrace_factor ;
2015-07-11 18:56:02 +08:00
/** \brief scaling factor for font of underset/overset text */
2019-01-26 20:00:40 +08:00
double undersetFactor ;
2015-07-11 18:56:02 +08:00
/** \brief fraction of the brace ascent that the brace is shifted downwards, when scaled */
2019-01-10 04:23:24 +08:00
double brace_y_shift_factor ;
2015-07-11 18:56:02 +08:00
/** \brief size of the decorations (dot, tilde, ...), as fractio of the baselineheight */
2019-01-10 04:23:24 +08:00
double decoration_height_factor ;
2015-07-11 18:56:02 +08:00
/** \brief switches on some options that will grant better rendering at the expense of higher time consumption */
2019-01-10 04:23:24 +08:00
bool expensiveRendering ;
2015-07-11 18:56:02 +08:00
/** \brief a list that will be filled with error messages while parsing, if any error occur */
QStringList error_list ;
/** \brief used by the parser. This is used to implement brace pairs with \\right. */
bool showRightBrace ;
/** \brief the result of parsing the last string supplied to the object via parse() */
MTnode * parsedNode ;
/** \brief a tree containing the unparsed text as a single node */
MTnode * unparsedNode ;
/** \brief if true, the unparsedNode is drawn */
bool useUnparsed ;
2019-06-30 23:34:41 +08:00
MTnode * getTree ( ) const ;
2015-07-11 18:56:02 +08:00
/** \brief the token types that may arrise in the string */
enum tokenType {
MTTnone ,
MTTtext ,
MTTinstruction ,
MTTunderscore ,
MTThat ,
MTTdollar ,
MTTopenbrace ,
MTTclosebrace ,
MTTwhitespace ,
MTTampersand
} ;
/** \brief tokenizer for the LaTeX parser */
tokenType getToken ( ) ;
/** \brief parse a LaTeX string */
2019-01-26 19:28:44 +08:00
MTnode * parseLatexString ( bool get , const QString & quitOnClosingBrace = QString ( " " ) , const QString & quitOnEnvironmentEnd = QString ( " " ) ) ;
2015-07-11 18:56:02 +08:00
/** \brief parse a LaTeX math environment */
MTnode * parseMath ( bool get ) ;
/** \brief used by the tokenizer. type of the current token */
tokenType currentToken ;
/** \brief used by the tokenizer. Name of the current token, id applicable */
QString currentTokenName ;
/** \brief used by the tokenizer. Points to the currently read character in parseString */
int currentTokenID ;
/** \brief used by the tokenizer. The string to be parsed */
QString parseString ;
/** \brief used by the parser. indicates whether we are in a math environment */
bool parsingMathEnvironment ;
public :
2020-09-21 19:47:54 +08:00
/** \copydoc parsedNode */
2019-06-30 23:34:41 +08:00
MTnode * getParsedNode ( ) const ;
2015-07-11 18:56:02 +08:00
2019-06-22 20:21:32 +08:00
struct JKQTMATHTEXT_LIB_EXPORT tbrData {
2015-07-11 18:56:02 +08:00
explicit tbrData ( const QFont & f , const QString & text , QPaintDevice * pd ) ;
QFontMetricsF fm ;
QString text ;
QRectF tbr ;
QFont f ;
int ldpiX , ldpiY , pdpiX , pdpiY ;
//QPaintDevice *pd;
bool operator = = ( const tbrData & other ) const ;
} ;
2019-06-22 20:21:32 +08:00
struct JKQTMATHTEXT_LIB_EXPORT tbrDataH {
2015-07-11 18:56:02 +08:00
explicit tbrDataH ( const QFont & f , const QString & text , QPaintDevice * pd ) ;
QString text ;
QFont f ;
int ldpiX , ldpiY , pdpiX , pdpiY ;
bool operator = = ( const tbrDataH & other ) const ;
} ;
2019-06-21 16:46:13 +08:00
static QList < JKQTMathText : : tbrData > tbrs ;
static QHash < JKQTMathText : : tbrDataH , QRectF > tbrh ;
static QRectF getTightBoundingRect ( const QFont & fm , const QString & text , QPaintDevice * pd ) ;
2019-06-30 23:34:41 +08:00
2015-07-11 18:56:02 +08:00
} ;
2022-04-22 19:27:31 +08:00
# if QT_VERSION >= QT_VERSION_CHECK(6,0,0)
inline size_t qHash ( const JKQTMathText : : tbrDataH & data , size_t /*seed=0*/ ) {
# else
2019-01-20 17:49:29 +08:00
inline uint qHash ( const JKQTMathText : : tbrDataH & data ) {
2022-04-22 19:27:31 +08:00
# endif
return qHash ( data . f . family ( ) ) + qHash ( data . text ) ;
2015-07-11 18:56:02 +08:00
}
2019-01-20 17:49:29 +08:00
/*! \brief A QLabel-derived class that draws an equation with LaTeX markup using JKQTMathText
2019-01-19 16:40:52 +08:00
\ ingroup jkqtmathtext
2019-01-20 17:49:29 +08:00
\ see JKQTMathText
2019-01-19 16:40:52 +08:00
*/
2019-06-22 20:21:32 +08:00
class JKQTMATHTEXT_LIB_EXPORT JKQTMathTextLabel : public QLabel {
2015-07-11 18:56:02 +08:00
Q_OBJECT
public :
2019-01-20 17:49:29 +08:00
explicit JKQTMathTextLabel ( QWidget * parent = nullptr ) ;
virtual ~ JKQTMathTextLabel ( ) ;
2015-07-11 18:56:02 +08:00
2019-01-20 17:49:29 +08:00
/** \brief returns the internal JKQTMathText instance used for drawing
2019-01-19 23:54:31 +08:00
*
* Use this function to set the font , font size and other properties of the used renderer .
*/
2019-01-20 17:49:29 +08:00
JKQTMathText * getMathText ( ) const ;
2019-01-19 23:54:31 +08:00
/** \brief set the equation to draw */
2015-07-11 18:56:02 +08:00
void setMath ( const QString & text , bool doRepaint = true ) ;
protected :
2019-01-20 17:49:29 +08:00
JKQTMathText * m_mathText ;
2015-07-11 18:56:02 +08:00
QString lastText ;
QPixmap buffer ;
bool repaintDo ;
void internalPaint ( ) ;
void paintEvent ( QPaintEvent * event ) ;
} ;
# endif // JKQTMATHTEXT_H