X-Git-Url: http://shamusworld.gotdns.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fdrawingview.h;h=c8e46ff627fe6fb70be0d860bbca4efa2c910ce8;hb=3c2db966e79e6437db75eebcff0bfc427f37c71b;hp=c4a7234fe733314ffc34bbebfcf98b3232a314e0;hpb=4bc000ba003a53fb11428a2eb71e3b4471a15c7a;p=architektonas diff --git a/src/drawingview.h b/src/drawingview.h index c4a7234..c8e46ff 100644 --- a/src/drawingview.h +++ b/src/drawingview.h @@ -5,6 +5,8 @@ #include #include "structs.h" +enum { ToolMouseDown, ToolMouseMove, ToolMouseUp, ToolKeyDown, ToolKeyUp, ToolCleanup }; + class Painter; class DrawingView: public QWidget @@ -15,20 +17,23 @@ class DrawingView: public QWidget DrawingView(QWidget * parent = NULL); public: -// void SetToolActive(Action * action); void SetGridSize(uint32_t); void UpdateGridBackground(void); Point SnapPointToGrid(Point); - void RenderObjects(Painter *, Container *); - void DeleteSelectedItems(void); - void ClearSelection(void); + void RenderObjects(Painter *, std::vector &); void AddHoveredToSelection(void); void GetSelection(std::vector &); void GetHovered(std::vector &); + void ToolHandler(int, Point); + void ToolDraw(Painter *); + void LineHandler(int, Point); + void CircleHandler(int, Point); + void RotateHandler(int, Point); + void CheckObjectBounds(void); + bool HitTestObjects(Point); + void HandleObjectMovement(Point); public slots: - void AddNewObjectToDocument(Object *); - void HandleActionUpdate(void); void SetCurrentLayer(int); protected: @@ -63,11 +68,14 @@ class DrawingView: public QWidget bool collided; bool scrollDrag; Vector oldPoint; + QString informativeText; public: std::vector select; std::vector hover; -// Action * toolAction; + std::vector toolObjects; + std::vector toolScratch; + Point toolPoint[32]; // public: // static Container document;