123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- #include "stdafx.h"
- CPtrArray l_Listeners[RADIANT_MSGCOUNT];
- CPtrArray l_WindowListeners;
- CXYWndWrapper l_XYWndWrapper;
- void WINAPI QERApp_HookWindow(IWindowListener* pListen)
- {
- l_WindowListeners.Add( pListen );
- pListen->IncRef();
- }
- void WINAPI QERApp_UnHookWindow(IWindowListener* pListen)
- {
- for ( int i = 0; i < l_WindowListeners.GetSize(); i++ )
- {
- if (l_WindowListeners.GetAt(i) == pListen)
- {
- l_WindowListeners.RemoveAt(i);
- pListen->DecRef();
- return;
- }
- }
- #ifdef _DEBUG
- Sys_Printf("WARNING: IWindowListener not found in QERApp_UnHookWindow\n");
- #endif
- }
- void DispatchOnMouseMove(UINT nFlags, int x, int y)
- {
- for( int i = 0; i < l_WindowListeners.GetSize(); i++ )
- static_cast<IWindowListener*>(l_WindowListeners.GetAt(i))->OnMouseMove( nFlags, x, y );
- }
- bool DispatchOnLButtonDown(UINT nFlags, int x, int y)
- {
- for( int i = 0; i < l_WindowListeners.GetSize(); i++ )
- if (static_cast<IWindowListener*>(l_WindowListeners.GetAt(i))->OnLButtonDown( nFlags, x, y ))
- return true;
- return false;
- }
- bool DispatchOnLButtonUp(UINT nFlags, int x, int y)
- {
- for( int i = 0; i < l_WindowListeners.GetSize(); i++ )
- if (static_cast<IWindowListener*>(l_WindowListeners.GetAt(i))->OnLButtonUp( nFlags, x, y ))
- return true;
- return false;
- }
- void WINAPI QERApp_HookListener(IListener* pListen, int Msg)
- {
- #ifdef _DEBUG
- if (Msg >= RADIANT_MSGCOUNT)
- {
- Sys_Printf("ERROR: bad index in QERApp_HookListener\n");
- return;
- }
- #endif
- l_Listeners[Msg].Add( pListen );
- pListen->IncRef();
- }
- int WINAPI QERApp_UnHookListener(IListener* pListen)
- {
- int count = 0;
- for( int i = 0; i<RADIANT_MSGCOUNT; i++ )
- for( int j = 0; j<l_Listeners[i].GetSize(); j++ )
- if (l_Listeners[i].GetAt(j) == pListen)
- {
- l_Listeners[i].RemoveAt(j);
- pListen->DecRef();
- count++;
- }
- return count;
- }
- void DispatchRadiantMsg( int Msg )
- {
- #ifdef _DEBUG
- if (Msg >= RADIANT_MSGCOUNT)
- {
- Sys_Printf("ERROR: bad index in DispatchRadiantMsg\n");
- return;
- }
- #endif
- for(int i = 0; i<l_Listeners[Msg].GetSize(); i++)
- static_cast<IListener *>(l_Listeners[Msg].GetAt(i))->DispatchRadiantMsg(Msg);
- }
- void CXYWndWrapper::SnapToGrid( int x1, int y1, vec3_t pt )
- {
- CRect rctZ;
- g_pParentWnd->ActiveXY()->GetClientRect( rctZ );
- g_pParentWnd->ActiveXY()->SnapToPoint( x1, rctZ.Height() - 1 - y1, pt );
- }
- IXYWndWrapper* WINAPI QERApp_GetXYWndWrapper()
- {
- return &l_XYWndWrapper;
- }
|