X-Git-Url: http://shamusworld.gotdns.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fdrawingview.h;h=da1912f39312fbcc20fc6e0d60ed96553f071a5c;hb=64482766268cddae393da1277987de31e69ffdd9;hp=dfb9f8fc0b43c18dc96d5872a41415487ef7d667;hpb=f19a3a172c425b7fcc5a648a94870f0247c6be89;p=architektonas diff --git a/src/drawingview.h b/src/drawingview.h index dfb9f8f..da1912f 100644 --- a/src/drawingview.h +++ b/src/drawingview.h @@ -3,6 +3,7 @@ #include #include +#include "action.h" #include "container.h" class DrawingView: public QWidget @@ -14,51 +15,61 @@ class DrawingView: public QWidget public: void SetRotateToolActive(bool state = true); -// void ZoomIn(void); -// void ZoomOut(void); +#if 0 + void SetAddLineToolActive(bool state = true); + void SetAddCircleToolActive(bool state = true); + void SetAddArcToolActive(bool state = true); + void SetAddDimensionToolActive(bool state = true); +#endif +// void SetToolActive(Action * action, bool state = true); + void SetToolActive(Action * action);//, bool state = true); + void SetGridSize(uint32_t); + void UpdateGridBackground(void); + + public slots: + void AddNewObjectToDocument(Object *); protected: void paintEvent(QPaintEvent * event); + void resizeEvent(QResizeEvent * event); void mousePressEvent(QMouseEvent * event); void mouseMoveEvent(QMouseEvent * event); void mouseReleaseEvent(QMouseEvent * event); + void keyPressEvent(QKeyEvent * event); + void keyReleaseEvent(QKeyEvent * event); private: QPoint GetAdjustedMousePosition(QMouseEvent * event); QPoint GetAdjustedClientPosition(int x, int y); +// Vector SnapPointToGrid(Vector); public: bool useAntialiasing; private: +// QBrush * backgroundBrush; + QPixmap gridBackground; double scale; // Window scaling factor int32_t offsetX, offsetY; // Window offsets + public: Container document; - double gridSpacing; +// double gridSpacing; // Grid spacing in base units + uint32_t gridPixels; // Grid size in pixels +// double gridBaseUnits; // Grid size in base units + private: bool collided; //Should this go into Object's class variables??? +//maybe, maybe not... :-P bool rotateTool; double rx, ry; bool scrollDrag; Vector oldPoint; -/* QSize minimumSizeHint() const; - QSize sizeHint() const; + bool addLineTool; + bool addCircleTool; + bool addDimensionTool; - private: - void CreateCursors(void); - QPoint GetAdjustedMousePosition(QMouseEvent * event); - QPoint GetAdjustedClientPosition(int x, int y); - - QImage image; - QPoint pt, ptOffset, ptPrevious; - ToolType tool; // Current tool - GlyphPoints pts; // Glyph point structure - int32 ptHighlight, oldPtHighlight, ptNextHighlight, oldPtNextHighlight; - bool polyFirstPoint; - - ToolWindow * toolPalette; - QCursor cur[8]; -*/ + public: + Action * toolAction; }; #endif // __DRAWINGVIEW_H__