π± Display and control your Android device with a Graphical Interface of Scrcpy powered by Electron. δΈζζζ‘£
- π Synchronous: Benefit from web technologies to synchronize with Scrcpy faster
- π€ Automation: Auto-connect devices, auto-execute images, custom scripts, scheduled tasks
- π‘ Customization: Multi-device management, independent configurations, custom notes, config import/export
- π‘ Wireless: Quick connect by scanning QR code
- π Reverse tethering: Gnirehtet reverse tethering
- π¨ Themes: Light mode, dark mode, system-based switching
- π Lightweight: Native support, only display device screen
- β‘οΈ Performance: 30-120 fps depending on device
- π Quality: 1920Γ1080 or higher
- π Low latency: 35~70 ms
- π Quick startup: Display first image in about 1 second
- π ββοΈ Non-intrusive: No installation residual left on Android device
- π€© User benefits: No account, no ads, no internet required
- π½ Free and open source
View release address
See homebrew-escrcpy
Note: If the phone prompts for debugging authorization, click allow
- Enable developer mode and USB debugging on your Android phone
- Open Escrcpy and connect your Android phone to your computer
- The device list in Escrcpy should have detected your phone, click start mirroring
- Enjoy!
- Follow steps 1-2 from USB connection
- Enable and enter wireless debugging in developer mode
- Click "Pair device using QR code"
- Start enjoying!
Note: If initial wireless connection fails, you may need wireless pairing. Please refer to FAQ
Note: You need to enable wireless debugging and obtain your device's wireless address (usually the IP address assigned when connecting to WiFi) and port number (default is 5555) from the wireless debugging page
- Follow steps 1-2 from USB connection
- Enter the obtained device IP address and port number in Escrcpy, then click connect device
- At this point, Escrcpy device list should detect your phone, click start mirroring
- Start enjoying!
Note: These platforms do not come with integrated Scrcpy, you need to install them manually
In Escrcpy@1.27.1+ scrcpy binary files are preliminarily integrated, eliminating the need for manual scrcpy installation.
- Refer to the installation document for Linux
- Refer to the installation document for macOS
- Follow steps in USB Connection and WIFI Connection after dependencies are installed successfully
Note: macOS does not have Gnirehtet built-in. You need to manually install it to use this feature Installation Guide.
Gnirehtet is built into the Windows and Linux apps to provide reverse tethering from PC to Android devices.
If you are a developer and would like to run or help improve this project please see the development documentation
Refer to scrcpy/doc/shortcuts
- Batch Interception Screen
- Batch Installation Application
- Batch File Management
- Batch Execution Script
- Batch Scheduled Task
- Mirror
- Recording
- Recording Camera
- Recording Audio
- Camera
- Custom
- OTG
- Switch
- Home
- Back
- Start APP (Mirror Group)
- Turn off screen (experimental)
- Notification
- Power
- Rotation
- Volume
- Screenshot
- Reboot
- Install APP
- File Manager
- Execution Script
- Scheduled Task
- Gnirehtet
Continuously improving. Currently supports the following common configurations
- Theme
- Language
- File storage path
- Adb path
- Scrcpy path
- Gnirehtet path
- Scrcpy parameters
- Auto-connect device
- Auto-execute mirroring
- Gnirehtet fix
- Debug
- Floating control bar
- Disable video forwarding
- Maximum size
- Video bitrate
- Refresh rate
- Video codec
- Display orientation
- Rotation angle
- Screen cropping
- Monitor
- Video buffer
- Receiver (v4l2) buffer
- Show touch points
- Keep awake
- Turn off screen during control
- Turn off screen after control
- Disable auto screen on during control
- Simulate auxiliary display
- Window width
- Window height
- Window X-coordinate
- Window Y-coordinate
- Borderless mode
- Fullscreen mode
- Always on top
- Disable screensaver
- Disable audio forwarding
- Keep device audio
- Audio source
- Audio codec
- Audio bitrate
- Audio buffer
- Audio output buffer
- Record video format
- Record video orientation
- Recording duration
- Disable video playback
- Disable audio playback
- Mouse mode
- Mouse binding
- Keyboard mode
- Keyboard injection method
- Gamepad
- Camera source
- Camera size
- Camera ratio
- Camera frame rate
Priority from high to low:
- Improved logo β
- Software update feature β
- Record and save audio/video β
- Device quick interaction control bar β
- Custom Adb and Scrcpy dependencies β
- Custom device names β
- Export and import preferences β
- Individual device configuration β
- macOS and Linux support β
- Internationalization β
- Dark mode β
- Reverse tethering (Gnirehtet) β
- Camera mirroring β
- Multi-screen collaboration β
- File push, screen rotation, audio control β
- Batch connect historical devices β
- Built-in terminal β
- Auto-execute mirroring β
- Flexible mirroring launch β
- Batch processing β
- Scheduled tasks β
- Graphical file manager β
- Floating control bar β
- Enhanced recording β
- Start APP(Multi-threaded) β
- Main window edge hidden β
- Group devices (by filtering remarks) β
- Improved history device connection experience β
- File management supports upload directory and progress display π§
- Game key mapping π§
- Please unplug and reconnect your device, and make sure the device has granted USB debugging authorization.
- If it still doesn't work, your computer may be missing necessary drivers. Please install drivers using third-party tools such as DriverWizard and try again.
In Scrcpy@2.4+ and above, the solution is as follows:
- Escrcpy Settings: Go to
Preferences
βInput Control
βKeyboard Mode
and selectuhid
mode. - Device Input Method Preparation: Install an input method that supports physical keyboards (WeChat Input Method is recommended) and complete the setup.
- Start Mirroring: Click
Start Mirroring
in Escrcpy. Verification: The deviceβsSettings
βSystem
βLanguage & Input
should display options forPhysical Keyboard
andOn-screen Keyboard
. - Device Input Settings: Enable WeChat Input Method in the
On-screen Keyboard
settings. Configure the keyboard layout in thePhysical Keyboard
settings to match the computer keyboard (only needs to be done once). - Computer Input Preparation: Set the input mode to English (important).
- Switch Input Language: Use
Ctrl
+Shift
to switch between English and Chinese. - Start Using.
The first wireless connection may require pairing. Alternatively, insert USB to ensure connection establishment and authorization success before using wireless.
Please click again, or click refresh devices. Generally it will not exceed two clicks. If still not working, please provide device model and Android version to Issues
It is important to note that, in principle, Escrcpy is just a GUI version based on Scrcpy, although it does extend some functionality. However, these extensions do not affect the core of Scrcpy. To implement this particular feature, I would have to modify the underlying Scrcpy code, which would make it more difficult for Escrcpy to stay in sync with Scrcpy's updates, and the drawbacks would outweigh the benefits.
Therefore, after careful consideration, we have decided to adopt the existing solution and look forward to Scrcpy adding native support for an interactive control bar in the future.
Note: For Xiaomi phones in particular, it requires not only enabling USB debugging but also enabling USB debugging (Security Settings), which is to allow modifying permissions or simulating clicks via USB debugging.
Please refer to the detailed instructions under Reasons why mouse and keyboard do not work
After feedback, Windows Defender may occasionally block the software packages from being downloaded due to lack of certificate signing. You can try the following solutions:
- Open
Windows Security Center
. - Select
Virus & threat protection
. - In the
Virus & threat protection settings
, clickManage settings
. - Find
Real-time protection
, you can try clicking Disable if permission allows. If unable to disable real-time protection, please skip this step. - Scroll down the page, find
Exclusions
, clickAdd or remove exclusions
. - Add the folder path where you download the software packages as an exclusion item, i.e. add the folder to the
Excluded list
.
This is generally caused by an incorrect path for
Adb
orScrcpy
, you can try the following solutions:
- In the menu, select
Preferences
and then click the reset configuration button in the top right corner ofGlobal Mode
. - Go to the
Device List
page and try enabling mirroring again. - Make sure you have downloaded and installed the latest version of
Escrcpy
. - Press
Ctrl
+Shift
+I
to open the developer tools and check for any error messages. - If there are errors, take a screenshot and submit your issue with the screenshot on the Feedback Issues page.
This is generally caused by too many icons in the system tray overflowing and hiding the Escrcpy icon. Try using the following tools:
After a successful installation of macOS, when I try to open it, I receive a prompt saying the file is damaged.
This is usually due to the software package not being signed. You can try the following solutions:
- Open Terminal and execute
sudo spctl --master-disable
to allow software from any source. - Open Terminal and execute
sudo xattr -r -d com.apple.quarantine /Applications/Escrcpy.app
to attempt fixing the damaged software package prompt.
Only support Windows 10
and above versions.
This usually happens because your computer lacks audio output or you have a low Android version (Android 11+).
Please try disabling audio forwarding
feature through the preferences settings
to resolve this issue.
This is caused by files in the installation directory lacking executable permissions.
You need to customize the file paths for scrcpy
and adb
(ensuring they have executable permissions). If using reverse tethering, configure gnirehtet
similarly.
This might be due to Chinese or special characters in the installation path. Please try changing the installation path.
New restrictions have been implemented for AppImage applications in some popular distributions, such as Ubuntu 24.04, limiting the use of sandboxes. A temporary workaround is as follows:
sudo chmod 4755 /opt/Escrcpy/chrome-sandbox
As this is an open source project run entirely by donations, support is limited and updates may not be on a fixed schedule.
- Issues: Submit Feedback
- Email: viarotel@qq.com
This project would not be possible without the following open source projects:
If this project has helped you, you can buy me a coffee to keep me energized and improving the project! π
Thanks for all their contributions!