From bdb0625280d827ba7333b6fc9d6c6534e0720100 Mon Sep 17 00:00:00 2001 From: Thales1330 Date: Tue, 24 Jan 2017 18:25:17 -0200 Subject: Control editor implementation start --- Project/ControlEditor.h | 59 ++++++++++++++++++++++++++++++++++--------------- 1 file changed, 41 insertions(+), 18 deletions(-) (limited to 'Project/ControlEditor.h') diff --git a/Project/ControlEditor.h b/Project/ControlEditor.h index 723831a..e121690 100644 --- a/Project/ControlEditor.h +++ b/Project/ControlEditor.h @@ -6,19 +6,14 @@ #include #include #include +#include +#include -enum ControlElementButtonID -{ - ID_IO = 0, - ID_TF, - ID_SUM, - ID_CONST, - ID_LIMITER, - ID_GAIN, - ID_MULT, - ID_SAT, - ID_RATELIM -}; +class Camera; +class ControlElement; +class TransferFunction; + +enum ControlElementButtonID { ID_IO = 0, ID_TF, ID_SUM, ID_CONST, ID_LIMITER, ID_GAIN, ID_MULT, ID_SAT, ID_RATELIM }; class ControlElementButton : public wxWindow { @@ -36,30 +31,58 @@ protected: wxString m_label; wxFont m_font; wxPoint m_labelPosition; - + wxImage m_image; wxSize m_imageSize; wxPoint m_imagePosition; - + int m_borderSize = 2; bool m_mouseAbove = false; bool m_selected = false; - + wxSize m_buttonSize; }; class ControlEditor : public ControlEditorBase { public: + enum ControlEditorMode { + MODE_EDIT = 0, + MODE_MOVE_ELEMENT, + MODE_DRAG, + MODE_DRAG_INSERT, + MODE_INSERT, + MODE_SELECTION_RECT, + MODE_PASTE, + MODE_DRAG_PASTE + }; ControlEditor(wxWindow* parent); virtual ~ControlEditor(); - + virtual void AddElement(ControlElementButtonID id); + virtual void Redraw() { m_glCanvas->Refresh(); } protected: - void BuildControlElementPanel(); + virtual void OnDoubleClick(wxMouseEvent& event); + virtual void OnLeftClickDown(wxMouseEvent& event); + virtual void OnLeftClickUp(wxMouseEvent& event); + virtual void OnMiddleDown(wxMouseEvent& event); + virtual void OnMiddleUp(wxMouseEvent& event); + virtual void OnMouseMotion(wxMouseEvent& event); + virtual void OnPaint(wxPaintEvent& event); virtual void LeftClickDown(wxMouseEvent& event); - wxButton* m_tfButton; + void BuildControlElementPanel(); + void SetViewport(); + + wxGLContext* m_glContext = NULL; + Camera* m_camera = NULL; + + ControlEditorMode m_mode = MODE_EDIT; + + wxRect2DDouble m_selectionRect; + wxPoint2DDouble m_startSelRect; + + std::vector m_elementList; }; #endif // CONTROLEDITOR_H -- cgit