X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=src%2Factions.hh;h=9f65f7ed3ef284c055cacc6a6b6d0af0c556a692;hb=77a8e11660edd66279f2d3def6de3768874ba780;hp=3df4fe4aa392a793c16074b9e9b59b7173eb4dbc;hpb=143d2df034e1304c1d9672226bd71f01533a1a63;p=chaz%2Fopenbox diff --git a/src/actions.hh b/src/actions.hh index 3df4fe4a..9f65f7ed 100644 --- a/src/actions.hh +++ b/src/actions.hh @@ -6,11 +6,13 @@ @brief The action interface for user-available actions */ -#include "otk/display.hh" #include "otk/point.hh" -#include "otk/rect.hh" #include "otk/eventhandler.hh" +extern "C" { +#include +} + namespace ob { //! The action interface for user-available actions @@ -20,26 +22,45 @@ namespace ob { */ class OBActions : public otk::OtkEventHandler { public: - struct MouseButtonAction { + struct ButtonReleaseAction { Window win; unsigned int button; Time time; - MouseButtonAction() { win = 0; button = 0; time = 0; } + ButtonReleaseAction() { win = 0; button = 0; time = 0; } + }; + + struct ButtonPressAction { + unsigned int button; + otk::Point pos; + ButtonPressAction() { button = 0; } }; private: // milliseconds XXX: config option static const unsigned int DOUBLECLICKDELAY; + static const int BUTTONS = 5; - //! The last 2 button release processed for CLICKs - MouseButtonAction _release; //! The mouse button currently being watched from a press for a CLICK unsigned int _button; + //! The last button release processed for CLICKs + ButtonReleaseAction _release; + //! The point where the mouse was when each mouse button was pressed + /*! + Used for motion events as the starting position. + */ + ButtonPressAction *_posqueue[BUTTONS]; + //! The delta x/y of the last motion sequence + int _dx, _dy; - void insertPress(Window win, unsigned int button, Time time); + //! Insert a button/position in the _posqueue + void insertPress(const XButtonEvent &e); + //! Remove a button/position from the _posqueue + void removePress(const XButtonEvent &e); public: + //! Constructs an OBActions object OBActions(); + //! Destroys the OBActions object virtual ~OBActions(); virtual void buttonPressHandler(const XButtonEvent &e);