used newly InputEvent

This commit is contained in:
2022-01-24 18:57:10 +08:00
parent 72b59fc22e
commit 4f63548fc2
5 changed files with 131 additions and 403 deletions

View File

@@ -1,214 +0,0 @@
#ifndef HGL_INPUT_DEVICE_INCLUDE
#define HGL_INPUT_DEVICE_INCLUDE
#include<hgl/TypeFunc.h>
namespace hgl
{
/**
* 鼠标状态枚举定义
*/
enum MouseButton
{
mbMove =0x00000001, ///<鼠标移动了
mbLeft =0x00000002, ///<鼠标左键处于按下状态
mbMid =0x00000004, ///<鼠标中键处于按下状态
mbRight =0x00000008, ///<鼠标右键处于按下状态
mbX1 =0x00000010,
mbX2 =0x00000020,
mbShift =0x10000000, ///<Shift键处于按下状态
mbCtrl =0x20000000, ///<Ctrl键处于按下状态
};
/**
* 按键枚举定义
*/
enum class KeyboardButton
{
NONE=0,
//主键盘区
Esc, ///<ESC
//F功能键
F1, ///<F1
F2, ///<F2
F3, ///<F3
F4, ///<F4
F5, ///<F5
F6, ///<F6
F7, ///<F7
F8, ///<F8
F9, ///<F9
F10, ///<F10
F11, ///<F11
F12, ///<F12
Grave, //<`号(主键盘数字键1左边的按钮)
//10个数字
_0, ///<数字键0
_1, ///<数字键1
_2, ///<数字键2
_3, ///<数字键3
_4, ///<数字键4
_5, ///<数字键5
_6, ///<数字键6
_7, ///<数字键7
_8, ///<数字键8
_9, ///<数字键9
Minus, ///< - (减号)
Equals, ///< = (等号)
BackSlash, ///< \ (反斜杠)
BackSpace, ///< 退格键
Tab, ///<Tab键
A, ///<A
B, ///<B
C, ///<C
D, ///<D
E, ///<E
F, ///<F
G, ///<G
H, ///<H
I, ///<I
J, ///<J
K, ///<K
L, ///<L
M, ///<M
N, ///<N
O, ///<O
P, ///<P
Q, ///<Q
R, ///<R
S, ///<S
T, ///<T
U, ///<U
V, ///<V
W, ///<W
X, ///<X
Y, ///<Y
Z, ///<Z
LeftBracket, ///<[
RightBracket, ///<]
CapsLock, ///<大写锁定键
Semicolon, ///<; (分号)
Apostrophe, ///<' (单引号)
Enter, ///<回车键
LeftShift, ///<左边的Shift键
Comma, ///<, (逗号)
Period, ///<. (句号)
Slash, ///</ (除号)
RightShift, ///<右边的Shift键
LeftCtrl, ///<左边的Ctrl键
LeftOS, ///<左边的OS键(Win/Apple键)
LeftAlt, ///<左边的Alt键
Space, ///<空格键
RightAlt, ///<右边的Alt键
RightOS, ///<右边的OS键(Win/Apple键)
RightMenu, ///<右边的Menu键
RightCtrl, ///<右边的Ctrl键
//中键盘区
PrintScreen, ///<打印屏幕键
ScrollLock, ///<滚动锁定键
Pause, ///<暂停键
Insert, ///<插入键
Delete, ///<删除键
Home, ///<行首键
End, ///<行尾键
PageUp, ///<向前翻页键
PageDown, ///<向后翻页键
Up, ///<↑光标键
Down, ///<↓光标键
Left, ///<←光标键
Right, ///<→光标键
//小键盘区
NumLock, ///<小键盘 数字锁定键
NumAdd, ///<小键盘 +
NumSubtract, ///<小键盘 -
NumMultiply, ///<小键盘 *
NumDivide, ///<小键盘 /
Num0, ///<小键盘 0
Num1, ///<小键盘 1
Num2, ///<小键盘 2
Num3, ///<小键盘 3
Num4, ///<小键盘 4
Num5, ///<小键盘 5
Num6, ///<小键盘 6
Num7, ///<小键盘 7
Num8, ///<小键盘 8
Num9, ///<小键盘 9
NumDecimal, ///<小键盘 . (小数点/删除键)
NumEnter, ///<小键盘 回车键
ENUM_CLASS_RANGE(NONE,NumEnter)
};//enum KeyboardButton
/**
* 手柄按键枚举
*/
enum class JoystickButton
{
NONE=0,
Up,
Down,
Left,
Right,
_0, _1, _2, _3, _4, _5, _6, _7,
_8, _9, _10, _11, _12, _13, _14, _15,
_16, _17, _18, _19, _20, _21, _22, _23,
_24, _25, _26, _27, _28, _29, _30, _31,
ENUM_CLASS_RANGE(NONE,_31)
};
enum class PlayStationButton
{
Up =JoystickButton::Up,
Down =JoystickButton::Down,
Left =JoystickButton::Left,
Right =JoystickButton::Right,
Fork =JoystickButton::_0, // 叉
Circle =JoystickButton::_1, // 圆
Square =JoystickButton::_2, // 方
Triangle =JoystickButton::_3, // 三角
L1 =JoystickButton::_6, L2 =JoystickButton::_4,
R1 =JoystickButton::_7, R2 =JoystickButton::_5,
Select =JoystickButton::_8, Start =JoystickButton::_9,
};
//enum class XBoxButton
//{
// //DreamCast/XBOX
// X=JoystickButton::_2,
// Y=JoystickButton::_3,
// A=JoystickButton::_0,
// B=JoystickButton::_1,
// L=JoystickButton::_4,
// R=JoystickButton::_5,
// //XBOX/XBOX360
// //XBOX, //西瓜键
//};
}//namespace hgl
#endif//HGL_INPUT_DEVICE_INCLUDE

View File

@@ -2,11 +2,11 @@
#define HGL_GRAPH_WINDOW_INCLUDE
#include<hgl/type/String.h>
#include<hgl/platform/InputDevice.h>
#include<hgl/io/event/WindowEvent.h>
namespace hgl
{
class Window
class Window:io::WindowEvent
{
protected:
@@ -19,78 +19,31 @@ namespace hgl
bool is_close;
bool is_min;
bool key_push[size_t(KeyboardButton::RANGE_SIZE)];
protected:
io::InputEvent input_event;
io::InputEvent sub_input_event;
void OnResize(uint,uint) override;
void OnActive(bool) override;
void OnClose () override;
virtual bool MessageProc()=0;
virtual bool WaitMessage()=0;
public:
virtual void ProcMouseMove (int x,int y) {SafeCallEvent(OnMouseMove, (x,y));}
virtual void ProcMouseWheel (int v,int h,uint mb) {SafeCallEvent(OnMouseWheel, (v,h,mb));}
virtual void ProcMousePressed (int x,int y,uint mb) {SafeCallEvent(OnMousePressed, (x,y,mb));}
virtual void ProcMouseReleased (int x,int y,uint mb) {SafeCallEvent(OnMouseReleased, (x,y,mb));}
virtual void ProcMouseDblClicked(int x,int y,uint mb) {SafeCallEvent(OnMouseDblClicked, (x,y,mb));}
//virtual void ProcJoystickPressed (uint);
//virtual void ProcJoystickRepeat (uint);
//virtual void ProcJoystickReleased(uint);
virtual void ProcKeyPressed (KeyboardButton);
virtual void ProcKeyRepeat (KeyboardButton kb){SafeCallEvent(OnKeyRepeat,(kb));}
virtual void ProcKeyReleased(KeyboardButton);
virtual void ProcChar (os_char ch){SafeCallEvent(OnChar,(ch));}
virtual void ProcResize (uint,uint);
virtual void ProcActive (bool);
virtual void ProcClose ();
const uint GetWidth()const{return width;}
const uint GetHeight()const{return height;}
public:
uint GetWidth()const{return width;}
uint GetHeight()const{return height;}
public:
DefEvent(void,OnMouseMove, (int,int));
DefEvent(void,OnMouseWheel, (int,int,uint));
DefEvent(void,OnMousePressed, (int,int,uint));
DefEvent(void,OnMouseReleased, (int,int,uint));
DefEvent(void,OnMouseDblClicked,(int,int,uint));
//DefEvent(void,OnJoystickDown ,(uint));
//DefEvent(void,OnJoystickPress ,(uint));
//DefEvent(void,OnJoystickUp ,(uint));
DefEvent(void,OnKeyPressed, (KeyboardButton));
DefEvent(void,OnKeyRepeat, (KeyboardButton));
DefEvent(void,OnKeyReleased,(KeyboardButton));
DefEvent(void,OnChar ,(os_char));
DefEvent(void,OnResize ,(uint,uint));
DefEvent(void,OnActive ,(bool));
DefEvent(void,OnClose ,());
public:
Window(const OSString &wn)
{
width=height=0;
full_screen=false;
win_name=wn;
active=false;
is_close=true;
is_min=false;
hgl_zero(key_push);
}
Window(const OSString &);
virtual ~Window()=default;
bool Join(InputEvent *ie){return sub_input_event.Join(ie);}
bool Unjoin(InputEvent *ie){return sub_input_event.Unjoin(ie);}
virtual bool Create(uint,uint)=0;
virtual bool Create(uint,uint,uint)=0;
virtual void Close()=0;

View File

@@ -1,5 +1,7 @@
#include"WinWindow.h"
#include<hgl/platform/InputDevice.h>
#include<hgl/io/event/KeyboardEvent.h>
#include<hgl/io/event/MouseEvent.h>
#include<hgl/io/event/WindowEvent.h>
#include<Windows.h>
#ifdef _DEBUG
@@ -8,29 +10,14 @@
namespace hgl
{
using namespace io;
namespace
{
#define PROP_DPIISOLATION L"PROP_ISOLATION"
static KeyboardButton KeyConvert[256];
static void (*WMProc[2048])(WinWindow *,uint32,uint32); //消息处理队列
uint32 GetMouseKeyFlags(uint32 wflags)
{
uint32 flag=0;
if(wflags&MK_LBUTTON)flag|=mbLeft;
if(wflags&MK_RBUTTON)flag|=mbRight;
if(wflags&MK_MBUTTON)flag|=mbMid;
if(wflags&MK_XBUTTON1)flag|=mbX1;
if(wflags&MK_XBUTTON2)flag|=mbX2;
if(wflags&MK_SHIFT )flag|=mbShift;
if(wflags&MK_CONTROL)flag|=mbCtrl;
return(flag);
}
static void (*WMProc[2048])(InputEvent *,uint32,uint32); //消息处理队列
void InitKeyConvert()
{
@@ -191,79 +178,33 @@ namespace hgl
return KeyConvert[key];
}
static EventHeader event_header;
static WindowEventData window_event_data;
void WMProcNCCreate(WinWindow *win,uint32 wParam,uint32 lParam)
void WMProcDestroy(InputEvent *ie,uint32,uint32)
{
auto createStruct = reinterpret_cast<const CREATESTRUCTW *>(lParam);
auto createParams = static_cast<const WindowCreateExteraParams *>(createStruct->lpCreateParams);
event_header.type =(uint8)InputEventSource::Window;
event_header.index =0;
event_header.id =(uint16)WindowEventID::Close;
if (createParams->bEnableNonClientDpiScaling)
{
EnableNonClientDpiScaling(win->GetWnd());
}
// Store a flag on the window to note that it'll run its child in a different awareness
if (createParams->bChildWindowDpiIsolation)
{
SetPropW(win->GetWnd(), PROP_DPIISOLATION, (HANDLE)TRUE);
}
}
void WMProcCreate(WinWindow *win,uint32 wParam,uint32 lParam)
{
HWND hWnd=win->GetWnd();
RECT rcWindow = {};
UINT uDpi = 96;
DPI_AWARENESS dpiAwareness = GetAwarenessFromDpiAwarenessContext(GetThreadDpiAwarenessContext());
switch (dpiAwareness)
{
// Scale the window to the system DPI
case DPI_AWARENESS_SYSTEM_AWARE:
uDpi = GetDpiForSystem();
break;
// Scale the window to the monitor DPI
case DPI_AWARENESS_PER_MONITOR_AWARE:
uDpi = GetDpiForWindow(hWnd);
break;
}
GetWindowRect(hWnd, &rcWindow);
rcWindow.right = rcWindow.left + MulDiv(win->GetWidth(), uDpi, 96);
rcWindow.bottom = rcWindow.top + MulDiv(win->GetHeight(), uDpi, 96);
SetWindowPos(hWnd, nullptr, rcWindow.right, rcWindow.top, rcWindow.right - rcWindow.left, rcWindow.bottom - rcWindow.top, SWP_NOZORDER | SWP_NOACTIVATE);
BOOL bDpiIsolation = PtrToInt(GetPropW(hWnd, PROP_DPIISOLATION));
DPI_AWARENESS_CONTEXT previousDpiContext = {};
DPI_HOSTING_BEHAVIOR previousDpiHostingBehavior = {};
if (bDpiIsolation)
{
previousDpiHostingBehavior = SetThreadDpiHostingBehavior(DPI_HOSTING_BEHAVIOR_MIXED);
// For this example, we'll have the external content run with System-DPI awareness
previousDpiContext = SetThreadDpiAwarenessContext(DPI_AWARENESS_CONTEXT_SYSTEM_AWARE);
SetThreadDpiAwarenessContext(previousDpiContext);
SetThreadDpiHostingBehavior(previousDpiHostingBehavior);
}
}
void WMProcDestroy(WinWindow *win,uint32,uint32)
{
win->ProcClose();
ie->OnEvent(event_header,window_event_data.data);
PostQuitMessage(0);
}
#define WMEF_MOUSE(button,action) void WMProcMouse##button##action(WinWindow *win,uint32 wParam,uint32 lParam) \
static MouseEventData mouse_event_data;
#define WMEF_MOUSE(mouse_button,action) void WMProcMouse##mouse_button##action(InputEvent *ie,uint32 wParam,uint32 lParam) \
{ \
const int x=LOWORD(lParam); \
const int y=HIWORD(lParam); \
mouse_event_data.x=LOWORD(lParam); \
mouse_event_data.y=HIWORD(lParam); \
mouse_event_data.button=(uint8)MouseButton::mouse_button; \
\
win->ProcMouseMove(x,y); \
win->ProcMouse##action(x,y,mb##button|GetMouseKeyFlags(wParam)); \
event_header.type =(uint8)InputEventSource::Mouse; \
event_header.index =0; \
event_header.id =(uint16)MouseEventID::action; \
\
ie->OnEvent(event_header,mouse_event_data.data); \
}
WMEF_MOUSE(Left,Pressed);
@@ -278,49 +219,100 @@ namespace hgl
WMEF_MOUSE(Right,Released);
WMEF_MOUSE(Right,DblClicked);
void WMProcMouseMove(WinWindow *win,uint32 wParam,uint32 lParam)
void WMProcMouseMove(InputEvent *ie,uint32 wParam,uint32 lParam)
{
win->ProcMouseMove(LOWORD(lParam),HIWORD(lParam));
mouse_event_data.x=LOWORD(lParam);
mouse_event_data.y=HIWORD(lParam);
mouse_event_data.button=0;
event_header.type =(uint8)InputEventSource::Mouse;
event_header.index =0;
event_header.id =(uint16)MouseEventID::Move;
ie->OnEvent(event_header,mouse_event_data.data);
}
#undef WMEF_MOUSE
#define WMEF2(name) void name(WinWindow *win,uint32 wParam,uint32 lParam)
#define WMEF2(name) void name(InputEvent *ie,uint32 wParam,uint32 lParam)
WMEF2(WMProcMouseWheel)
{
const int zDelta=GET_WHEEL_DELTA_WPARAM(wParam);
const uint key=(uint)ConvertOSKey(GET_KEYSTATE_WPARAM(wParam));
//const uint key=(uint)ConvertOSKey(GET_KEYSTATE_WPARAM(wParam));
win->ProcMouseWheel(zDelta,0,key);
mouse_event_data.x=0;
mouse_event_data.y=zDelta;
mouse_event_data.button=0;
event_header.type =(uint8)InputEventSource::Mouse;
event_header.index =0;
event_header.id =(uint16)MouseEventID::Wheel;
ie->OnEvent(event_header,mouse_event_data.data);
}
WMEF2(WMProcMouseHWheel)
{
const int zDelta=GET_WHEEL_DELTA_WPARAM(wParam);
const uint key=(uint)ConvertOSKey(GET_KEYSTATE_WPARAM(wParam));
//const uint key=(uint)ConvertOSKey(GET_KEYSTATE_WPARAM(wParam));
win->ProcMouseWheel(0,zDelta,key);
mouse_event_data.x=zDelta;
mouse_event_data.y=0;
mouse_event_data.button=0;
event_header.type =(uint8)InputEventSource::Mouse;
event_header.index =0;
event_header.id =(uint16)MouseEventID::Wheel;
ie->OnEvent(event_header,mouse_event_data.data);
}
WMEF2(WMProcSize)
{
win->ProcResize(LOWORD(lParam),HIWORD(lParam));
event_header.type =(uint8)InputEventSource::Window;
event_header.index =0;
event_header.id =(uint16)WindowEventID::Resize;
window_event_data.width =LOWORD(lParam);
window_event_data.height=HIWORD(lParam);
ie->OnEvent(event_header,window_event_data.data);
}
#undef WMEF2
#define WMEF1(name) void name(WinWindow *win,uint32 wParam,uint32)
static KeyboardEventData keyboard_event_data;
#define WMEF1(name) void name(InputEvent *ie,uint32 wParam,uint32)
WMEF1(WMProcKeyDown)
{
win->ProcKeyPressed(ConvertOSKey(wParam));
event_header.type =(uint8)InputEventSource::Keyboard;
event_header.index =0;
event_header.id =(uint16)KeyboardEventID::Pressed;
keyboard_event_data.key=(uint32)ConvertOSKey(wParam);
ie->OnEvent(event_header,keyboard_event_data.data);
}
WMEF1(WMProcKeyUp)
{
win->ProcKeyReleased(ConvertOSKey(wParam));
event_header.type =(uint8)InputEventSource::Keyboard;
event_header.index =0;
event_header.id =(uint16)KeyboardEventID::Released;
keyboard_event_data.key=(uint32)ConvertOSKey(wParam);
ie->OnEvent(event_header,keyboard_event_data.data);
}
WMEF1(WMProcChar)
{
win->ProcChar((wchar_t)wParam);
event_header.type =(uint8)InputEventSource::Keyboard;
event_header.index =0;
event_header.id =(uint16)KeyboardEventID::Char;
keyboard_event_data.ch=(wchar_t)wParam;
ie->OnEvent(event_header,keyboard_event_data.data);
}
WMEF1(WMProcActive)
@@ -328,7 +320,13 @@ namespace hgl
//if(JoyPlugIn)
// JoyInterface.SetInputActive(wParam);
win->ProcActive(wParam);
event_header.type =(uint8)InputEventSource::Window;
event_header.index =0;
event_header.id =(uint16)WindowEventID::Active;
window_event_data.active=wParam;
ie->OnEvent(event_header,window_event_data.data);
}
#undef WMEF1
}//namespace
@@ -343,8 +341,6 @@ namespace hgl
#define WM_MAP(wm,func) WMProc[wm]=func;
WM_MAP(WM_NCCREATE ,WMProcNCCreate);
WM_MAP(WM_CREATE ,WMProcCreate);
WM_MAP(WM_CLOSE ,WMProcDestroy);
WM_MAP(WM_LBUTTONDOWN ,WMProcMouseLeftPressed);
WM_MAP(WM_LBUTTONUP ,WMProcMouseLeftReleased);
@@ -375,10 +371,10 @@ namespace hgl
if(uMsg<2048)
if(WMProc[uMsg])
{
WinWindow *win=(WinWindow *)GetWindowLongPtrW(hWnd,GWLP_USERDATA);
InputEvent *ie=(InputEvent *)GetWindowLongPtrW(hWnd,GWLP_USERDATA);
if(win)
WMProc[uMsg](win,wParam,lParam);
if(ie)
WMProc[uMsg](ie,wParam,lParam);
}
return (DefWindowProcW(hWnd, uMsg, wParam, lParam));

View File

@@ -98,7 +98,7 @@ namespace hgl
}
win_dc = GetDC(win_hwnd);
SetWindowLongPtrW(win_hwnd, GWLP_USERDATA, (LONG_PTR)this);
SetWindowLongPtrW(win_hwnd, GWLP_USERDATA, (LONG_PTR)&input_event);
return(true);
}
@@ -205,8 +205,8 @@ namespace hgl
TranslateMessage(&win_msg);
DispatchMessage(&win_msg);
if(win_msg.message==WM_QUIT)
ProcClose();
// if(win_msg.message==WM_QUIT)
// OnClose();
return(true);
}

View File

@@ -2,24 +2,20 @@
namespace hgl
{
void Window::ProcKeyPressed(KeyboardButton kb)
Window::Window(const OSString &wn)
{
if(key_push[size_t(kb)])
ProcKeyRepeat(kb);
else
key_push[size_t(kb)]=true;
width=height=0;
full_screen=false;
win_name=wn;
active=false;
is_close=true;
is_min=false;
SafeCallEvent(OnKeyPressed,(kb));
input_event.Join(this);
input_event.Join(&sub_input_event);
}
void Window::ProcKeyReleased(KeyboardButton kb)
{
key_push[size_t(kb)]=false;
SafeCallEvent(OnKeyReleased,(kb));
}
void Window::ProcResize(uint w,uint h)
void Window::OnResize(uint w,uint h)
{
if(w==width&&height==h)
return;
@@ -35,20 +31,17 @@ namespace hgl
{
is_min=false;
}
SafeCallEvent(OnResize,(w,h));
}
void Window::ProcActive(bool a)
void Window::OnActive(bool a)
{
active=a;
SafeCallEvent(OnActive,(a));
active=a;
}
void Window::ProcClose()
void Window::OnClose()
{
is_close=true;
SafeCallEvent(OnClose,());
input_event.Unjoin(this);
is_close=true;
}
bool Window::Update()