File indexing completed on 2024-09-08 03:45:19

0001 /***************************************************************************
0002                                cmaptext.h
0003                              -------------------
0004     begin                : Sat Mar 10 2001
0005     copyright            : (C) 2001 by Kmud Developer Team
0006     email                : kmud-devel@kmud.de
0007  ***************************************************************************/
0008 
0009 /***************************************************************************
0010  *                                                                         *
0011  *   This program is free software; you can redistribute it and/or modify  *
0012  *   it under the terms of the GNU General Public License as published by  *
0013  *   the Free Software Foundation; either version 2 of the License, or     *
0014  *   (at your option) any later version.                                   *
0015  *                                                                         *
0016  ***************************************************************************/
0017 
0018 #ifndef CMAPTEXT_H
0019 #define CMAPTEXT_H
0020 
0021 #include "cmapelement.h"
0022 
0023 /**The class used to store text data
0024   *@author Kmud Developer Team
0025   */
0026 
0027 class QString;
0028 class QStringList;
0029 class QColor;
0030 class QFont;
0031 class QPoint;
0032 
0033 #include "kmemconfig.h"
0034 
0035 class KMUDDY_EXPORT CMapText : public CMapElement
0036 {
0037 public:
0038     CMapText(QString str,QFont f,QColor col,CMapManager *manager,QPoint pos,CMapLevel *level);
0039     CMapText(QString str,CMapManager *manager,QPoint pos,CMapLevel *level);
0040     ~CMapText() override;
0041 
0042     elementTyp getElementType(void) override    { return TEXT ; }
0043         void setLevel(CMapLevel *level) override;
0044 
0045     /** Sets the text of the text element
0046       * @param str The new string that the text element should be set to
0047       */
0048     void setText(QString str);
0049     /** Gets the text of the text element
0050       * @return The text
0051       */
0052     QString getText(void);
0053     /** Used to set the font of the text. This font is used when drawing the text.
0054       * @param f The required font of the text
0055       */
0056     void setFont(QFont f);
0057     /** This menthod will return the font used to display the text
0058       * @return The font used to display text
0059       */
0060     QFont getFont(void);
0061     /** This is used to return the color of the text
0062       * @return The color of the text
0063       */
0064     QColor getColor(void);
0065     /** This method is used to set the color of the text
0066       * @param color The color to set the text to
0067       */
0068     void setColor(QColor color);
0069 
0070     /** Used to paint the text on the map
0071       * @param p The painter used to paint the text
0072       * @param zone The zone the text is being painted in
0073       */
0074     void paint(QPainter *p,CMapZone *zone) override;
0075     void dragPaint(QPoint offset,QPainter *p,CMapZone *zone) override;
0076     void lowerPaint(QPainter *p,CMapZone *zone) override;
0077     void higherPaint(QPainter *p,CMapZone *zone) override;
0078 
0079     /** This is used to create  a new copy of the text element and return
0080       * a pointer to the new text element
0081       * @return A pointer to the copy of the text element.
0082       */
0083     CMapElement *copy(void) override;
0084 
0085     void setLinkElement (CMapElement *element)   { m_linkElement = element; }
0086     CMapElement *getLinkElement(void)            { return m_linkElement; }
0087     void updateLinkElements(void);
0088 
0089     /** This is used to set the cursor position within the text element
0090      * @param pos The cursor position
0091      */
0092     void setCursor(QPoint pos);
0093     /** This is used to return the color of the text
0094       * @return The color of the text
0095       */
0096     QPoint getCursor(void);
0097     /** This is used to return the actual cords in the view of the cursor
0098       * @return the cords */
0099     QPoint getCursorCords(void);
0100     /** Move the cursor left */
0101     void cursorLeft(void);
0102     /** Move the cursor right */
0103     void cursorRight(void);
0104     /** Move the cursor up */
0105     void cursorUp(void);
0106     /** Move the cursor down */
0107     void cursorDown(void);
0108     /** Move the cursor to the end */
0109     void cursorEnd(void);
0110     /** this will insert a caridge return at the cursor */
0111     void insertCR(void);
0112     /** This will delete a character behind the cursor */
0113     void deleteChar(void);
0114     /** This will delete a character infront of the cursor */
0115     void backspace(void);
0116 
0117     /** Used to load the properties of the element from a list of properties
0118       * @param properties The properties to load into the element */
0119     void loadProperties(KConfigGroup properties) override;
0120     /** Used to save the properties of the element to a list of properties
0121       * @param properties The properties to load into the element */
0122     void saveProperties(KConfigGroup properties) override;
0123     /** Used to save the element as an XML object
0124       * @param properties The XML object to save the properties too
0125       * @param doc The XML Document */
0126     void saveQDomElement(QDomDocument *doc,QDomElement *properties) override;
0127     /** Used to load the properties from a XML object
0128       * @param properties The XML object to load the properties from */
0129     void loadQDomElement(QDomElement *properties) override;
0130     
0131     /** This is used to convert mouse cordinates into a cursor position
0132       * @param mousePos The position of the mose */
0133     QPoint convertPosToCursor(QPoint mousePos);
0134     /** This is used to conver a offset from the element orgin into a cursor position
0135       * @param offset The offset of the curosr */
0136     QPoint convertOffsetToCursor(QPoint offset);
0137 
0138     /** This method is called to insert a string at the cursor position
0139       * @param s The string to insert */
0140     void insertString(QString s);
0141     /** This method is called to restore the orginal text of the element. When editing, if
0142       * esc is pressed, then this method is called to restore the text to the value it had
0143       * before editing */
0144     void restoreText(void);
0145 
0146     /** This is used to convert a Actual size to it's closet font size
0147       * @param size The actual size of the font
0148       * @param font The text font
0149       * @return The closet matching font size */
0150     static int getActualToFontSize(QSize size,QFont font,QStringList *text);
0151     /** This is used to paint the text. It is capable of painting multiline
0152       * of text. It is static so that it can be called with out creating a instance of CMapText
0153       * @param p The painter used to paint the text
0154       * @param col The color to paint the text
0155       * @param pos The position to paint the text
0156       * @param font The Font used to paint the text
0157       * @param text A point to the text list
0158       * @param size The size of the text */
0159     static void paintText(QPainter *p,QColor col,QPoint pos,QFont font,QStringList *text,QSize size);
0160     /** This method is used to convert a text string into a text list
0161       * @param str The string of text
0162       * @param textList The list to add the text to
0163       */
0164     static void stringToList(QString str,QStringList *textList);
0165     /** This is used to get a unique ID for the text */
0166     unsigned int getTextID(void)                                   { return m_ID; }
0167     /** This is used to set the ID of the text */
0168     void setTextID(unsigned int id);
0169 
0170 
0171 protected:
0172     /** This method is called when the element looses it's edit mode */
0173     void editModeUnsetEvent(void) override;
0174     /** This method is called when the element gains it's edit mode */
0175     void editModeSetEvent(void) override;
0176     /** Used to paint the element at a given location and size
0177       * @param p The painer to paint the element to
0178       * @param pos The position to paint the elmenet
0179       * @param size The size the element should be draw
0180       * @param zone The current zone being viewed */
0181     void paintElementResize(QPainter *p,QPoint pos,QSize size,CMapZone *zone) override;
0182 
0183 private:
0184     /** This used internaly to calculate the offset of the cursor */
0185     void setActualCursorPosition(void);
0186     /** This is used to paint the text. It is capable of painting multiline
0187       * of text. It is static so that it can be called with out creating a instance of CMapText
0188       * @param p The painter used to paint the text
0189       * @param col The color to paint the text
0190       * @param pos The position to paint the text
0191       * @param font The Font used to paint the text
0192       * @param text A point to the text list */
0193     static void paintText(QPainter *p,QColor col,QPoint pos,QFont font,QStringList *text);
0194     /** This method is used to update the size of the text element */
0195     void setTextSize(void);
0196 
0197 private:
0198     QString m_orgText;
0199     QColor m_col;
0200     QStringList m_text;
0201     QFont m_font;
0202     CMapElement *m_linkElement;
0203     QPoint m_cursorPos;
0204     QPoint m_cursorOffset;
0205     unsigned int m_ID;
0206 };
0207 
0208 #endif