File indexing completed on 2024-09-15 12:06:27
0001 /*************************************************************************** 0002 cmapview.h 0003 ------------------- 0004 begin : Mon Mar 19 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 CMAPVIEW_H 0019 #define CMAPVIEW_H 0020 0021 #include <qlayout.h> 0022 0023 #include <kxmlguiwindow.h> 0024 #include <kmuddy_export.h> 0025 0026 class QLabel; 0027 class QScrollArea; 0028 class QPushButton; 0029 class QAction; 0030 class KToggleAction; 0031 class KSelectAction; 0032 class QActionGroup; 0033 0034 class CMapWidget; 0035 class CMapManager; 0036 class CMapElement; 0037 class CMapLevel; 0038 class CMapRoom; 0039 class CMapZone; 0040 class CMapViewStatusbar; 0041 class HVBoxLayout; 0042 class CMapClipboard; 0043 0044 0045 /**This widget is used as a view of the map. 0046 *It should be create only from the map manager. 0047 *@author Kmud Developer Team 0048 */ 0049 class KMUDDY_EXPORT CMapView : public KXmlGuiWindow 0050 { 0051 Q_OBJECT 0052 0053 public: 0054 CMapView(CMapManager *manager, QWidget *parent); 0055 ~CMapView() override; 0056 0057 void initGUI(); 0058 0059 CMapWidget *getMapWidget() { return mapWidget; } 0060 CMapManager *getManager() { return mapManager; } 0061 0062 // FIXME: Follow/create mode needs to be saved/restored somewere 0063 /** Set the state of the follow combo box */ 0064 void setFollowMode(bool follow); 0065 /** Get the state of the follow combo box */ 0066 bool getFollowMode(); 0067 /** Set the state of the create combo box */ 0068 void setCreateMode(bool create); 0069 /** Get the state of the create combo box */ 0070 bool getCreateMode(); 0071 0072 /** Used to let the map manager know if it should register the focus of this widget */ 0073 virtual bool acceptFocus(); 0074 0075 /** Used to get the currently viewed zone */ 0076 virtual CMapZone *getCurrentlyViewedZone(void); 0077 /** Used to get the currently viewed level */ 0078 virtual CMapLevel *getCurrentlyViewedLevel(void); 0079 /** This method is called when the current position of the player changes */ 0080 virtual void playerPositionChanged(CMapRoom *); 0081 /** Used to set the current level. This is for internal use */ 0082 virtual void setLevel(CMapLevel *level); 0083 0084 /** Tell this map view to display a different level. view wiil 0085 * center on the first room */ 0086 void showPosition(CMapLevel *level,bool centerView=true); 0087 /** Tell this map view to display the level with a given room in it 0088 * @param room The room to center on 0089 * @param centerView used to tell center view 0090 */ 0091 void showPosition(CMapRoom *room,bool centerView=true); 0092 /** Tell this map widget to display a different zone */ 0093 virtual void showPosition(QPoint pos,CMapLevel *level,bool centerView=true); 0094 /** This method is used to set the element when that a popup menu is to be showed for */ 0095 void setSelectedElement(CMapElement *element); 0096 /** This methid is used to set the position that a element was selected when the contex menu is shown */ 0097 void setSelectedPos(QPoint pos); 0098 /** This method is used to get the element that a popup menu is being displayed for */ 0099 CMapElement *getSelectedElement(); 0100 0101 /** This method is called when an element is added */ 0102 virtual void addedElement(CMapElement *element); 0103 /** This method is called when an element is deleted */ 0104 virtual void deletedElement(CMapLevel *deletedFromLevel); 0105 /** This method is called when an element is changed */ 0106 virtual void changedElement(CMapElement *element); 0107 /** This method is called when a map level is changed */ 0108 virtual void changedLevel(CMapLevel *level); 0109 /** This method is called when something else is changed, it should trigger a repaint */ 0110 virtual void changed(); 0111 /** Asks the widget to repaint itself */ 0112 virtual void requestPaint(); 0113 /** Get the max x cord of all elements */ 0114 int getMaxX(void); 0115 /** Get the max y cord of all elements */ 0116 int getMaxY(void); 0117 0118 /** Used to find out if a element is visible in the view */ 0119 virtual bool isElementVisible(CMapElement *element); 0120 /** Used to find out if a level is visible in the view */ 0121 virtual bool isLevelVisible(CMapLevel *level); 0122 0123 /* Used to calculate the correct size for the widget */ 0124 void checkSize(QPoint pos); 0125 0126 /** This is used ensure a location is visiable for views that scroll */ 0127 virtual void ensureVisible(QPoint pos); 0128 0129 /** This will pass cursor changes to the mapWidet */ 0130 void setCursor ( const QCursor & cursor); 0131 0132 void readOptions(); 0133 0134 QActionGroup *toolGroup () { return m_toolGroup; } 0135 0136 protected: 0137 /** Used to get the width of the widget */ 0138 virtual int getWidth(void); 0139 /** Used to gt the height of the widget */ 0140 virtual int getHeight(void); 0141 void resizeEvent (QResizeEvent *) override; 0142 virtual void slotWidgetBeingClosed(); 0143 virtual void slotDockWindowClose(); 0144 void closeEvent ( QCloseEvent *e) override; 0145 /** Used to set the view to active */ 0146 void focusInEvent(QFocusEvent *e) override; 0147 0148 private slots: 0149 void slotToolsGrid(); 0150 void slotToolsLevelUp(); 0151 void slotToolsLevelDown(); 0152 void slotToolsLevelDelete(); 0153 void slotToolsZoneCreate(); 0154 void slotToolsZoneDelete(); 0155 0156 void slotViewUpperLevel(); 0157 void slotViewLowerLevel(); 0158 0159 /** Used to change the position of room/zone labels */ 0160 void slotChangeLabelPos(); 0161 /** Used to room under the point the current room */ 0162 void slotRoomSetCurrentPos(void); 0163 /** Used to room under the point the login room */ 0164 void slotRoomSetLogin(void); 0165 /** Used to set speedwalk to the room under the pointer */ 0166 void slotRoomSpeedwalkTo(void); 0167 /** Used to delete the room under the pointer */ 0168 void slotRoomDelete(void); 0169 /** Used to display the properties of the room under the pointer */ 0170 void slotRoomProperties(void); 0171 /** Used to make the path under the pointer one way */ 0172 void slotPathOneWay(void); 0173 /** Used to make the path under the pointer two way */ 0174 void slotPathTwoWay(void); 0175 /** Used to add a bend to the path under the pointer */ 0176 void slotPathAddBend(void); 0177 /** Used to delete the path segment under the pointer */ 0178 void slotPathDelBend(void); 0179 /** Used to edit the bends of the path under the pointer */ 0180 void slotPathEditBends(void); 0181 /** Used to delete the path under the pointer */ 0182 void slotPathDelete(void); 0183 /** Used to display the properties of the path under the pointer */ 0184 void slotPathProperties(void); 0185 /** Used to delete the text element under the pointer */ 0186 void slotTextDelete(void); 0187 /** Used to display the text properties of the text element under the pointer */ 0188 void slotTextProperties(void); 0189 0190 signals: 0191 void closed (); 0192 0193 private: 0194 void initMenus(); 0195 /** Used by slotToolsLevel(Up/Down) */ 0196 void levelShift(bool up); 0197 bool queryClose () override; 0198 0199 /** 0200 * Used to enable/disable the view actions 0201 * @param If true then enable the actions otherwise disable the actions 0202 */ 0203 void enableViewControls(bool enable); 0204 /** 0205 * This method is used to disable/enable mapper actions that are not done by enableViewControls() 0206 * @param If true then enable the actions otherwise disable the actions 0207 */ 0208 void enableNonViewActions(bool enabled); 0209 0210 0211 private: 0212 /** A pointer to the map manager */ 0213 CMapManager *mapManager; 0214 /** A pointer to the current level for this map widget */ 0215 CMapLevel *currentLevel; 0216 0217 /** The element that is selected ( when the right mouse button menu is show for it) */ 0218 CMapElement *m_selectedElement; 0219 /** The position that the mouse is in when the context menu is show for a element */ 0220 QPoint m_selectedPos; 0221 0222 /** This is the map clipboard used for copy and paste actions */ 0223 CMapClipboard *m_clipboard; 0224 /** Main layout */ 0225 HVBoxLayout *layout; 0226 /** A toggle button to tell the map view to follow the player. */ 0227 QPushButton *cmdFollowMode; 0228 /** A toggle button to automatically create rooms as we walk. */ 0229 QPushButton *cmdCreateMode; 0230 /** The scrolling area wrapping the map widget */ 0231 QScrollArea *scroller; 0232 /** The Widget used to draw the map */ 0233 CMapWidget *mapWidget; 0234 /** The status bar */ 0235 CMapViewStatusbar *statusbar; 0236 /** The max size of all the components */ 0237 QSize maxSize; 0238 0239 //Actions 0240 KToggleAction *m_toolsGrid; 0241 QAction *m_toolsUpLevel; 0242 QAction *m_toolsDownLevel; 0243 QAction *m_toolsDeleteLevel; 0244 QAction *m_toolsCreateZone; 0245 QAction *m_toolsDeleteZone; 0246 0247 KToggleAction *m_viewLowerLevel; 0248 KToggleAction *m_viewUpperLevel; 0249 0250 KSelectAction *labelMenu; 0251 0252 QActionGroup *m_toolGroup; 0253 0254 0255 }; 0256 0257 #endif 0258