📱 Graphical Scrcpy to display and control Android, devices powered by Electron. | 使用图形化的 Scrcpy 显示和控制您的 Android 设备,由 Electron 驱动。
Go to file
2023-11-26 22:23:38 +08:00
.github/workflows ci: 💚 Update workflows 2023-11-20 09:11:08 +08:00
.husky Update 2023-10-31 23:28:01 +08:00
.vscode refactor: ♻️ Optimize directory structure 2023-11-03 14:48:54 +08:00
copilot perf: ️ Add webSocket 2023-11-22 09:56:18 +08:00
electron style: 🚧 Disabled copilot 2023-11-26 19:48:34 +08:00
public fix: 🐛 修复 macOS 最小化到托盘后状态栏图标不显示的问题 2023-10-24 11:08:27 +08:00
screenshots docs: Update README 2023-10-30 17:12:28 +08:00
src perf: Update to scrcpy v2.3 2023-11-26 19:44:01 +08:00
.eslintignore fix: 🐛 修复 macOS 或 linux 下自定义依赖选项描述错误的问题 2023-10-21 13:58:42 +08:00
.eslintrc.js perf: ♻️ optimize Codec 2023-11-02 15:08:19 +08:00
.gitignore perf: 🚀 Add volume control 2023-11-08 17:28:05 +08:00
.npmrc fix: 🐛 linux build error 2023-11-26 21:06:53 +08:00
.yarnrc feat: 📝 添加基本的有线连接支持 2023-09-15 19:32:13 +08:00
CHANGELOG.md chore(main): release 1.16.1 2023-11-26 21:07:30 +08:00
dev-publish.yml refactor: 🚀 对目录结构和代码逻辑进行重构 2023-10-16 11:53:08 +08:00
electron-builder.json build: Add appx build 2023-11-14 15:22:26 +08:00
index.html perf: 🍻 Update base copilot 2023-11-21 16:37:02 +08:00
jsconfig.json perf: 🍻 Update base copilot 2023-11-21 16:37:02 +08:00
LICENSE docs: 📝 Update LICENSE 2023-11-14 17:24:46 +08:00
package.json build: ⬆️ Update deps 2023-11-26 22:23:38 +08:00
postcss.config.mjs feat: 🎉 Add Terminal Debugging 2023-11-13 18:35:44 +08:00
README-CN.md docs: 📝 Update README 2023-11-18 11:27:44 +08:00
README.md docs: 📝 Update README 2023-11-18 11:27:44 +08:00
unocss.config.js feat: 📝 添加基本的有线连接支持 2023-09-15 19:32:13 +08:00
vite.config.js perf: 🍻 Update base copilot 2023-11-21 16:37:02 +08:00

viarotel-escrcpy

Escrcpy

📱 Display and control your Android device with a graphical interface of Scrcpy powered by Electron. 中文文档

viarotel-escrcpy

More screenshots

Features

  • 🏃 Synchronous: Benefit from web technologies to synchronize with Scrcpy faster
  • 💡 Customizable: Support independent configuration for multiple devices and ability to add notes and import/export all configurations
  • 🎨 Theme: Supports light mode and dark mode, system-wide switching
  • 🔗 Gnirehtet: Integrated Gnirehtet's reverse tethering functionality
  • 😎 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

Get Software Packages

Check release addresses

Quick Start

USB Connection

Note: If the phone prompts for debugging authorization, click allow

  1. Enable developer mode and USB debugging on your Android phone
  2. Open Escrcpy and connect your Android phone to your computer
  3. The device list in Escrcpy should have detected your phone, click start mirroring
  4. Enjoy!

WIFI Connection

Note: Wireless debugging needs to be enabled on your phone's wireless debugging page to get the IP address (usually the IP assigned when connecting to WIFI) and port number (default 5555) of the device

  1. Follow steps 1-2 in USB Connection
  2. Input the device IP address and port number obtained to Escrcpy and click connect device
  3. The device list in Escrcpy should have detected your phone, click start mirroring
  4. Enjoy!

macOS && Linux

Note: These platforms do not come with integrated Adb and Scrcpy, you need to install them manually

  1. Refer to the installation document for Linux
  2. Refer to the installation document for macOS
  3. Follow steps in USB Connection and WIFI Connection after dependencies are installed successfully

Gnirehtet Reverse Tethering

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.

Shortcuts

Refer to scrcpy/doc/shortcuts

Device Interaction Bar

  • Switch
  • Home
  • Back
  • Notification
  • Power
  • Restart
  • Screenshot
  • Install APP
  • Gnirehtet

Preferences

Continuously improving. Currently supports the following common configurations

General

  • Adb path
  • Scrcpy path
  • File storage path (audio and video recordings and device screenshots are all saved here)
  • Gnirehtet path
  • Gnirehtet fix
  • Scrcpy append parameter
  • Change theme
  • Adjust language
  • Enable debug

Video

  • Resolution
  • Bitrate
  • Refresh rate
  • Video encoding
  • Screen rotation
  • Screen cropping
  • Display
  • Video buffer
  • Receiver (v4l2) buffer

Device

  • Show touch points
  • Keep awake
  • Close screen during control
  • Close screen after control
  • Stop charging during control

Window

  • Borderless mode
  • Fullscreen mode
  • Always on top
  • Disable screen saver

Recording

  • Recording format
  • Recording duration
  • Recording video orientation
  • Disable video recording
  • Disable video playback
  • Disable audio recording
  • Disable audio playback

Audio

  • Audio source
  • Audio encoding
  • Audio bitrate
  • Audio buffer
  • Audio output buffer

OTG

  • Enable OTG
  • Keyboard only
  • Mouse only

Camera

  • Enable camera
  • Camera source
  • Camera size
  • Camera ratio
  • Camera frame rate

Next Steps?

Priority from high to low:

  1. Optimize user interface, design a suitable logo
  2. Built-in software update function
  3. Record and save audio/video
  4. Add device quick interaction control bar
  5. Support customization of Adb and Scrcpy dependencies
  6. Support custom device name, and import/export of preference settings
  7. Customization, support independent configuration for individual devices
  8. Add support for macOS and linux operating systems
  9. Support internationalization
  10. Support for dark mode
  11. Add Gnirehtet reverse network function
  12. Add new camera mirror related features
  13. Better multi -screen collaboration
  14. Add more features to device interaction bar: file push, screen rotation, audio control etc
  15. Support bulk connecting to historical devices
  16. Support to use built-in terminals to execute custom commands
  17. Add standalone clipboard sync feature 🚧
  18. Support GUI-based selective file downloads from devices 🚧
  19. Support grouping devices and bulk operations by group 🚧
  20. Add game enhancement features such as game keyboard mapping 🚧

FAQ

Computer cannot detect device after connecting

  1. Please unplug and reconnect your device, and make sure the device has granted USB debugging authorization.
  2. 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.

Unable to enter Chinese

This issue is known - Scrcpy doesn't seem to have tested and supported direct Chinese input. It's recommended to install a third-party input method on the phone that can well support, such as:

  • Sogou Input
  • QQ Input
  • Google Pinyin Input
  • Gboard

Wireless connection prompts: The target computer actively refuses access

The first wireless connection may require pairing. Alternatively, insert USB to ensure connection establishment and authorization success before using wireless.

Clicking wireless mode after connecting via data cable has no response

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

Why is the device interaction control bar not designed as an automatically sticking floating menu?

Adopting the floating menu approach will inevitably increase coupling with Scrcpy and difficulty in synchronization updates. Many similar ScrcpyGUI softwares had to invest a lot of effort in this approach and eventually gave up development due to update difficulties. Therefore, taking overall considerations, we decided to adopt the existing approach and look forward to Scrcpy's native support for an interaction control bar in the future.

Some devices can see screenshots after connecting but cannot operate

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

Downloading prompts antivirus detection causing unable to download normally

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:

  1. Open Windows Security Center.
  2. Select Virus & threat protection.
  3. In the Virus & threat protection settings, click Manage settings.
  4. Find Real-time protection, you can try clicking Disable if permission allows. If unable to disable real-time protection, please skip this step.
  5. Scroll down the page, find Exclusions, click Add or remove exclusions.
  6. Add the folder path where you download the software packages as an exclusion item, i.e. add the folder to the Excluded list.

Failed to get device list or error when starting mirroring/recording

This is generally caused by an incorrect path for Adb or Scrcpy, you can try the following solutions:

  1. In the menu, select Preferences and then click the reset configuration button in the top right corner of Global Mode.
  2. Go to the Device List page and try enabling mirroring again.
  3. Make sure you have downloaded and installed the latest version of Escrcpy.
  4. Press Ctrl + Shift + I to open the developer tools and check for any error messages.
  5. If there are errors, take a screenshot and submit your issue with the screenshot on the Feedback Issues page.

macOS window minimized to system tray icon not found

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:

  1. Open Terminal and execute sudo spctl --master-disable to allow software from any source.
  2. Open Terminal and execute sudo xattr -r -d com.apple.quarantine [AppPath] to attempt fixing the damaged software package prompt.

Getting Help

As this is an open source project run entirely by donations, support is limited and updates may not be on a fixed schedule.

Acknowledgements

This project would not be possible without the following open source projects:

Support the Project

If this project has helped you, you can buy me a coffee to keep me energized and improving the project! 😛

viarotel-wepay viarotel-alipay