Skip to content

Commit

Permalink
Add option to turn device screen off
Browse files Browse the repository at this point in the history
In addition to the shortcut (Ctrl+o) to turn the device screen off, add
a command-line argument to turn it off on start.
  • Loading branch information
rom1v committed Jun 4, 2019
1 parent 7f07b13 commit 8e66b33
Show file tree
Hide file tree
Showing 4 changed files with 35 additions and 6 deletions.
12 changes: 11 additions & 1 deletion app/src/main.c
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ struct args {
uint16_t max_size;
uint32_t bit_rate;
bool always_on_top;
bool turn_screen_off;
};

static void usage(const char *arg0) {
Expand Down Expand Up @@ -82,6 +83,9 @@ static void usage(const char *arg0) {
" The device serial number. Mandatory only if several devices\n"
" are connected to adb.\n"
"\n"
" -S, --turn-screen-off\n"
" Turn the device screen off immediately.\n"
"\n"
" -t, --show-touches\n"
" Enable \"show touches\" on start, disable on quit.\n"
" It only shows physical touches (not clicks from scrcpy).\n"
Expand Down Expand Up @@ -299,11 +303,12 @@ parse_args(struct args *args, int argc, char *argv[]) {
{"record-format", required_argument, NULL, 'f'},
{"serial", required_argument, NULL, 's'},
{"show-touches", no_argument, NULL, 't'},
{"turn-screen-off", no_argument, NULL, 'S'},
{"version", no_argument, NULL, 'v'},
{NULL, 0, NULL, 0 },
};
int c;
while ((c = getopt_long(argc, argv, "b:c:fF:hm:nNp:r:s:tTv", long_options,
while ((c = getopt_long(argc, argv, "b:c:fF:hm:nNp:r:s:StTv", long_options,
NULL)) != -1) {
switch (c) {
case 'b':
Expand Down Expand Up @@ -347,6 +352,9 @@ parse_args(struct args *args, int argc, char *argv[]) {
case 's':
args->serial = optarg;
break;
case 'S':
args->turn_screen_off = true;
break;
case 't':
args->show_touches = true;
break;
Expand Down Expand Up @@ -417,6 +425,7 @@ main(int argc, char *argv[]) {
.always_on_top = false,
.no_control = false,
.no_display = false,
.turn_screen_off = false,
};
if (!parse_args(&args, argc, argv)) {
return 1;
Expand Down Expand Up @@ -457,6 +466,7 @@ main(int argc, char *argv[]) {
.always_on_top = args.always_on_top,
.control = !args.no_control,
.display = !args.no_display,
.turn_screen_off = args.turn_screen_off,
};
int res = scrcpy(&options) ? 0 : 1;

Expand Down
10 changes: 10 additions & 0 deletions app/src/scrcpy.c
Original file line number Diff line number Diff line change
Expand Up @@ -375,6 +375,16 @@ scrcpy(const struct scrcpy_options *options) {
goto end;
}

if (options->turn_screen_off) {
struct control_msg msg;
msg.type = CONTROL_MSG_TYPE_SET_SCREEN_POWER_MODE;
msg.set_screen_power_mode.mode = SCREEN_POWER_MODE_OFF;

if (!controller_push_msg(&controller, &msg)) {
LOGW("Cannot request 'set screen power mode'");
}
}

if (options->fullscreen) {
screen_switch_fullscreen(&screen);
}
Expand Down
1 change: 1 addition & 0 deletions app/src/scrcpy.h
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ struct scrcpy_options {
bool always_on_top;
bool control;
bool display;
bool turn_screen_off;
};

bool
Expand Down
18 changes: 13 additions & 5 deletions server/src/main/java/com/genymobile/scrcpy/Controller.java
Original file line number Diff line number Diff line change
Expand Up @@ -53,9 +53,21 @@ private void setScroll(int hScroll, int vScroll) {
coords.setAxisValue(MotionEvent.AXIS_VSCROLL, vScroll);
}

@SuppressWarnings("checkstyle:MagicNumber")
public void control() throws IOException {
// on start, power on the device
powerOn();
if (!device.isScreenOn()) {
injectKeycode(KeyEvent.KEYCODE_POWER);

// dirty hack
// After POWER is injected, the device is powered on asynchronously.
// To turn the device screen off while mirroring, the client will send a message that
// would be handled before the device is actually powered on, so its effect would
// be "canceled" once the device is turned back on.
// Adding this delay prevents to handle the message before the device is actually
// powered on.
SystemClock.sleep(500);
}

while (true) {
handleEvent();
Expand Down Expand Up @@ -182,10 +194,6 @@ private boolean injectEvent(InputEvent event) {
return device.injectInputEvent(event, InputManager.INJECT_INPUT_EVENT_MODE_ASYNC);
}

private boolean powerOn() {
return device.isScreenOn() || injectKeycode(KeyEvent.KEYCODE_POWER);
}

private boolean pressBackOrTurnScreenOn() {
int keycode = device.isScreenOn() ? KeyEvent.KEYCODE_BACK : KeyEvent.KEYCODE_POWER;
return injectKeycode(keycode);
Expand Down

0 comments on commit 8e66b33

Please sign in to comment.