2022-06-08 21:38:26 +08:00
/*
2024-02-06 21:50:49 +08:00
Copyright ( c ) 2008 - 2024 Jan W . Krieger ( < jan @ jkrieger . de > )
2022-06-08 21:38:26 +08:00
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 JKQTMATHTEXTMATRIXNODE_H
# define JKQTMATHTEXTMATRIXNODE_H
# include "jkqtmathtext/jkqtmathtext_imexport.h"
# include "jkqtmathtext/jkqtmathtexttools.h"
# include "jkqtmathtext/nodes/jkqtmathtextnode.h"
# include <QPainter>
class JKQTMathText ; // forward
// JKQTMATHTEXT_LIB_EXPORT
2022-08-12 18:54:10 +08:00
/** \brief subclass representing a \c \\begin{matrix} , \c \\begin{tabular} , \c \\begin{array} , ... node
2022-06-08 21:38:26 +08:00
* \ ingroup jkqtmathtext_items
2022-08-12 18:54:10 +08:00
*
* Definition of the matrix geometry
* \ image html jkqtmathtext / jkqtmathtext_matrix_geometry . png
*
*
* Two examples :
* \ image html jkqtmathtext / jkqtmathtext_tabular . png
*
* \ image html jkqtmathtext / jkqtmathtext_array . png
2022-06-08 21:38:26 +08:00
*/
2022-08-13 21:32:31 +08:00
class JKQTMATHTEXT_LIB_EXPORT JKQTMathTextMatrixNode : public JKQTMathTextMultiChildNode {
2022-06-08 21:38:26 +08:00
public :
2022-08-12 18:54:10 +08:00
/** \brief types of lines */
enum LineType {
LTnone , /*!< \brief noline */
LTline , /*!< \brief single line */
LTdoubleline , /*!< \brief double line */
LTheavyline , /*!< \brief heavier/thick line */
LTdashed , /*!< \brief single dashed line */
LTdoubleDashed , /*!< \brief double dashed line */
LTdefault = LTnone
} ;
JKQTMathTextMatrixNode ( JKQTMathText * parent , const QVector < QVector < JKQTMathTextNode * > > & children , const QString & columnSpec = QString ( ) ) ;
JKQTMathTextMatrixNode ( JKQTMathText * parent , const QString & columnSpec = QString ( ) ) ;
2022-06-08 21:38:26 +08:00
virtual ~ JKQTMathTextMatrixNode ( ) override ;
2022-08-12 18:54:10 +08:00
/** \brief sets the child nodes */
void setChildren ( const QVector < QVector < JKQTMathTextNode * > > & children ) ;
/** \copydoc horizontalLineBottomRow */
void setRowBottomLine ( int col , LineType line ) ;
/** \copydoc horizontalLineTop */
void setTopLine ( LineType line ) ;
2022-06-08 21:38:26 +08:00
/** \copydoc JKQTMathTextNode::getTypeName() */
virtual QString getTypeName ( ) const override ;
2022-06-09 05:52:22 +08:00
/** \copydoc JKQTMathTextNode::draw() */
2022-08-17 05:05:04 +08:00
virtual double draw ( QPainter & painter , double x , double y , JKQTMathTextEnvironment currentEv ) const override ;
2022-06-09 05:52:22 +08:00
/** \copydoc JKQTMathTextNode::toHtml() */
2022-08-17 05:05:04 +08:00
virtual bool toHtml ( QString & html , JKQTMathTextEnvironment currentEv , JKQTMathTextEnvironment defaultEv ) const override ;
2022-06-08 21:38:26 +08:00
/** \brief returns the child nodes */
2022-08-13 21:32:31 +08:00
QVector < QVector < JKQTMathTextNode * > > getChildrenMatrix ( ) const ;
2022-06-08 21:38:26 +08:00
/** \copydoc columns */
int getColumns ( ) const ;
/** \copydoc lines */
int getLines ( ) const ;
2022-08-13 21:32:31 +08:00
/** \copydoc JKQTMathTextMultiChildNode::getChildren() */
virtual QList < JKQTMathTextNode * > getChildren ( ) override ;
/** \copydoc JKQTMathTextMultiChildNode::childCount() */
virtual int childCount ( ) const override ;
/** \copydoc JKQTMathTextMultiChildNode::clearChildren() */
virtual void clearChildren ( bool deleteChildren = true ) override ;
/** \copydoc JKQTMathTextMultiChildNode::deleteChild() */
virtual void deleteChild ( int i ) override ;
/** \copydoc JKQTMathTextMultiChildNode::getChild() */
virtual JKQTMathTextNode * getChild ( int i ) override ;
/** \copydoc JKQTMathTextMultiChildNode::getChild() */
virtual const JKQTMathTextNode * getChild ( int i ) const override ;
/** \copydoc JKQTMathTextMultiChildNode::getChild() */
virtual JKQTMathTextNode * replaceChild ( int i , JKQTMathTextNode * newChild ) override ;
2022-06-08 21:38:26 +08:00
protected :
2022-08-12 18:54:10 +08:00
/** \brief describes the layout of the whole node */
struct LayoutInfo : public JKQTMathTextNodeSize {
LayoutInfo ( ) ;
/** \brief widths of the columns */
QVector < double > colwidth ;
/** \brief widths of the cells */
QVector < QVector < double > > cellwidth ;
inline double & getCellwidth ( int line , int col ) {
return cellwidth [ line ] . operator [ ] ( col ) ;
}
inline const double & getCellwidth ( int line , int col ) const {
return cellwidth [ line ] . operator [ ] ( col ) ;
}
/** \brief heights of the rows */
QVector < double > rowheight ;
/** \brief ascents of the rows */
QVector < double > rowascent ;
double leftPadding ;
double rightPadding ;
double topPadding ;
double bottomPadding ;
} ;
/** \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 ;
2022-06-08 21:38:26 +08:00
/** \copydoc JKQTMathTextNode::getSizeInternal() */
2022-08-17 05:05:04 +08:00
virtual JKQTMathTextNodeSize getSizeInternal ( QPainter & painter , JKQTMathTextEnvironment currentEv ) const override ;
2022-06-08 21:38:26 +08:00
/** \copydoc JKQTMathTextNode::setDrawBoxes() */
virtual void setDrawBoxes ( bool draw ) override ;
2022-06-09 05:52:22 +08:00
/** \brief child nodes making up the matrix, vector of rows */
2022-06-08 21:38:26 +08:00
QVector < QVector < JKQTMathTextNode * > > children ;
2022-08-12 18:54:10 +08:00
/** \brief alignment of the columns */
QVector < JKQTMathTextHorizontalAlignment > columnAlignment ;
/** \brief lines to the right of each column */
QMap < int , LineType > verticalLineRHSColumn ;
/** \brief line at the left of the table */
LineType verticalLineLeft ;
/** \brief lines to the bottom of each row */
QMap < int , LineType > horizontalLineBottomRow ;
/** \brief line at the top of the table */
LineType horizontalLineTop ;
2022-06-09 05:52:22 +08:00
/** \brief number of columns in the matrix */
2022-06-08 21:38:26 +08:00
int columns ;
2022-06-09 05:52:22 +08:00
/** \brief number of rows in the matrix */
2022-06-08 21:38:26 +08:00
int lines ;
2022-08-12 18:54:10 +08:00
/** \brief draw a vertical line starting at pixel position (\a x, \a y ) with length \a height, using linetype \a lt, width \a linewidth and \a color */
static void drawVLine ( QPainter & painter , double x , double y , double height , LineType lt , double linewidth , double linewidthHeavy , QColor color , double doublelineseparation ) ;
/** \brief draw a horizontal line starting at pixel position (\a x, \a y ) with length \a width, using linetype \a lt, width \a linewidth and \a color */
static void drawHLine ( QPainter & painter , double x , double y , double width , LineType lt , double linewidth , double linewidthHeavy , QColor color , double doublelineseparation ) ;
/** \brief parses a column specifier */
void parseColumnSpec ( const QString & columnspec ) ;
2022-08-13 21:32:31 +08:00
/** \copydoc JKQTMathTextMultiChildNode::clearChildren() */
void clearChildrenImpl ( bool deleteChildren ) ;
2022-06-08 21:38:26 +08:00
} ;
# endif // JKQTMATHTEXTMATRIXNODE_H