InputEvent不再分多类建多组

This commit is contained in:
hyzboy 2025-06-10 01:31:18 +08:00
parent 86ac0c37fc
commit 333bec0a12
5 changed files with 66 additions and 49 deletions

View File

@ -6,7 +6,7 @@ namespace hgl::io
{
struct EventHeader
{
uint8 type; ///<输入源类型
InputEventSource type; ///<输入源类型
uint8 index; ///<输入源索引(比如同一设备有多个)
uint16 id; ///<事件id
};
@ -28,7 +28,11 @@ namespace hgl::io
InputEventSource source_type;
SortedSet<InputEvent *> sub_event_proc[size_t(InputEventSource::RANGE_SIZE)];
InputEvent *parent_input_event;
SortedSet<InputEvent *> sub_event_proc;
void SetParent(InputEvent *ie){parent_input_event=ie;}
public:
@ -36,20 +40,12 @@ namespace hgl::io
virtual EventProcResult OnEvent(const EventHeader &header,const uint64 data)
{
if(!RangeCheck((InputEventSource)header.type))
if(!RangeCheck(header.type))
return(EventProcResult::Break);
if(sub_event_proc[header.type].GetCount()>0)
if(!sub_event_proc.IsEmpty())
{
for(InputEvent *ie:sub_event_proc[header.type])
if(ie->OnEvent(header,data)==EventProcResult::Break)
return EventProcResult::Break;
}
if(sub_event_proc[size_t(InputEventSource::Root)].GetCount()>0
&&InputEventSource(header.type)!=InputEventSource::Root)
{
for(InputEvent *ie:sub_event_proc[size_t(InputEventSource::Root)])
for(InputEvent *ie:sub_event_proc)
if(ie->OnEvent(header,data)==EventProcResult::Break)
return EventProcResult::Break;
}
@ -62,14 +58,20 @@ namespace hgl::io
InputEvent()
{
source_type=InputEventSource::Root;
parent_input_event=nullptr;
}
InputEvent(InputEventSource ies)
{
source_type=ies;
parent_input_event=nullptr;
}
virtual ~InputEvent()=default;
virtual ~InputEvent()
{
if(parent_input_event)
parent_input_event->Unjoin(this);
}
virtual bool Join(InputEvent *ie)
{
@ -81,7 +83,9 @@ namespace hgl::io
if(!RangeCheck(ies))
return(false);
return(sub_event_proc[size_t(ies)].Add(ie)!=-1);
ie->SetParent(this);
return(sub_event_proc.Add(ie)!=-1);
}
bool Unjoin(InputEvent *ie)
@ -93,7 +97,11 @@ namespace hgl::io
if(!RangeCheck(ies))
return(false);
return sub_event_proc[size_t(ies)].Delete(ie);
ie->SetParent(nullptr);
return sub_event_proc.Delete(ie);
}
virtual bool Update(){return true;}
};//class InputEvent
}//namespace hgl::io

View File

@ -3,7 +3,7 @@
#include<hgl/TypeFunc.h>
namespace hgl::io
{
enum class InputEventSource
enum class InputEventSource:uint8
{
Root=0,

View File

@ -167,15 +167,18 @@ namespace hgl
EventProcResult OnEvent(const EventHeader &header,const uint64 data) override
{
if(InputEvent::OnEvent(header,data)==EventProcResult::Break)
return EventProcResult::Break;
if(header.type==InputEventSource::Keyboard)
{
switch(KeyboardEventID(header.id))
{
case KeyboardEventID::Pressed: if(OnPressed (KeyboardButton(((KeyboardEventData *)&data)->key)))return EventProcResult::Break;break;
case KeyboardEventID::Released: if(OnReleased (KeyboardButton(((KeyboardEventData *)&data)->key)))return EventProcResult::Break;break;
case KeyboardEventID::Char: if(OnChar ( ((KeyboardEventData *)&data)->ch ) )return EventProcResult::Break;break;
}
}
if(InputEvent::OnEvent(header,data)==EventProcResult::Break)
return EventProcResult::Break;
return EventProcResult::Continue;
}

View File

@ -64,9 +64,8 @@ namespace hgl
EventProcResult OnEvent(const EventHeader &header,const uint64 data) override
{
if(InputEvent::OnEvent(header,data)==EventProcResult::Break)
return EventProcResult::Break;
if(header.type==InputEventSource::Mouse)
{
med=(MouseEventData *)&data;
if(MouseEventID(header.id)==MouseEventID::Wheel)
@ -87,6 +86,10 @@ namespace hgl
case MouseEventID::DblClicked: if(OnDblClicked (med->x,med->y,MouseButton(med->button)))return EventProcResult::Break;break;
}
}
}
if(InputEvent::OnEvent(header,data)==EventProcResult::Break)
return EventProcResult::Break;
return EventProcResult::Continue;
}

View File

@ -33,10 +33,12 @@ namespace hgl
public:
WindowEvent():InputEvent(InputEventSource::Window){}
WindowEvent():InputEvent(InputEventSource::Window){wed=nullptr;}
virtual ~WindowEvent()=default;
virtual EventProcResult OnEvent(const EventHeader &header,const uint64 data) override
{
if(header.type==InputEventSource::Window)
{
wed=(WindowEventData *)&data;
@ -46,6 +48,7 @@ namespace hgl
case WindowEventID::Resize:OnResize (wed->width,wed->height);break;
case WindowEventID::Close: OnClose () ;break;
}
}
if(InputEvent::OnEvent(header,data)==EventProcResult::Break)
return EventProcResult::Break;