return (m_controlDown ? wxMOD_CONTROL : 0) |
(m_shiftDown ? wxMOD_SHIFT : 0) |
(m_metaDown ? wxMOD_META : 0) |
+ (m_rawControlDown ? wxMOD_RAW_CONTROL : 0) |
(m_altDown ? wxMOD_ALT : 0);
}
// accessors for individual modifier keys
bool ControlDown() const { return m_controlDown; }
+ bool RawControlDown() const
+ {
+#ifdef __WXOSX__
+ return m_rawControlDown;
+#else
+ return m_controlDown;
+#endif
+ }
bool ShiftDown() const { return m_shiftDown; }
bool MetaDown() const { return m_metaDown; }
bool AltDown() const { return m_altDown; }
// purpose under Mac)
bool CmdDown() const
{
-#if defined(__WXMAC__) || defined(__WXCOCOA__)
- return MetaDown();
-#else
return ControlDown();
-#endif
}
// these functions are mostly used by wxWidgets itself
// ---------------------------------------------------
void SetControlDown(bool down) { m_controlDown = down; }
+ void SetRawControlDown(bool down)
+ {
+#ifdef __WXOSX__
+ m_rawControlDown = down;
+#else
+ m_controlDown = down;
+#endif
+ }
void SetShiftDown(bool down) { m_shiftDown = down; }
void SetAltDown(bool down) { m_altDown = down; }
void SetMetaDown(bool down) { m_metaDown = down; }
// members of wxKeyEvent directly, these variables are public, however you
// should not use them in any new code, please use the accessors instead
public:
- bool m_controlDown : 1;
- bool m_shiftDown : 1;
- bool m_altDown : 1;
- bool m_metaDown : 1;
+ bool m_controlDown : 1;
+ bool m_shiftDown : 1;
+ bool m_altDown : 1;
+ bool m_metaDown : 1;
+#ifdef __WXOSX__
+ bool m_rawControlDown : 1;
+#endif
};
#endif // _WX_KBDSTATE_H_
bool HasModifiers() const;
/**
- Returns true if the Control key is pressed.
+ Returns true if the Control key or Apple/Command key under OS X is pressed.
This function doesn't distinguish between right and left control keys.
- In portable code you usually want to use CmdDown() to automatically
- test for the more frequently used Command key (and not the rarely used
- Control one) under Mac.
-
Notice that GetModifiers() should usually be used instead of this one.
*/
bool ControlDown() const;
+ /**
+ Returns true if the Control key (also under OS X).
+
+ This function doesn't distinguish between right and left control keys.
+
+ Notice that GetModifiers() should usually be used instead of this one.
+ */
+ bool RawControlDown() const;
+
/**
Returns true if the Shift key is pressed.
Returns true if the Meta/Windows/Apple key is pressed.
This function tests the state of the key traditionally called Meta
- under Unix systems, Windows keys under MSW and Apple, or Command, key
- under Mac.
-
+ under Unix systems, Windows keys under MSW
Notice that GetModifiers() should usually be used instead of this one.
@see CmdDown()
bool AltDown() const;
/**
- Returns true if the key used for command accelerators is pressed.
-
- @c Cmd is a pseudo key which is Control for PC and Unix platforms but
- Apple (or Command) key under Macs: it makes often sense to use it
- instead of ControlDown() because @c Command key is used for the same
- thing under Mac as @c Control elsewhere (even though @c Control still
- exists, it is usually not used for the same purpose under Mac).
+ Returns true if the key used for command accelerators is pressed. Same as
+ ControlDown(). Deprecated.
Notice that GetModifiers() should usually be used instead of this one.
*/
void SetControlDown(bool down);
+ void SetRawControlDown(bool down);
void SetShiftDown(bool down);
void SetAltDown(bool down);
void SetMetaDown(bool down);