Some work on support clipboard

This commit is contained in:
Deve 2017-05-04 22:36:12 +02:00
parent e27df23415
commit a9c2a1922a
4 changed files with 46 additions and 14 deletions

View File

@ -39,8 +39,9 @@ extern bool GLContextDebugBit;
#endif // _IRR_COMPILE_WITH_JOYSTICK_EVENTS_ #endif // _IRR_COMPILE_WITH_JOYSTICK_EVENTS_
#define XRANDR_ROTATION_LEFT (1 << 1) #define MOD_SHIFT_MASK 0x01
#define XRANDR_ROTATION_RIGHT (1 << 3) #define MOD_ALT_MASK 0x02
#define MOD_CONTROL_MASK 0x04
namespace irr namespace irr
{ {
@ -346,9 +347,8 @@ public:
irrevent.EventType = irr::EET_KEY_INPUT_EVENT; irrevent.EventType = irr::EET_KEY_INPUT_EVENT;
irrevent.KeyInput.PressedDown = (state == WL_KEYBOARD_KEY_STATE_PRESSED); irrevent.KeyInput.PressedDown = (state == WL_KEYBOARD_KEY_STATE_PRESSED);
irrevent.KeyInput.Char = xkb_keysym_to_utf32(sym); irrevent.KeyInput.Char = xkb_keysym_to_utf32(sym);
// irrevent.KeyInput.Char = ((wchar_t*)(buf))[0]; irrevent.KeyInput.Control = (device->modifiers & MOD_CONTROL_MASK) != 0;
// irrevent.KeyInput.Control = (event.xkey.state & ControlMask) != 0; irrevent.KeyInput.Shift = (device->modifiers & MOD_SHIFT_MASK) != 0;
// irrevent.KeyInput.Shift = (event.xkey.state & ShiftMask) != 0;
@ -405,13 +405,14 @@ public:
XKB_STATE_MODS_DEPRESSED | XKB_STATE_MODS_LATCHED); XKB_STATE_MODS_DEPRESSED | XKB_STATE_MODS_LATCHED);
mask = xkb_state_serialize_mods(device->state, mask = xkb_state_serialize_mods(device->state,
state_component); state_component);
//~ input->modifiers = 0;
//~ if (mask & input->xkb.control_mask) device->modifiers = 0;
//~ input->modifiers |= MOD_CONTROL_MASK; if (mask & device->control_mask)
//~ if (mask & input->xkb.alt_mask) device->modifiers |= MOD_CONTROL_MASK;
//~ input->modifiers |= MOD_ALT_MASK; if (mask & device->alt_mask)
//~ if (mask & input->xkb.shift_mask) device->modifiers |= MOD_ALT_MASK;
//~ input->modifiers |= MOD_SHIFT_MASK; if (mask & device->shift_mask)
device->modifiers |= MOD_SHIFT_MASK;
} }
static void static void
@ -631,7 +632,7 @@ CIrrDeviceWayland::CIrrDeviceWayland(const SIrrlichtCreationParameters& param)
linuxversion += " "; linuxversion += " ";
linuxversion += LinuxInfo.machine; linuxversion += LinuxInfo.machine;
Operator = new COSOperator(linuxversion); Operator = new COSOperator(linuxversion, this);
os::Printer::log(linuxversion.c_str(), ELL_INFORMATION); os::Printer::log(linuxversion.c_str(), ELL_INFORMATION);
// Retrieve wayland infos // Retrieve wayland infos
@ -1365,13 +1366,16 @@ bool CIrrDeviceWayland::getGammaRamp( f32 &red, f32 &green, f32 &blue, f32 &brig
//! \return Returns 0 if no string is in there. //! \return Returns 0 if no string is in there.
const c8* CIrrDeviceWayland::getTextFromClipboard() const const c8* CIrrDeviceWayland::getTextFromClipboard() const
{ {
return 0; printf("get text from clipboard: %s\n", Clipboard.c_str());
return Clipboard.c_str();
} }
//! copies text to the clipboard //! copies text to the clipboard
void CIrrDeviceWayland::copyToClipboard(const c8* text) const void CIrrDeviceWayland::copyToClipboard(const c8* text) const
{ {
printf("copy to clipboard: %s\n", text);
Clipboard = text;
} }

View File

@ -259,6 +259,7 @@ namespace irr
xkb_mod_mask_t control_mask; xkb_mod_mask_t control_mask;
xkb_mod_mask_t alt_mask; xkb_mod_mask_t alt_mask;
xkb_mod_mask_t shift_mask; xkb_mod_mask_t shift_mask;
uint32_t modifiers;
struct xkb_compose_table *compose_table; struct xkb_compose_table *compose_table;
struct xkb_compose_state *compose_state; struct xkb_compose_state *compose_state;

View File

@ -25,6 +25,9 @@
#if defined(_IRR_COMPILE_WITH_X11_DEVICE_) #if defined(_IRR_COMPILE_WITH_X11_DEVICE_)
#include "CIrrDeviceLinux.h" #include "CIrrDeviceLinux.h"
#endif #endif
#if defined(_IRR_COMPILE_WITH_WAYLAND)
#include "CIrrDeviceWayland.h"
#endif
#ifdef _IRR_COMPILE_WITH_OSX_DEVICE_ #ifdef _IRR_COMPILE_WITH_OSX_DEVICE_
#include "MacOSX/OSXClipboard.h" #include "MacOSX/OSXClipboard.h"
#endif #endif
@ -40,6 +43,14 @@ namespace irr
} }
#endif #endif
#if defined(_IRR_COMPILE_WITH_WAYLAND)
// constructor linux
COSOperator::COSOperator(const core::stringc& osVersion, CIrrDeviceWayland* device)
: OperatingSystem(osVersion), IrrDeviceWayland(device)
{
}
#endif
// constructor // constructor
COSOperator::COSOperator(const core::stringc& osVersion) : OperatingSystem(osVersion) COSOperator::COSOperator(const core::stringc& osVersion) : OperatingSystem(osVersion)
{ {
@ -121,6 +132,9 @@ void COSOperator::copyToClipboard(const c8* text) const
#elif defined(_IRR_COMPILE_WITH_X11_DEVICE_) #elif defined(_IRR_COMPILE_WITH_X11_DEVICE_)
if ( IrrDeviceLinux ) if ( IrrDeviceLinux )
IrrDeviceLinux->copyToClipboard(text); IrrDeviceLinux->copyToClipboard(text);
#elif defined(_IRR_COMPILE_WITH_WAYLAND)
if ( IrrDeviceWayland )
IrrDeviceWayland->copyToClipboard(text);
#else #else
#endif #endif
@ -177,6 +191,11 @@ const c8* COSOperator::getTextFromClipboard() const
return IrrDeviceLinux->getTextFromClipboard(); return IrrDeviceLinux->getTextFromClipboard();
return 0; return 0;
#elif defined(_IRR_COMPILE_WITH_WAYLAND)
if ( IrrDeviceWayland )
return IrrDeviceWayland->getTextFromClipboard();
return 0;
#else #else
return 0; return 0;

View File

@ -11,6 +11,7 @@ namespace irr
{ {
class CIrrDeviceLinux; class CIrrDeviceLinux;
class CIrrDeviceWayland;
//! The Operating system operator provides operation system specific methods and informations. //! The Operating system operator provides operation system specific methods and informations.
class COSOperator : public IOSOperator class COSOperator : public IOSOperator
@ -20,6 +21,9 @@ public:
// constructor // constructor
#if defined(_IRR_COMPILE_WITH_X11_DEVICE_) #if defined(_IRR_COMPILE_WITH_X11_DEVICE_)
COSOperator(const core::stringc& osversion, CIrrDeviceLinux* device); COSOperator(const core::stringc& osversion, CIrrDeviceLinux* device);
#endif
#if defined(_IRR_COMPILE_WITH_WAYLAND)
COSOperator(const core::stringc& osversion, CIrrDeviceWayland* device);
#endif #endif
COSOperator(const core::stringc& osversion); COSOperator(const core::stringc& osversion);
@ -59,6 +63,10 @@ private:
#if defined(_IRR_COMPILE_WITH_X11_DEVICE_) #if defined(_IRR_COMPILE_WITH_X11_DEVICE_)
CIrrDeviceLinux * IrrDeviceLinux; CIrrDeviceLinux * IrrDeviceLinux;
#endif #endif
#if defined(_IRR_COMPILE_WITH_WAYLAND)
CIrrDeviceWayland * IrrDeviceWayland;
#endif
}; };