Skip to content

Commit

Permalink
Simplify Device.java
Browse files Browse the repository at this point in the history
Remove useless intermediate method with a "mode" parameter (it's always
called with the same mode).

This also avoids the need for a specific injectEventOnDisplay() method,
since it does not conflict with another injectEvent() method anymore.
  • Loading branch information
rom1v committed Apr 30, 2021
1 parent ae6ec7a commit d00ee64
Showing 1 changed file with 5 additions and 17 deletions.
22 changes: 5 additions & 17 deletions server/src/main/java/com/genymobile/scrcpy/Device.java
Original file line number Diff line number Diff line change
Expand Up @@ -164,39 +164,27 @@ public boolean supportsInputEvents() {
return supportsInputEvents;
}

public static boolean injectEvent(InputEvent inputEvent, int mode, int displayId) {
public static boolean injectEvent(InputEvent inputEvent, int displayId) {
if (!supportsInputEvents(displayId)) {
return false;
throw new AssertionError("Could not inject input event if !supportsInputEvents()");
}

if (displayId != 0 && !InputManager.setDisplayId(inputEvent, displayId)) {
return false;
}

return SERVICE_MANAGER.getInputManager().injectInputEvent(inputEvent, mode);
}

public boolean injectEvent(InputEvent inputEvent, int mode) {
if (!supportsInputEvents()) {
throw new AssertionError("Could not inject input event if !supportsInputEvents()");
}

return injectEvent(inputEvent, mode, displayId);
}

public static boolean injectEventOnDisplay(InputEvent event, int displayId) {
return injectEvent(event, InputManager.INJECT_INPUT_EVENT_MODE_ASYNC, displayId);
return SERVICE_MANAGER.getInputManager().injectInputEvent(inputEvent, InputManager.INJECT_INPUT_EVENT_MODE_ASYNC);
}

public boolean injectEvent(InputEvent event) {
return injectEvent(event, InputManager.INJECT_INPUT_EVENT_MODE_ASYNC);
return injectEvent(event, displayId);
}

public static boolean injectKeyEvent(int action, int keyCode, int repeat, int metaState, int displayId) {
long now = SystemClock.uptimeMillis();
KeyEvent event = new KeyEvent(now, now, action, keyCode, repeat, metaState, KeyCharacterMap.VIRTUAL_KEYBOARD, 0, 0,
InputDevice.SOURCE_KEYBOARD);
return injectEventOnDisplay(event, displayId);
return injectEvent(event, displayId);
}

public boolean injectKeyEvent(int action, int keyCode, int repeat, int metaState) {
Expand Down

0 comments on commit d00ee64

Please sign in to comment.