wxPython / src / _keyboardstate.i

// Name:        _keyboardstate.i
// Purpose:     SWIG interface for wx.KeyboardState
// Author:      Robin Dunn
// Created:     1-Feb-2010
// RCS-ID:      $Id: _keyboardstate.i 69040 2011-09-10 01:00:23Z RD $
// Copyright:   (c) 2010 by Total Control Software
// Licence:     wxWindows license

// Not a %module


       "wx.KeyboardState stores the state of the keyboard modifier keys", "");

class wxKeyboardState
    wxKeyboardState(bool controlDown = false,
                    bool shiftDown = false,
                    bool altDown = false,
                    bool metaDown = false);
        int, GetModifiers() const,
        "Returns a bitmask of the current modifier settings.  Can be used to
check if the key event has exactly the given modifiers without having
to explicitly check that the other modifiers are not down.  For

    if event.GetModifers() == wx.MOD_CONTROL:
", "");

    %property(Modifiers, GetModifiers, doc="See `GetModifiers`");

        bool , ControlDown() const,
        "Returns ``True`` if the Control key was down at the time of the event.", "");

        bool , MetaDown() const,
        "Returns ``True`` if the Meta key was down at the time of the event.", "");

        bool , AltDown() const,
        "Returns ``True`` if the Alt key was down at the time of the event.", "");

        bool , ShiftDown() const,
        "Returns ``True`` if the Shift key was down at the time of the event.", "");

        bool , CmdDown() const,
        "\"Cmd\" is a pseudo key which is the same as Control for PC and Unix
platforms but the special \"Apple\" (a.k.a as \"Command\") key on
Macs. It makes often sense to use it instead of, say, `ControlDown`
because Cmd key is used for the same thing under Mac as Ctrl
elsewhere. The Ctrl still exists, it's just not used for this
purpose. So for non-Mac platforms this is the same as `ControlDown`
and Macs this is the same as `MetaDown`.", "");

        bool , HasModifiers() const,
        "Returns true if either CTRL or ALT keys was down at the time of the
key event. Note that this function does not take into account neither
SHIFT nor META key states (the reason for ignoring the latter is that
it is common for NUMLOCK key to be configured as META under X but the
key presses even while NUMLOCK is on should be still processed
normally).", "");

    void SetControlDown(bool down);
    void SetShiftDown(bool down);
    void SetAltDown(bool down);
    void SetMetaDown(bool down);

    %pythoncode {
        controlDown = property(ControlDown, SetControlDown)
        shiftDown = property(ShiftDown, SetShiftDown)
        altDown = property(AltDown, SetAltDown)
        metaDown = property(MetaDown, SetMetaDown)
        cmdDown = property(CmdDown)

        # For 2.8 compatibility
        m_controlDown = wx.deprecated(controlDown)
        m_shiftDown = wx.deprecated(shiftDown)
        m_altDown = wx.deprecated(altDown)
        m_metaDown = wx.deprecated(metaDown)            
Tip: Filter by directory path e.g. /media app.js to search for public/media/app.js.
Tip: Use camelCasing e.g. ProjME to search for ProjectModifiedEvent.java.
Tip: Filter by extension type e.g. /repo .js to search for all .js files in the /repo directory.
Tip: Separate your search with spaces e.g. /ssh pom.xml to search for src/ssh/pom.xml.
Tip: Use ↑ and ↓ arrow keys to navigate and return to view the file.
Tip: You can also navigate files with Ctrl+j (next) and Ctrl+k (previous) and view the file with Ctrl+o.
Tip: You can also navigate files with Alt+j (next) and Alt+k (previous) and view the file with Alt+o.