forked from Mirrorlandia_minetest/irrlicht
SDL: Implement touchscreen support
This commit is contained in:
parent
a2b6244f54
commit
7df45b4cf3
@ -229,7 +229,7 @@ CIrrDeviceSDL::CIrrDeviceSDL(const SIrrlichtCreationParameters& param)
|
|||||||
Window((SDL_Window*)param.WindowId), SDL_Flags(0),
|
Window((SDL_Window*)param.WindowId), SDL_Flags(0),
|
||||||
MouseX(0), MouseY(0), MouseXRel(0), MouseYRel(0), MouseButtonStates(0),
|
MouseX(0), MouseY(0), MouseXRel(0), MouseYRel(0), MouseButtonStates(0),
|
||||||
Width(param.WindowSize.Width), Height(param.WindowSize.Height),
|
Width(param.WindowSize.Width), Height(param.WindowSize.Height),
|
||||||
Resizable(param.WindowResizable == 1 ? true : false)
|
Resizable(param.WindowResizable == 1 ? true : false), CurrentTouchCount(0)
|
||||||
{
|
{
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
setDebugName("CIrrDeviceSDL");
|
setDebugName("CIrrDeviceSDL");
|
||||||
@ -254,6 +254,11 @@ CIrrDeviceSDL::CIrrDeviceSDL(const SIrrlichtCreationParameters& param)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Minetest has its own code to synthesize mouse events from touch events,
|
||||||
|
// so we prevent SDL from doing it.
|
||||||
|
SDL_SetHint(SDL_HINT_TOUCH_MOUSE_EVENTS, "0");
|
||||||
|
SDL_SetHint(SDL_HINT_MOUSE_TOUCH_EVENTS, "0");
|
||||||
|
|
||||||
// create keymap
|
// create keymap
|
||||||
createKeyMap();
|
createKeyMap();
|
||||||
|
|
||||||
@ -745,6 +750,45 @@ bool CIrrDeviceSDL::run()
|
|||||||
postEventFromUser(irrevent);
|
postEventFromUser(irrevent);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case SDL_FINGERDOWN:
|
||||||
|
irrevent.EventType = EET_TOUCH_INPUT_EVENT;
|
||||||
|
irrevent.TouchInput.Event = ETIE_PRESSED_DOWN;
|
||||||
|
irrevent.TouchInput.ID = SDL_event.tfinger.fingerId;
|
||||||
|
irrevent.TouchInput.X = SDL_event.tfinger.x * Width;
|
||||||
|
irrevent.TouchInput.Y = SDL_event.tfinger.y * Height;
|
||||||
|
CurrentTouchCount++;
|
||||||
|
irrevent.TouchInput.touchedCount = CurrentTouchCount;
|
||||||
|
|
||||||
|
postEventFromUser(irrevent);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SDL_FINGERMOTION:
|
||||||
|
irrevent.EventType = EET_TOUCH_INPUT_EVENT;
|
||||||
|
irrevent.TouchInput.Event = ETIE_MOVED;
|
||||||
|
irrevent.TouchInput.ID = SDL_event.tfinger.fingerId;
|
||||||
|
irrevent.TouchInput.X = SDL_event.tfinger.x * Width;
|
||||||
|
irrevent.TouchInput.Y = SDL_event.tfinger.y * Height;
|
||||||
|
irrevent.TouchInput.touchedCount = CurrentTouchCount;
|
||||||
|
|
||||||
|
postEventFromUser(irrevent);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SDL_FINGERUP:
|
||||||
|
irrevent.EventType = EET_TOUCH_INPUT_EVENT;
|
||||||
|
irrevent.TouchInput.Event = ETIE_LEFT_UP;
|
||||||
|
irrevent.TouchInput.ID = SDL_event.tfinger.fingerId;
|
||||||
|
irrevent.TouchInput.X = SDL_event.tfinger.x * Width;
|
||||||
|
irrevent.TouchInput.Y = SDL_event.tfinger.y * Height;
|
||||||
|
// To match Android behavior, still count the pointer that was
|
||||||
|
// just released.
|
||||||
|
irrevent.TouchInput.touchedCount = CurrentTouchCount;
|
||||||
|
if (CurrentTouchCount > 0) {
|
||||||
|
CurrentTouchCount--;
|
||||||
|
}
|
||||||
|
|
||||||
|
postEventFromUser(irrevent);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
} // end switch
|
} // end switch
|
||||||
|
@ -318,6 +318,8 @@ namespace irr
|
|||||||
|
|
||||||
core::array<SKeyMap> KeyMap;
|
core::array<SKeyMap> KeyMap;
|
||||||
SDL_SysWMinfo Info;
|
SDL_SysWMinfo Info;
|
||||||
|
|
||||||
|
s32 CurrentTouchCount;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
Loading…
Reference in New Issue
Block a user