Provided by: scrcpy_1.25-1ubuntu1_amd64 bug

NAME

       scrcpy - Display and control your Android device

SYNOPSIS

       scrcpy [options]

DESCRIPTION

       scrcpy  provides  display  and  control of Android devices connected on USB (or over TCP/IP). It does not
       require any root access.

OPTIONS

       --always-on-top
              Make scrcpy window always on top (above other windows).

       -b, --bit-rate value
              Encode the video at the given bit-rate, expressed in bits/s.  Unit  suffixes  are  supported:  'K'
              (x1000) and 'M' (x1000000).

              Default is 8000000.

       --codec-options key[:type]=value[,...]
              Set a list of comma-separated key:type=value options for the device encoder.

              The possible values for 'type' are 'int' (default), 'long', 'float' and 'string'.

              The   list   of   possible   codec   options   is   available   in   the   Android   documentation
              https://d.android.com/reference/android/media/MediaFormat.

       --crop width:height:x:y
              Crop the device screen on the server.

              The values are expressed in the device natural  orientation  (typically,  portrait  for  a  phone,
              landscape for a tablet). Any --max-size value is computed on the cropped size.

       -d, --select-usb
              Use USB device (if there is exactly one, like adb -d).

              Also see -e (--select-tcpip).

       --disable-screensaver
              Disable screensaver while scrcpy is running.

       --display id
              Specify the display id to mirror.

              The  list  of  possible  display  ids  can  be  listed  by  "adb  shell  dumpsys  display" (search
              "mDisplayId=" in the output).

              Default is 0.

       --display-buffer ms
              Add a buffering delay (in milliseconds) before displaying. This increases  latency  to  compensate
              for jitter.

              Default is 0 (no buffering).

       -e, --select-tcpip
              Use TCP/IP device (if there is exactly one, like adb -e).

              Also see -d (--select-usb).

       --encoder name
              Use a specific MediaCodec encoder (must be a H.264 encoder).

       --force-adb-forward
              Do not attempt to use "adb reverse" to connect to the device.

       --forward-all-clicks
              By  default,  right-click  triggers BACK (or POWER on) and middle-click triggers HOME. This option
              disables these shortcuts and forward the clicks to the device instead.

       -f, --fullscreen
              Start in fullscreen.

       -h, --help
              Print this help.

       -K, --hid-keyboard
              Simulate a physical keyboard by using HID over AOAv2.

              This provides a better experience for IME users, and  allows  to  generate  non-ASCII  characters,
              contrary to the default injection method.

              It may only work over USB.

              The keyboard layout must be configured (once and for all) on the device, via Settings -> System ->
              Languages and input -> Physical keyboard. This settings page can be started directly:

                  adb shell am start -a android.settings.HARD_KEYBOARD_SETTINGS

              However,  the option is only available when the HID keyboard is enabled (or a physical keyboard is
              connected).

              Also see --hid-mouse.

       --legacy-paste
              Inject computer clipboard text as a sequence of key events on Ctrl+v (like MOD+Shift+v).

              This is a workaround for some devices not behaving as expected when setting the  device  clipboard
              programmatically.

       --lock-video-orientation[=value]
              Lock  video orientation to value. Possible values are "unlocked", "initial" (locked to the initial
              orientation), 0, 1, 2 and 3. Natural device orientation is 0, and each increment adds a 90 degrees
              rotation counterclockwise.

              Default is "unlocked".

              Passing the option without argument is equivalent to passing "initial".

       --max-fps value
              Limit the framerate of screen capture (officially supported since Android  10,  but  may  work  on
              earlier versions).

       -m, --max-size value
              Limit both the width and height of the video to value. The other dimension is computed so that the
              device aspect-ratio is preserved.

              Default is 0 (unlimited).

       -M, --hid-mouse
              Simulate a physical mouse by using HID over AOAv2.

              In this mode, the computer mouse is captured to control the device directly (relative mouse mode).

              LAlt, LSuper or RSuper toggle the capture mode, to give control of the mouse back to the computer.

              It may only work over USB.

              Also see --hid-keyboard.

       --no-cleanup
              By  default,  scrcpy removes the server binary from the device and restores the device state (show
              touches, stay awake and power mode) on exit.

              This option disables this cleanup.

       --no-clipboard-autosync
              By default, scrcpy automatically synchronizes the  computer  clipboard  to  the  device  clipboard
              before injecting Ctrl+v, and the device clipboard to the computer clipboard whenever it changes.

              This option disables this automatic synchronization.

       --no-downsize-on-error
              By default, on MediaCodec error, scrcpy automatically tries again with a lower definition.

              This option disables this behavior.

       -n, --no-control
              Disable device control (mirror the device in read-only).

       -N, --no-display
              Do not display device (only when screen recording is enabled).

       --no-key-repeat
              Do not forward repeated key events when a key is held down.

       --no-mipmaps
              If  the  renderer  is  OpenGL  3.0+ or OpenGL ES 2.0+, then mipmaps are automatically generated to
              improve downscaling quality. This option disables the generation of mipmaps.

       --no-power-on
              Do not power on the device on start.

       --otg  Run in OTG mode: simulate physical keyboard and mouse, as if the computer keyboard and mouse  were
              plugged directly to the device via an OTG cable.

              In this mode, adb (USB debugging) is not necessary, and mirroring is disabled.

              LAlt,  LSuper  or  RSuper  toggle the mouse capture mode, to give control of the mouse back to the
              computer.

              If any of --hid-keyboard or --hid-mouse is  set,  only  enable  keyboard  or  mouse  respectively,
              otherwise enable both.

              It may only work over USB.

              See --hid-keyboard and --hid-mouse.

       -p, --port port[:port]
              Set the TCP port (range) used by the client to listen.

              Default is 27183:27199.

       --power-off-on-close
              Turn the device screen off when closing scrcpy.

       --prefer-text
              Inject alpha characters and space as text events instead of key events.

              This  avoids  issues  when  combining  multiple  keys  to enter special characters, but breaks the
              expected behavior of alpha keys in games (typically WASD).

       --print-fps
              Start FPS counter, to print framerate logs to the console. It can be started  or  stopped  at  any
              time with MOD+i.

       --push-target path
              Set  the  target  directory  for pushing files to the device by drag & drop. It is passed as-is to
              "adb push".

              Default is "/sdcard/Download/".

       --raw-key-events
              Inject key events for all input keys, and ignore text events.

       -r, --record file
              Record screen to file.

              The format is determined by the --record-format option if set, or by the file extension  (.mp4  or
              .mkv).

       --record-format format
              Force recording format (either mp4 or mkv).

       --render-driver name
              Request SDL to use the given render driver (this is just a hint).

              Supported   names  are  currently  "direct3d",  "opengl",  "opengles2",  "opengles",  "metal"  and
              "software".

              https://wiki.libsdl.org/SDL_HINT_RENDER_DRIVER

       --rotation value
              Set the initial display rotation. Possibles values are 0, 1, 2 and 3. Each  increment  adds  a  90
              degrees rotation counterclockwise.

       -s, --serial number
              The device serial number. Mandatory only if several devices are connected to adb.

       --shortcut-mod key[+...]][,...]
              Specify  the  modifiers  to  use for scrcpy shortcuts. Possible keys are "lctrl", "rctrl", "lalt",
              "ralt", "lsuper" and "rsuper".

              A shortcut can consist in several keys, separated by '+'.  Several  shortcuts  can  be  specified,
              separated by ','.

              For example, to use either LCtrl+LAlt or LSuper for scrcpy shortcuts, pass "lctrl+lalt,lsuper".

              Default is "lalt,lsuper" (left-Alt or left-Super).

       --tcpip[=ip[:port]]
              Configure and reconnect the device over TCP/IP.

              If  a  destination  address is provided, then scrcpy connects to this address before starting. The
              device must listen on the given TCP port (default is 5555).

              If no destination address is provided, then scrcpy attempts to find the IP address and adb port of
              the current device (typically connected over USB), enables TCP/IP mode if necessary, then connects
              to this address before starting.

       -S, --turn-screen-off
              Turn the device screen off immediately.

       -t, --show-touches
              Enable "show touches" on start, restore the initial value on exit.

              It only shows physical touches (not clicks from scrcpy).

       --tunnel-host ip
              Set the IP address of the adb tunnel to reach the scrcpy server. This option automatically enables
              --force-adb-forward.

              Default is localhost.

       --tunnel-port port
              Set the TCP port of the adb tunnel to reach the scrcpy server. This option  automatically  enables
              --force-adb-forward.

              Default is 0 (not forced): the local port used for establishing the tunnel will be used.

       --v4l2-sink /dev/videoN
              Output to v4l2loopback device.

              It requires to lock the video orientation (see --lock-video-orientation).

       --v4l2-buffer ms
              Add  a  buffering  delay  (in  milliseconds)  before  pushing  frames.  This  increases latency to
              compensate for jitter.

              This option is similar to --display-buffer, but specific to V4L2 sink.

              Default is 0 (no buffering).

       -V, --verbosity value
              Set the log level ("verbose", "debug", "info", "warn" or "error").

              Default is "info" for release builds, "debug" for debug builds.

       -v, --version
              Print the version of scrcpy.

       -w, --stay-awake
              Keep the device on while scrcpy is running, when the device is plugged in.

       --window-borderless
              Disable window decorations (display borderless window).

       --window-title text
              Set a custom window title.

       --window-x value
              Set the initial window horizontal position.

              Default is "auto".

       --window-y value
              Set the initial window vertical position.

              Default is "auto".

       --window-width value
              Set the initial window width.

              Default is 0 (automatic).

       --window-height value
              Set the initial window height.

              Default is 0 (automatic).

EXIT STATUS

       scrcpy will exit with code  0  on  normal  program  termination.  If  an  initial  connection  cannot  be
       established,  the exit code 1 will be returned. If the device disconnects while a session is active, exit
       code 2 will be returned.

SHORTCUTS

       In the following list, MOD is the shortcut modifier. By default, it's (left) Alt or (left) Super, but  it
       can be configured by --shortcut-mod (see above).

       MOD+f  Switch fullscreen mode

       MOD+Left
              Rotate display left

       MOD+Right
              Rotate display right

       MOD+g  Resize window to 1:1 (pixel-perfect)

       MOD+w, Double-click on black borders
              Resize window to remove black borders

       MOD+h, Home, Middle-click
              Click on HOME

       MOD+b, MOD+Backspace, Right-click (when screen is on)
              Click on BACK

       MOD+s  Click on APP_SWITCH

       MOD+m  Click on MENU

       MOD+Up Click on VOLUME_UP

       MOD+Down
              Click on VOLUME_DOWN

       MOD+p  Click on POWER (turn screen on/off)

       Right-click (when screen is off)
              Turn screen on

       MOD+o  Turn device screen off (keep mirroring)

       MOD+Shift+o
              Turn device screen on

       MOD+r  Rotate device screen

       MOD+n  Expand notification panel

       MOD+Shift+n
              Collapse notification panel

       Mod+c  Copy to clipboard (inject COPY keycode, Android >= 7 only)

       Mod+x  Cut to clipboard (inject CUT keycode, Android >= 7 only)

       MOD+v  Copy computer clipboard to device, then paste (inject PASTE keycode, Android >= 7 only)

       MOD+Shift+v
              Inject computer clipboard text as a sequence of key events

       MOD+i  Enable/disable FPS counter (print frames/second in logs)

       Ctrl+click-and-move
              Pinch-to-zoom from the center of the screen

       Drag & drop APK file
              Install APK from computer

       Drag & drop non-APK file
              Push file to device (see --push-target)

Environment variables

       ADB    Path to adb.

       ANDROID_SERIAL
              Device serial to use if no selector (-s, -d, -e or --tcpip=<addr>) is specified.

       SCRCPY_ICON_PATH
              Path to the program icon.

       SCRCPY_SERVER_PATH
              Path to the server binary.

AUTHORS

       scrcpy is written by Romain Vimont.

       This manual page was written by Yangfl for the Debian Project (and may be used by others).

REPORTING BUGS

       Report bugs to https://github.com/Genymobile/scrcpy/issues.

COPYRIGHT

       Copyright © 2018 Genymobile Genymobile

       Copyright © 2018-2022 Romain Vimont

       Licensed under the Apache License, Version 2.0.

WWW

       https://github.com/Genymobile/scrcpy

                                                                                                       scrcpy(1)