# QtScrcpy
[![Financial Contributors to Open Collective](https://opencollective.com/QtScrcpy/all/badge.svg?label=financial+contributors)](https://opencollective.com/QtScrcpy)
![Windows](https://github.com/barry-ran/QtScrcpy/workflows/Windows/badge.svg)
![MacOS](https://github.com/barry-ran/QtScrcpy/workflows/MacOS/badge.svg)
![Ubuntu](https://github.com/barry-ran/QtScrcpy/workflows/Ubuntu/badge.svg)
![license](https://img.shields.io/badge/license-Apache2.0-blue.svg)
![release](https://img.shields.io/github/v/release/barry-ran/QtScrcpy.svg)
[中文用户?点我查看中文介绍](README_zh.md)
QtScrcpy supports displaying and controlling Android devices via USB or over network. It does NOT require root privileges.
It supports three major platforms: GNU/Linux, Windows and macOS.
It focuses on:
- **lightness** (displays only the device screen)
- **performance** (30~60 fps)
- **quality** (1920×1080 or above)
- **low latency** ([35~70ms][lowlatency])
- **low startup time** (only about 1 second to display the first frame)
- **non-intrusiveness** (nothing will be installed on the device)
[lowlatency]: https://github.com/Genymobile/scrcpy/pull/646
![win](screenshot/win-en.png)
![mac](screenshot/mac-en.png)
![linux](screenshot/linux-en.png)
## Mapping Keys
You can write your script to map keyboard and mouse actions to touches and clicks of the mobile phone according to your needs. [Here](docs/KeyMapDes.md) are the script writing rules.
Script for TikTok and some other games are provided by default. Once enabled, you can play the game with your keyboard and mouse. The default key mapping for PUBG Mobile is as follows:
![game](screenshot/game.jpg)
[Here is a video demonstration playing PUBG Mobile.](http://mp.weixin.qq.com/mp/video?__biz=MzU1NTg5MjYyNw==&mid=100000015&sn=3e301fdc5a364bd16d6207fa674bc8b3&vid=wxv_968792362971430913)
Instruction for adding new customized mapping files.
- Write a customized script and put it in the `keymap` directory
- Click `refresh script` to show it
- Select your script
- Connect to your phone, start service and click `apply`
- Press `~` key (the SwitchKey in the key map script) to switch to custom mapping mode
- Press the ~ key again to switch back to normal mode
- (For games such as PUBG Mobile) If you want to move vehicles with the STEER_WHEEL keys, you need to set the move mode to `single rocker mode`.
## Group control
You can control all your phones at the same time.
![group-control-demo](docs/image/group-control.gif)
## Thanks
QtScrcpy is based on [Genymobile](https://github.com/Genymobile)'s [scrcpy](https://github.com/Genymobile/scrcpy) project. Thanks a lot!
The difference between QtScrcpy and the original scrcpy is as follows:
key points|scrcpy|QtScrcpy
--|:--:|:--:
ui|sdl|qt
video encode|ffmpeg|ffmpeg
video render|sdl|opengl
cross-platform|self implemented|provided by Qt
language|C|C++
style|sync|async
keymap|no custom keymap|support custom keymap
build|meson+gradle|qmake or CMake
- It's very easy to customize your GUI with Qt
- Asynchronous programming of Qt-based signal slot mechanism improves performance
- Easy to learn
- Add support for multi-touch
## Learn
If you are interested in it and want to learn how it works but do not know how to get started, you can choose to purchase my recorded video lessons.
It details the development architecture and the development process of the entire software and helps you develop QtScrcpy from scratch.
Course introduction:[https://blog.csdn.net/rankun1/article/details/87970523](https://blog.csdn.net/rankun1/article/details/87970523)
You can join my QQ group for QtScrcpy and exchange ideas with like-minded friends.:
QQ Group number:901736468
## Requirements
Android API >= 21 (Android 5.0).
Make sure you have enabled [ADB debugging][enable-adb] on your device(s).
[enable-adb]: https://developer.android.com/studio/command-line/adb.html#Enabling
## Download
[gitee-download]: https://gitee.com/Barryda/QtScrcpy/releases
[github-download]: https://github.com/barry-ran/QtScrcpy/releases
### Windows
On Windows, for simplicity, prebuilt archives with all the dependencies (including ADB) are available at Releases:
- [`QtScrcpy`][github-download]
or you can [build it yourself](#Build)
### Mac OS
On Mac OS, for simplicity, prebuilt archives with all the dependencies (including ADB) are available at Releases:
- [`QtScrcpy`][github-download]
or you can [build it yourself](#Build)
### Linux
For Arch Linux Users, you can use AUR to install: `yay -Syu qtscrcpy` (may be outdated; maintainer: [yochananmarqos](https://aur.archlinux.org/account/yochananmarqos))
For users in other distros, you can use the prebuilt archives from Releases:
- [`QtScrcpy`][github-download]
or you can get it at [GitHub Actions](https://github.com/UjhhgtgTeams/QtScrcpy/actions/workflows/ubuntu.yml), in branch `dev` and download the latest artifact.
or you can [build it yourself](#Build) (not recommended, get it in Actions if you can)
## Run
Connect to your Android device on your computer, then run the program and click `USB connect` or `WiFi connect`
### Wireless connection steps (ensure that the mobile phone and PC are on the same LAN):
1. Enable USB debugging in developer options on the Android device
2. Connect the Android device to the computer via USB
3. Click update device, and you will see that the device number is updated
4. Click get device IP
5. Click start adbd
6. Click wireless connect
7. Click update device again, and another device with an IP address will be found. Select this device.
8. Click start service
Note: it is not necessary to keep your Android device connected via USB after you start adbd.
## Interface button introduction:
- Start config: function parameter settings before starting the service
You can set the bit rate, resolution, recording format, and video save path of the locally recorded video.
- Background record: the Android device screen is not displayed after starting the service. It is recorded in the background.
- Always on top: the video window for Android devices will be kept on the top
- Close screen: automatically turn off the Android device screen to save power after starting the service
- Reverse connection: service startup mode. You can uncheck it if you experience connection failure with a message `more than one device`
- Refresh devices: Refresh the currently connected device
- Start service: connect to the Android device
- Stop service: disconnect from the Android device
- Stop all services: disconnect all connected Android devices
- Get device IP: Get the IP address of the Android device and update it to the "Wireless" area for the ease of wireless connection setting.
- Start adbd: Start the adbd service of the Android device. You must start it before the wireless connection.
- Wireless connect: Connect to Android devices wirelessly
- Wireless disconnect: Disconnect wirelessly connected Android devices
- adb command: execute customized ADB commands (blocking commands are not supported now, such as a shell)
## The main function
- Display Android device screens in real-time
- Real-time mouse and keyboard control of Android devices
- Screen recording
- Screenshot to png
- Wireless connection
- Supports multiple device connections
- Full-screen display
- Display on the top
- Install apk: drag and drop apk to the video window to install
- Transfer files: Drag files to the video window to send files to Android devices
- Background recording: record only, no display interface
- Copy-paste
It is possible to synchronize clipboards between the computer and the device, in
both directions:
- `Ctrl + c` copies the device clipboard to the computer clipboard;
- `Ctrl + Shift + v` copies the computer clipboard to the device clipboard;
- `Ctrl + v` _pastes_ the computer clipboard as a sequence of text events (non-ASCII characters does not yet work).
- Group control
- Syn
没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
QtScrcpy可以通过USB(或通过TCP/IP)连接Android设备,并进行显示和控制。不需要root权限。 单个应用程序最多支持16个安卓设备同时连接。同时支持GNU/Linux,Windows和MacOS三大主流桌面平台。 主要功能: 1、实时显示Android设备屏幕 2、实时键鼠控制Android设备 3、屏幕录制 4、截图为png 5、无线连接 6、最多支持16台设备连接(PC性能允许的情况下可以增加,需要自己编译) 7、全屏显示 8、窗口置顶 9、安装apk:拖拽apk到视频窗口即可安装 10、传输文件:拖拽文件到视频窗口即可发送文件到Android设备 11、后台录制:只录制,不显示界面 12、复制粘贴 在计算机和设备之间双向同步剪贴板: Ctrl + c将设备剪贴板复制到计算机剪贴板; Ctrl + Shift + v将计算机剪贴板复制到设备剪贴板; Ctrl +v 将计算机剪贴板作为一系列文本事件发送到设备(不支持非ASCII字符)。 13、群控 要求: Android部分至少需要API 21(Android 5.0)。
资源推荐
资源详情
资源评论
收起资源包目录
QtScrcpy v2.2.0 (180个子文件)
IRotationWatcher.aidl 801B
IOnPrimaryClipChangedListener.aidl 757B
sndcpy.apk 93KB
publish_for_win.bat 4KB
build_for_win.bat 3KB
sndcpy.bat 2KB
meson.build 1KB
.clang-format 8KB
videoform.cpp 23KB
dialog.cpp 22KB
config.cpp 12KB
groupcontroller.cpp 10KB
qyuvopenglwidget.cpp 9KB
main.cpp 6KB
magneticwidget.cpp 6KB
toolform.cpp 5KB
audiooutput.cpp 5KB
xmousetap.cpp 3KB
keepratiowidget.cpp 2KB
winutils.cpp 848B
winmousetap.cpp 646B
iconhelper.cpp 629B
mousetap.cpp 531B
psblack.css 15KB
group-control.gif 6.08MB
.gitignore 282B
.gitignore 88B
.gitmodules 115B
build.gradle 705B
videoform.h 3KB
dialog.h 2KB
groupcontroller.h 2KB
config.h 2KB
magneticwidget.h 2KB
qyuvopenglwidget.h 1KB
toolform.h 1KB
audiooutput.h 886B
iconhelper.h 787B
cocoamousetap.h 612B
keepratiowidget.h 571B
mousetap.h 425B
winmousetap.h 331B
xmousetap.h 319B
winutils.h 241B
path.h 79B
说明.htm 4KB
QtScrcpy.icns 188KB
QtScrcpy.ico 37KB
Info_Mac.plist.in 1KB
config.ini 980B
ControlMessageReaderTest.java 16KB
Server.java 14KB
Controller.java 12KB
Device.java 12KB
ScreenEncoder.java 12KB
ControlMessageReader.java 7KB
ContentProvider.java 7KB
CleanUp.java 6KB
ScreenInfo.java 6KB
KeyComposition.java 6KB
ControlMessage.java 5KB
ClipboardManager.java 5KB
SurfaceControl.java 5KB
Options.java 5KB
DesktopConnection.java 5KB
ServiceManager.java 4KB
WindowManager.java 4KB
CodecOptionsTest.java 4KB
Workarounds.java 4KB
ActivityManager.java 3KB
StatusBarManager.java 3KB
Settings.java 3KB
CodecOption.java 3KB
PointersState.java 3KB
Ln.java 2KB
InputManager.java 2KB
Position.java 2KB
DeviceMessageWriterTest.java 2KB
DisplayManager.java 1KB
DeviceMessageSender.java 1KB
DeviceMessageWriter.java 1KB
IO.java 1KB
PowerManager.java 1KB
StringUtilsTest.java 1KB
Command.java 1KB
Size.java 1KB
Pointer.java 1KB
DeviceMessage.java 972B
DisplayInfo.java 869B
Point.java 789B
StringUtils.java 679B
InvalidEncoderException.java 610B
InvalidDisplayIdException.java 572B
SettingsException.java 480B
显示指针位置.jpg 174KB
USB调试(安全设置).jpg 142KB
game.jpg 60KB
dmg-background.jpg 41KB
gameforpeace.json 5KB
identityv.json 4KB
共 180 条
- 1
- 2
资源评论
阿尔法星球
- 粉丝: 1514
- 资源: 240
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- Java字符串转换处理工具类
- windows USB 驱动,用于PL2303芯片上报GPS信息使用
- McFly 为 Bash 提供历史命令搜索功能 v0.9.2
- Package Control-12.22.sublime-package.zip
- Dragon book编译器龙书源码附详细注释
- 华为云开发者服务协议.pdf
- Hyper-YOLO保姆级教程(私以为的YOLOv12)
- Hyper-YOLO保姆级教程(私以为的YOLOv12)
- Java课程课后作业答案(1).zip
- IMG_20230412_094114.jpg
- asm-西电微机原理实验
- py-apple-quadruped-robot-四足机器人
- asm-西电微机原理实验
- asm-西电微机原理实验
- py-apple-bldc-quadruped-robot-四足机器人
- asm-西电微机原理实验
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功