docs: set en readme default

This commit is contained in:
rankun 2019-11-11 16:40:45 +08:00
parent e6ab785c26
commit f7eb231d38
3 changed files with 325 additions and 324 deletions

234
README.md
View file

@ -1,16 +1,16 @@
# QtScrcpy
# QtScrcpy
![build state](https://img.shields.io/badge/build-passing-brightgreen.svg)
![license](https://img.shields.io/badge/license-Apache2.0-blue.svg)
![release](https://img.shields.io/badge/release-v1.0.1-brightgreen.svg)
[English introduction (from Google Translate)](README_EN.md)
[中文介绍](README_zh.md)
QtScrcpy可以通过USB(或通过TCP/IP)连接Android设备并进行显示和控制。不需要root权限。
QtScrcpy can connect to Android devices via USB (or via TCP/IP) for display and control. No root privileges are required.
单个应用程序最多支持16个安卓设备同时连接。
A single application can support up to 16 Android devices to connect at the same time.
同时支持GNU/LinuxWindows和MacOS三大主流桌面平台
Supports three major desktop platforms, GNU/Linux, Windows and MacOS.
![win](screenshot/win.png)
@ -18,178 +18,170 @@ QtScrcpy可以通过USB(或通过TCP/IP)连接Android设备并进行显示和
![linux](screenshot/ubuntu.png)
## 自定义按键映射仅windows平台开启
可以根据需要自己编写脚本将PC键盘按键映射为手机的触摸点击编写规则在[这里](docs/按键映射说明.md)。
## Custom keymaponly windows enable
You can write your own script to map the PC keyboard keys to the touch and click of the mobile phone according to your needs. [Here](docs/按键映射说明.md) are the rules.
默认自带了针对和平精英手游进行键鼠映射的映射脚本,开启后可以用键鼠像玩端游一样玩和平精英手游,你也可以按照[编写规则](docs/按键映射说明.md)编写其他游戏的映射文件,默认按键映射如下:
By default, it has its own mapping script for key and mouse mapping of "Game for peace" mobile games. When enabled, you can use key and mouse to play "Game for peace" mobile games like PC games. You can also write mapping files of other games according to [writing rules](docs/按键映射说明.md). The default key mapping is as follows:
![game](screenshot/game.jpg)
[这里有玩和平精英的视频演示](http://mp.weixin.qq.com/mp/video?__biz=MzU1NTg5MjYyNw==&mid=100000015&sn=3e301fdc5a364bd16d6207fa674bc8b3&vid=wxv_968792362971430913&idx=1&vidsn=eec329cc13c3e24c187dc9b4d5eb8760&fromid=1&scene=20&xtrack=1&clicktime=1567346543&sessionid=1567346375&subscene=92&ascene=0&fasttmpl_type=0&fasttmpl_fullversion=4730859-zh_CN-zip&fasttmpl_flag=0&realreporttime=1567346543910#wechat_redirect)
[Here is a video demonstration of playing "Game for peace"](http://mp.weixin.qq.com/mp/video?__biz=MzU1NTg5MjYyNw==&mid=100000015&sn=3e301fdc5a364bd16d6207fa674bc8b3&vid=wxv_968792362971430913&idx=1&vidsn=eec329cc13c3e24c187dc9b4d5eb8760&fromid=1&scene=20&xtrack=1&clicktime=1567346543&sessionid=1567346375&subscene=92&ascene=0&fasttmpl_type=0&fasttmpl_fullversion=4730859-zh_CN-zip&fasttmpl_flag=0&realreporttime=1567346543910#wechat_redirect)
自定义按键映射操作方法如下
- 编写自定义脚本放入keymap目录
- 启动服务之前记得勾选自定义映射选项,并选择自定义映射脚本
- 连接手机以后进入游戏场景
- 按~键数字键1左边切换为游戏映射模式即可体验具体按什么键要看你按键脚本定义的switchKey
- 再次按~键切换为正常控制模式
- 要想wasd控制开车记得在载具设置中设置为单摇杆模式
The operation method of custom key mapping is as follows
- Write a custom script and put it in the keymap directory
- Check the custom mapping option and select the custom mapping script before starting the service
- Enter the game scene after connecting the mobile phone
- Press the ~ key (left side of the number key 1) to switch to the game mapping mode to experience (what key to press depends on the switchkey defined by your key script)
- Press the ~ key again to switch to normal control mode
- To start the WASD control car, remember to set it to single rocker mode in vehicle settings.
## 感谢
## Thanks
基于[Genymobile](https://github.com/Genymobile)的[scrcpy](https://github.com/Genymobile/scrcpy)项目进行复刻重构非常感谢他。QtScrcpy和原版scrcpy区别如下
QtScrcpy is based on [Genymobile's](https://github.com/Genymobile) [scrcpy](https://github.com/Genymobile/scrcpy) project and is very grateful to him.
关键点|scrcpy|QtScrcpy
The difference between QtScrcpy and the original scrcpy is as follows:
keys|scrcpy|QtScrcpy
--|:--:|:--:
界面|sdl|qt
视频解码|ffmpeg|ffmpeg
视频渲染|sdl|opengl
跨平台基础设施|自己封装|Qt提供
编程语言|C|C++
编程方式|同步|异步
控制方式|单点触控|单点/多点触控
编译方式|meson+gradle|Qt Creator
ui|sdl|qt
video decode|ffmpeg|ffmpeg
video render|sdl|opengl
base tool|c++|Qt
language|C|C++
style|sync|asyn
build|meson+gradle|Qt Creator
- 使用Qt可以非常容易的定制自己的界面
- 基于Qt的信号槽机制的异步编程提高性能
- 方便新手学习
- 增加多点触控支持
- It's very easy to customize your interface with Qt
- Asynchronous programming of Qt-based signal slot mechanism improves performance
- Easy for novices to learn
- Add multi touch support
## 学习它
如果你对它感兴趣,想学习它的实现原理而又感觉无从下手,可以选择购买我录制的视频课程,
里面详细介绍了整个软件的开发架构以及开发流程带你从无到有的开发QtScrcpy
## Learn
课程介绍:[https://blog.csdn.net/rankun1/article/details/87970523](https://blog.csdn.net/rankun1/article/details/87970523)
If you are interested in it and want to learn how it works and feel that you can't get started, you can choose to purchase my recorded video lessons.
It details the development architecture and development process of the entire software, and takes you to develop QtScrcpy from scratch.
或者你也可以加入我的QtScrcpy QQ群和志同道合的朋友一块互相交流技术
course introduction[https://blog.csdn.net/rankun1/article/details/87970523](https://blog.csdn.net/rankun1/article/details/87970523)
QQ群号901736468
Or you can join my QtScrcpy qq group and exchange ideas with like-minded friends.
QQ Group number901736468
## 要求
Android部分至少需要API 21Android 5.0)。
## Requirements
The Android part requires at least API 21 (Android 5.0).
您要确保在Android设备上[启用adb调试][enable-adb]。
Make sure you 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
For Windows, for simplicity, prebuilt archives with all the dependencies (including adb) are available:
windows平台你可以直接使用我编译好的可执行程序:
- [`QtScrcpy`][github-download]
- [国内下载][gitee-download]
- [国外下载][github-download]
你也可以[自己编译](#如何编译)
or you can [build it by yourself](#Build)
### Mac OS
For Mac OS, for simplicity, prebuilt archives with all the dependencies (including adb) are available:
Mac OS平台你可以直接使用我编译好的可执行程序:
- [`QtScrcpy`][github-download]
- [国内下载][gitee-download]
- [国外下载][github-download]
你也可以[自己编译](#如何编译)
or you can [build it by yourself](#Build)
### Linux
you can [build it by yourself](#Build)(just ubuntu test)
目前只提供了windows和mac平台的可执行程序如果需要linux平台的可执行程序
您通常需要[自己编译](#如何编译)。别担心,这并不难。
## Run
目前只在ubuntu上测试过
Connect to your Android device on your computer, then run the program and click the button below to connect to the Android device.
## 运行
![run](screenshot/run.png)
在你的电脑上接入Android设备然后运行程序按顺序点击如下按钮即可连接到Android设备
### Wireless connection steps (ensure that the mobile phone and computer are in the same LAN):
1. Enable USB debugging in developer options on Android mobile terminal
2. Connect Android phone to computer via USB
3. Click update device, and you will see that the device number is updated.
4. Click get ip
5. Click start adbd
6. Click wireless connect
7. Click update device again, and another device with IP address beginning is found. Select this device.
8. Click start service
![运行](screenshot/run.png)
## Interface button introduction
### 无线连接步骤(保证手机和电脑在同一个局域网):
1. 安卓手机端在开发者选项中打开usb调试
2. 通过usb连接安卓手机到电脑
3. 点击刷新设备,会看到有设备号更新出来
4. 点击获取设备ip
5. 点击启动adbd
6. 无线连接
7. 再次点击刷新设备发现多出了一个ip地址开头的设备选择这个设备
8. 启动服务
- Startup configuration: function parameter settings before starting the service
备注启动adbd以后不用再usb线了以后连接断开都不再需要除非安卓adbd停了需要重新启动
You can set the bit rate, resolution, recording format, and video save path of the local recorded video.
## 界面按钮介绍:
- 启动配置:启动服务前的功能参数设置
分别可以设置本地录制视频的比特率、分辨率、录制格式、录像保存路径等。
- 仅后台录制启动服务不现实界面只是录制Android设备屏幕
- 窗口置顶Android设备视频窗口置顶显示
- 自动息屏启动服务以后自动关闭Android设备屏幕节省电量
- 使用reverse服务启动模式出现服务启动失败报错more than one device可以去掉这个勾选尝试连接
- Recording only in the background: Starting the service is not realistic, just recording the Android device screen
- Window Top: Android device video window top display
- Close screen: automatically turn off the Android device screen to save power after starting the service
- Use reverse: service startup mode, service startup failure error more than one device can remove this check to try to connect
- 刷新设备列表:刷新当前连接的设备
- 启动服务连接到Android设备
- 停止服务断开与Android设备的连接
- 停止所有服务断开所有已连接的Android设备
- 获取设备ip获取到Android设备的ip地址更新到“无线”区域中方便进行无线连接
- 启动adbd启动Android设备的adbd服务无线连接之前必须要启动。
- 无线连接使用无线方式连接Android设备
- 无线断开断开无线方式连接的Android设备
- adb命令行方便执行自定义adb命令目前不支持阻塞命令例如shell
- Refresh device list: Refresh the currently connected device
- Start the service: connect to the Android device
- Stop service: disconnect from 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 easy wireless connection.
- Start adbd: Start the adbd service of the Android device, you must start it before the wireless connection.
- Wireless connection: Connect to Android devices wirelessly
- Wireless disconnect: Disconnect wirelessly connected Android devices
- adb command line: convenient to execute custom adb commands (currently does not support blocking commands, such as shell)
## 主要功能
- 实时显示Android设备屏幕
- 实时键鼠控制Android设备
- 屏幕录制
- 无线连接
- 最多支持16台设备连接PC性能允许的情况下可以增加需要自己编译
- 全屏显示
- 窗口置顶
- 安装apk拖拽apk到视频窗口即可安装
- 传输文件拖拽文件到视频窗口即可发送文件到Android设备
- 后台录制:只录制,不显示界面
## The main function
- Display Android device screens in real time
Real-time mouse and keyboard control Android device
- Screen recording
- Wireless connections
- Supports up to 16 device connections (can be added if PC performance allows, you need to compile it yourself)
- full-screen display
- Window topping
- 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
## TODO
[后期计划](docs/TODO.md)
[TODO](docs/TODO.md)
## FAQ
[常见问题说明](docs/FAQ.md)
[FAQ](docs/FAQ.md)
## 为什么开发QtScrcpy
综合起来有以下几个原因,比重从大到小排列:
1. 学习Qt的过程中需要一个项目实战一下
2. 本身具有音视频相关技能,对音视频很感兴趣
3. 本身具有Android开发技能好久没用有点生疏需要巩固一下
4. 发现了scrcpy决定用新的技术栈C++ + Qt + Opengl + ffmpeg复刻一下
## Why develop QtScrcpy?
There are several reasons for this, and the proportions are arranged from large to small:
1. In the process of learning Qt, you need a project to combat
2. It has audio and video related skills and is very interested in audio and video.
3. It has Android development skills, its a bit rusty for a long time, you need to consolidate it.
4. Found scrcpy, decided to re-entamrate with the new technology stack (C++ + Qt + Opengl + ffmpeg)
## 如何编译
尽量提供了所有依赖资源,方便傻瓜式编译。
## Build
Try to provide all the dependencies and make it easy to compile.
### PC
1. 目标平台上搭建Qt开发环境(Qt >= 5.9.7, vs >= 2015 (不支持mingw))
2. 克隆该项目
3. 使用QtCreator打开项目根目录all.pro
4. 编译,运行即可
### PC client
1. Set up the Qt development environment on the target platform (Qt >= 5.9.7, vs >= 2015 (not support mingw))
2. Clone the project
3. Open the project root directory all.pro with QtCreator
4. Compile and run
### Android没有修改需求的话直接使用自带的scrcpy-server.jar即可
1. 目标平台上搭建Android开发环境
2. 使用Android Studio打开项目根目录中的server项目
3. 编辑即可
4. 编译出apk以后改名为scrcpy-server.jar并替换third_party/scrcpy-server.jar即可
### Android (If you do not need to modify the requirements, you can use the built-in scrcpy-server.jar directly)
1. Set up an Android development environment on the target platform
2. Open the server project in the project root directory using Android Studio
3. Build it
4. After compiling apk, rename it to scrcpy-server.jar and replace third_party/scrcpy-server.jar.
## Licence
由于是复刻的scrcpy尊重它的Licence
Since it is based on scrcpy, respect its Licence
Copyright (C) 2018 Genymobile
@ -205,8 +197,8 @@ Mac OS平台你可以直接使用我编译好的可执行程序:
See the License for the specific language governing permissions and
limitations under the License.
## 关于作者
## About the author
[BarryCSDN](https://blog.csdn.net/rankun1)
[Barry CSDN](https://blog.csdn.net/rankun1)
一枚普通的程序员工作中主要使用C++进行桌面客户端开发一毕业在山东做过一年多钢铁仿真教育软件后来转战上海先后从事安防在线教育相关领域工作对音视频比较熟悉对音视频领域如语音通话直播教育视频会议等相关解决方案有所了解。同时具有androidlinux服务器等开发经验。
An ordinary programmer, working mainly in C++ for desktop client development, graduated from Shandong for more than a year of steel simulation education software, and later moved to Shanghai to work in security, online education related fields, familiar with audio and video. I have an understanding of audio and video fields such as voice calls, live education, video conferencing and other related solutions. At the same time have android, linux server and other development experience.

View file

@ -1,203 +0,0 @@
# QtScrcpy
![build state](https://img.shields.io/badge/build-passing-brightgreen.svg)
![license](https://img.shields.io/badge/license-Apache2.0-blue.svg)
![release](https://img.shields.io/badge/release-v1.0.1-brightgreen.svg)
QtScrcpy can connect to Android devices via USB (or via TCP/IP) for display and control. No root privileges are required.
A single application can support up to 16 Android devices to connect at the same time.
Supports three major desktop platforms, GNU/Linux, Windows and MacOS.
![win](screenshot/win.png)
![mac](screenshot/mac.jpg)
![linux](screenshot/ubuntu.png)
## Custom keymaponly windows enable
You can write your own script to map the PC keyboard keys to the touch and click of the mobile phone according to your needs. [Here](docs/按键映射说明.md) are the rules.
By default, it has its own mapping script for key and mouse mapping of "Game for peace" mobile games. When enabled, you can use key and mouse to play "Game for peace" mobile games like PC games. You can also write mapping files of other games according to [writing rules](docs/按键映射说明.md). The default key mapping is as follows:
![game](screenshot/game.jpg)
[Here is a video demonstration of playing "Game for peace"](http://mp.weixin.qq.com/mp/video?__biz=MzU1NTg5MjYyNw==&mid=100000015&sn=3e301fdc5a364bd16d6207fa674bc8b3&vid=wxv_968792362971430913&idx=1&vidsn=eec329cc13c3e24c187dc9b4d5eb8760&fromid=1&scene=20&xtrack=1&clicktime=1567346543&sessionid=1567346375&subscene=92&ascene=0&fasttmpl_type=0&fasttmpl_fullversion=4730859-zh_CN-zip&fasttmpl_flag=0&realreporttime=1567346543910#wechat_redirect)
The operation method of custom key mapping is as follows
- Write a custom script and put it in the keymap directory
- Check the custom mapping option and select the custom mapping script before starting the service
- Enter the game scene after connecting the mobile phone
- Press the ~ key (left side of the number key 1) to switch to the game mapping mode to experience (what key to press depends on the switchkey defined by your key script)
- Press the ~ key again to switch to normal control mode
- To start the WASD control car, remember to set it to single rocker mode in vehicle settings.
## Thanks
QtScrcpy is based on [Genymobile's](https://github.com/Genymobile) [scrcpy](https://github.com/Genymobile/scrcpy) project and is very grateful to him.
The difference between QtScrcpy and the original scrcpy is as follows:
keys|scrcpy|QtScrcpy
--|:--:|:--:
ui|sdl|qt
video decode|ffmpeg|ffmpeg
video render|sdl|opengl
base tool|c++|Qt
language|C|C++
style|sync|asyn
build|meson+gradle|Qt Creator
- It's very easy to customize your interface with Qt
- Asynchronous programming of Qt-based signal slot mechanism improves performance
- Easy for novices to learn
- Add multi touch support
## Learn
If you are interested in it and want to learn how it works and feel that you can't get started, you can choose to purchase my recorded video lessons.
It details the development architecture and development process of the entire software, and takes you to develop QtScrcpy from scratch.
course introduction[https://blog.csdn.net/rankun1/article/details/87970523](https://blog.csdn.net/rankun1/article/details/87970523)
Or you can join my QtScrcpy qq group and exchange ideas with like-minded friends.
QQ Group number901736468
## Requirements
The Android part requires at least API 21 (Android 5.0).
Make sure you 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
For Windows, for simplicity, prebuilt archives with all the dependencies (including adb) are available:
- [`QtScrcpy`][github-download]
or you can [build it by yourself](#Build)
### Mac OS
For Mac OS, for simplicity, prebuilt archives with all the dependencies (including adb) are available:
- [`QtScrcpy`][github-download]
or you can [build it by yourself](#Build)
### Linux
you can [build it by yourself](#Build)(just ubuntu test)
## Run
Connect to your Android device on your computer, then run the program and click the button below to connect to the Android device.
![run](screenshot/run.png)
### Wireless connection steps (ensure that the mobile phone and computer are in the same LAN):
1. Enable USB debugging in developer options on Android mobile terminal
2. Connect Android phone to computer via USB
3. Click update device, and you will see that the device number is updated.
4. Click get ip
5. Click start adbd
6. Click wireless connect
7. Click update device again, and another device with IP address beginning is found. Select this device.
8. Click start service
## Interface button introduction
- Startup configuration: function parameter settings before starting the service
You can set the bit rate, resolution, recording format, and video save path of the local recorded video.
- Recording only in the background: Starting the service is not realistic, just recording the Android device screen
- Window Top: Android device video window top display
- Close screen: automatically turn off the Android device screen to save power after starting the service
- Use reverse: service startup mode, service startup failure error more than one device can remove this check to try to connect
- Refresh device list: Refresh the currently connected device
- Start the service: connect to the Android device
- Stop service: disconnect from 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 easy wireless connection.
- Start adbd: Start the adbd service of the Android device, you must start it before the wireless connection.
- Wireless connection: Connect to Android devices wirelessly
- Wireless disconnect: Disconnect wirelessly connected Android devices
- adb command line: convenient to execute custom adb commands (currently does not support blocking commands, such as shell)
## The main function
- Display Android device screens in real time
Real-time mouse and keyboard control Android device
- Screen recording
- Wireless connections
- Supports up to 16 device connections (can be added if PC performance allows, you need to compile it yourself)
- full-screen display
- Window topping
- 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
## TODO
[TODO](docs/TODO.md)
## FAQ
[FAQ](docs/FAQ.md)
## Why develop QtScrcpy?
There are several reasons for this, and the proportions are arranged from large to small:
1. In the process of learning Qt, you need a project to combat
2. It has audio and video related skills and is very interested in audio and video.
3. It has Android development skills, its a bit rusty for a long time, you need to consolidate it.
4. Found scrcpy, decided to re-entamrate with the new technology stack (C++ + Qt + Opengl + ffmpeg)
## Build
Try to provide all the dependencies and make it easy to compile.
### PC client
1. Set up the Qt development environment on the target platform (Qt >= 5.9.7, vs >= 2015 (not support mingw))
2. Clone the project
3. Open the project root directory all.pro with QtCreator
4. Compile and run
### Android (If you do not need to modify the requirements, you can use the built-in scrcpy-server.jar directly)
1. Set up an Android development environment on the target platform
2. Open the server project in the project root directory using Android Studio
3. Build it
4. After compiling apk, rename it to scrcpy-server.jar and replace third_party/scrcpy-server.jar.
## Licence
Since it is based on scrcpy, respect its Licence
Copyright (C) 2018 Genymobile
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
## About the author
[Barry CSDN](https://blog.csdn.net/rankun1)
An ordinary programmer, working mainly in C++ for desktop client development, graduated from Shandong for more than a year of steel simulation education software, and later moved to Shanghai to work in security, online education related fields, familiar with audio and video. I have an understanding of audio and video fields such as voice calls, live education, video conferencing and other related solutions. At the same time have android, linux server and other development experience.

212
README_zh.md Normal file
View file

@ -0,0 +1,212 @@
# QtScrcpy
![build state](https://img.shields.io/badge/build-passing-brightgreen.svg)
![license](https://img.shields.io/badge/license-Apache2.0-blue.svg)
![release](https://img.shields.io/badge/release-v1.0.1-brightgreen.svg)
[English introduction (from Google Translate)](README.md)
QtScrcpy可以通过USB(或通过TCP/IP)连接Android设备并进行显示和控制。不需要root权限。
单个应用程序最多支持16个安卓设备同时连接。
同时支持GNU/LinuxWindows和MacOS三大主流桌面平台
![win](screenshot/win.png)
![mac](screenshot/mac.jpg)
![linux](screenshot/ubuntu.png)
## 自定义按键映射仅windows平台开启
可以根据需要自己编写脚本将PC键盘按键映射为手机的触摸点击编写规则在[这里](docs/按键映射说明.md)。
默认自带了针对和平精英手游进行键鼠映射的映射脚本,开启后可以用键鼠像玩端游一样玩和平精英手游,你也可以按照[编写规则](docs/按键映射说明.md)编写其他游戏的映射文件,默认按键映射如下:
![game](screenshot/game.jpg)
[这里有玩和平精英的视频演示](http://mp.weixin.qq.com/mp/video?__biz=MzU1NTg5MjYyNw==&mid=100000015&sn=3e301fdc5a364bd16d6207fa674bc8b3&vid=wxv_968792362971430913&idx=1&vidsn=eec329cc13c3e24c187dc9b4d5eb8760&fromid=1&scene=20&xtrack=1&clicktime=1567346543&sessionid=1567346375&subscene=92&ascene=0&fasttmpl_type=0&fasttmpl_fullversion=4730859-zh_CN-zip&fasttmpl_flag=0&realreporttime=1567346543910#wechat_redirect)
自定义按键映射操作方法如下:
- 编写自定义脚本放入keymap目录
- 启动服务之前记得勾选自定义映射选项,并选择自定义映射脚本
- 连接手机以后进入游戏场景
- 按~键数字键1左边切换为游戏映射模式即可体验具体按什么键要看你按键脚本定义的switchKey
- 再次按~键切换为正常控制模式
- 要想wasd控制开车记得在载具设置中设置为单摇杆模式
## 感谢
基于[Genymobile](https://github.com/Genymobile)的[scrcpy](https://github.com/Genymobile/scrcpy)项目进行复刻重构非常感谢他。QtScrcpy和原版scrcpy区别如下
关键点|scrcpy|QtScrcpy
--|:--:|:--:
界面|sdl|qt
视频解码|ffmpeg|ffmpeg
视频渲染|sdl|opengl
跨平台基础设施|自己封装|Qt提供
编程语言|C|C++
编程方式|同步|异步
控制方式|单点触控|单点/多点触控
编译方式|meson+gradle|Qt Creator
- 使用Qt可以非常容易的定制自己的界面
- 基于Qt的信号槽机制的异步编程提高性能
- 方便新手学习
- 增加多点触控支持
## 学习它
如果你对它感兴趣,想学习它的实现原理而又感觉无从下手,可以选择购买我录制的视频课程,
里面详细介绍了整个软件的开发架构以及开发流程带你从无到有的开发QtScrcpy
课程介绍:[https://blog.csdn.net/rankun1/article/details/87970523](https://blog.csdn.net/rankun1/article/details/87970523)
或者你也可以加入我的QtScrcpy QQ群和志同道合的朋友一块互相交流技术
QQ群号901736468
## 要求
Android部分至少需要API 21Android 5.0)。
您要确保在Android设备上[启用adb调试][enable-adb]。
[enable-adb]: https://developer.android.com/studio/command-line/adb.html#Enabling
## 下载这个软件
[gitee-download]: https://gitee.com/Barryda/QtScrcpy/releases
[github-download]: https://github.com/barry-ran/QtScrcpy/releases
### Windows
windows平台你可以直接使用我编译好的可执行程序:
- [国内下载][gitee-download]
- [国外下载][github-download]
你也可以[自己编译](#如何编译)
### Mac OS
Mac OS平台你可以直接使用我编译好的可执行程序:
- [国内下载][gitee-download]
- [国外下载][github-download]
你也可以[自己编译](#如何编译)
### Linux
目前只提供了windows和mac平台的可执行程序如果需要linux平台的可执行程序
您通常需要[自己编译](#如何编译)。别担心,这并不难。
目前只在ubuntu上测试过
## 运行
在你的电脑上接入Android设备然后运行程序按顺序点击如下按钮即可连接到Android设备
![运行](screenshot/run.png)
### 无线连接步骤(保证手机和电脑在同一个局域网):
1. 安卓手机端在开发者选项中打开usb调试
2. 通过usb连接安卓手机到电脑
3. 点击刷新设备,会看到有设备号更新出来
4. 点击获取设备ip
5. 点击启动adbd
6. 无线连接
7. 再次点击刷新设备发现多出了一个ip地址开头的设备选择这个设备
8. 启动服务
备注启动adbd以后不用再usb线了以后连接断开都不再需要除非安卓adbd停了需要重新启动
## 界面按钮介绍:
- 启动配置:启动服务前的功能参数设置
分别可以设置本地录制视频的比特率、分辨率、录制格式、录像保存路径等。
- 仅后台录制启动服务不现实界面只是录制Android设备屏幕
- 窗口置顶Android设备视频窗口置顶显示
- 自动息屏启动服务以后自动关闭Android设备屏幕节省电量
- 使用reverse服务启动模式出现服务启动失败报错more than one device可以去掉这个勾选尝试连接
- 刷新设备列表:刷新当前连接的设备
- 启动服务连接到Android设备
- 停止服务断开与Android设备的连接
- 停止所有服务断开所有已连接的Android设备
- 获取设备ip获取到Android设备的ip地址更新到“无线”区域中方便进行无线连接
- 启动adbd启动Android设备的adbd服务无线连接之前必须要启动。
- 无线连接使用无线方式连接Android设备
- 无线断开断开无线方式连接的Android设备
- adb命令行方便执行自定义adb命令目前不支持阻塞命令例如shell
## 主要功能
- 实时显示Android设备屏幕
- 实时键鼠控制Android设备
- 屏幕录制
- 无线连接
- 最多支持16台设备连接PC性能允许的情况下可以增加需要自己编译
- 全屏显示
- 窗口置顶
- 安装apk拖拽apk到视频窗口即可安装
- 传输文件拖拽文件到视频窗口即可发送文件到Android设备
- 后台录制:只录制,不显示界面
## TODO
[后期计划](docs/TODO.md)
## FAQ
[常见问题说明](docs/FAQ.md)
## 为什么开发QtScrcpy
综合起来有以下几个原因,比重从大到小排列:
1. 学习Qt的过程中需要一个项目实战一下
2. 本身具有音视频相关技能,对音视频很感兴趣
3. 本身具有Android开发技能好久没用有点生疏需要巩固一下
4. 发现了scrcpy决定用新的技术栈C++ + Qt + Opengl + ffmpeg复刻一下
## 如何编译
尽量提供了所有依赖资源,方便傻瓜式编译。
### PC端
1. 目标平台上搭建Qt开发环境(Qt >= 5.9.7, vs >= 2015 (不支持mingw))
2. 克隆该项目
3. 使用QtCreator打开项目根目录all.pro
4. 编译,运行即可
### Android端 没有修改需求的话直接使用自带的scrcpy-server.jar即可
1. 目标平台上搭建Android开发环境
2. 使用Android Studio打开项目根目录中的server项目
3. 编辑即可
4. 编译出apk以后改名为scrcpy-server.jar并替换third_party/scrcpy-server.jar即可
## Licence
由于是复刻的scrcpy尊重它的Licence
Copyright (C) 2018 Genymobile
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
## 关于作者
[Barry的CSDN](https://blog.csdn.net/rankun1)
一枚普通的程序员工作中主要使用C++进行桌面客户端开发一毕业在山东做过一年多钢铁仿真教育软件后来转战上海先后从事安防在线教育相关领域工作对音视频比较熟悉对音视频领域如语音通话直播教育视频会议等相关解决方案有所了解。同时具有androidlinux服务器等开发经验。