Gitee 地址:Barryda/QtScrcpy(微信限制,见原文)
项目名称:QtScrcpy
项目简介:Android 实时投屏软件,此应用程序提供 USB(或通过 TCP/IP)连接的 Android 设备的显示和控制。它不需要任何 root 访问权限
项目作者:Barryda
开发语言:C++ Qt Widgets
开源许可协议:Apache-2.0
关于开源协议:Apache-2.0
百度搜索都是长篇大论,简单点说吧,参考开源许可证通俗解释[1]
BSD、Apache 2.0 相对 GPL/LGPL 的开放源代码,BSD,Apache 2.0 就宽松许多——商业软件可以任意的使用 BSD,Apache 2.0 发布的软件代码,而不需要开放源代码,只需要提及代码的原出处就可以了。BSD 和 Apache 2.0 提及的方式稍有不同
QtScrcpy 可以通过 USB(或通过 TCP/IP)连接 Android 设备,并进行显示和控制。不需要 root 权限。
单个应用程序最多支持 16 个安卓设备同时连接。
同时支持 GNU/Linux,Windows 和 MacOS 三大主流桌面平台
它专注于:
精致 (仅显示设备屏幕)
性能 (30~60fps)
质量 (1920×1080 以上)
低延迟 (35~70ms)
快速启动 (1s 内就可以看到第一帧图像)
非侵入性 (不在设备上安装任何软件)
windows 上运行
windows上运行mac 上运行
mac上运行ubuntu 上运行
ubuntu上运行可以根据需要,自己编写脚本将 PC 键盘按键映射为手机的触摸点击,编写规则在这里[2]。
默认自带了针对和平精英手游和抖音进行键鼠映射的映射脚本,开启平精英手游后可以用键鼠像玩端游一样玩和平精英手游,开启抖音映射以后可以使用上下左右方向键模拟上下左右滑动,你也可以按照编写规则[3]编写其他游戏的映射文件,默认按键映射如下:
针对和平精英手游和抖音进行键鼠映射这里有玩和平精英的视频演示(微信限制,见原文)
自定义按键映射操作方法如下:
编写自定义脚本放入 keymap 目录
点击刷新脚本,确保脚本可以被检测到
选择需要的脚本
连接手机并启动服务之后,点击应用脚本
按~键(数字键 1 左边)切换为自定义映射模式即可体验(具体按什么键要看你按键脚本定义的 switchKey)
再次按~键切换为正常控制模式
要想 wasd 控制开车记得在载具设置中设置为单摇杆模式
你可以同时控制所有的手机
群控基于Genymobile[4]的scrcpy[5]项目进行复刻,重构,非常感谢。QtScrcpy 和原版 scrcpy 区别如下:
关键点 | scrcpy | QtScrcpy |
---|---|---|
界面 | sdl | qt |
视频解码 | ffmpeg | ffmpeg |
视频渲染 | sdl | opengl |
跨平台基础设施 | 自己封装 | Qt 提供 |
编程语言 | C | C++ |
编程方式 | 同步 | 异步 |
按键映射 | 不支持自定义 | 支持自定义按键映射 |
编译方式 | meson+gradle | Qt Creator |
使用 Qt 可以非常容易的定制自己的界面
基于 Qt 的信号槽机制的异步编程提高性能
方便新手学习
增加多点触控支持
如果你对它感兴趣,想学习它的实现原理而又感觉无从下手,可以选择购买我录制的视频课程, 里面详细介绍了整个软件的开发架构以及开发流程,带你从无到有的开发 QtScrcpy:
课程介绍:基于 Qt ffmpeg opengl 开发跨平台安卓实时投屏软件[6]
或者你也可以加入我的 QtScrcpy QQ 群,和志同道合的朋友一块互相交流技术:
QQ 群号:901736468
Android 部分至少需要 API 21(Android 5.0)。
您要确保在 Android 设备上启用 adb 调试[7]。
Windows
Windows 平台,你可以直接使用我编译好的可执行程序:
国内下载[8]
国外下载[9]
你也可以自己编译[10]
Mac OS
Mac OS 平台,你可以直接使用我编译好的可执行程序:
国内下载[11]
国外下载[12]
你也可以自己编译[13]
Linux
目前只提供了 windows 和 mac 平台的可执行程序,如果需要 linux 平台的可执行程序,
您通常需要自己编译[14]。别担心,这并不难。
目前只在 ubuntu 上测试过
在你的电脑上接入 Android 设备,然后运行程序,按顺序点击如下按钮即可连接到 Android 设备
运行安卓手机端在开发者选项中打开 usb 调试
通过 usb 连接安卓手机到电脑 3.点击刷新设备,会看到有设备号更新出来
点击获取设备 IP
点击启动 adbd
无线连接
再次点击刷新设备,发现多出了一个 IP 地址开头的设备,选择这个设备
启动服务
备注:启动 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 设备
屏幕录制
截图为 png
无线连接
最多支持 16 台设备连接(PC 性能允许的情况下可以增加,需要自己编译)
全屏显示
窗口置顶
安装 apk:拖拽 apk 到视频窗口即可安装
传输文件:拖拽文件到视频窗口即可发送文件到 Android 设备
后台录制:只录制,不显示界面
复制粘贴 在计算机和设备之间双向同步剪贴板:
Ctrl + c 将设备剪贴板复制到计算机剪贴板;
Ctrl + Shift + v 将计算机剪贴板复制到设备剪贴板;
Ctrl +v 将计算机剪贴板作为一系列文本事件发送到设备(不支持非 ASCII 字符)。
群控
功能 | 快捷键(Windows) | 快捷键 (macOS) |
---|---|---|
切换全屏 | Ctrl+f | Cmd+f |
调整窗口大小为 1:1 | Ctrl+g | Cmd+g |
调整窗口大小去除黑边 | Ctrl+x | 左键双击 | Cmd+x | 左键双击 |
点击 主页 | Ctrl+h | 点击鼠标中键 | Ctrl+h | 点击鼠标中键 |
点击 BACK | Ctrl+b | 右键双击 | Cmd+b | 右键双击 |
点击 APP_SWITCH | Ctrl+s | Cmd+s |
点击 MENU | Ctrl+m | Ctrl+m |
点击 VOLUME_UP | Ctrl+↑ (上) | Cmd+↑ (上) |
点击 VOLUME_DOWN | Ctrl+↓ (下) | Cmd+↓ (下) |
点击 POWER | Ctrl+p | Cmd+p |
打开电源 | 右键双击 | 右键双击 |
关闭屏幕 (保持投屏) | Ctrl+o | Cmd+o |
打开下拉菜单 | Ctrl+n | Cmd+n |
关闭下拉菜单 | Ctrl+Shift+n | Cmd+Shift+n |
复制设备剪切板到电脑 | Ctrl+c | Cmd+c |
粘贴电脑剪切板到设备 | Ctrl+v | Cmd+v |
复制电脑剪切板到设备 | Ctrl+Shift+v | Cmd+Shift+v |
鼠标左键双击黑色区域可以去除黑色区域
如果电源关闭,鼠标右键双击打开电源;如果电源开启,鼠标右键双击相当于返回
后期计划[15]
常见问题说明[16]
开发者相关[17]
欢迎大家一起维护这个项目,贡献自己的代码,不过请遵循一下几点要求:
pr 请提到 dev 分支,不要提到 master 分支
提 pr 之前请先 rebase dev
pr 请以少量多次的原则提交(建议一个小的功能点提一个 pr)
代码风格请保持和已有风格一致
综合起来有以下几个原因,比重从大到小排列:
学习 Qt 的过程中需要一个项目实战一下
本身具有音视频相关技能,对音视频很感兴趣
本身具有 Android 开发技能,好久没用有点生疏,需要巩固一下
发现了 scrcpy,决定用新的技术栈(C++ + Qt + Opengl + ffmpeg)复刻一下
尽量提供了所有依赖资源,方便傻瓜式编译。
目标平台上搭建 Qt 开发环境(Qt >= 5.12.0, vs >= 2017 (不支持 mingw))
克隆该项目
使用 QtCreator 打开项目根目录 all.pro
编译,运行即可
目标平台上搭建 Android 开发环境
使用 Android Studio 打开项目根目录中的 server 项目
第一次打开如果你没有对应版本的 gradle 会提示找不到 gradle,是否升级 gradle 并创建,选择取消,取消后会弹出选择已有 gradle 的位置,同样取消即可(会自动下载)
按需编辑代码即可,当然也可以不编辑
编译出 apk 以后改名为 scrcpy-server 并替换 third_party/scrcpy-server 即可
由于是复刻的 scrcpy,尊重它的 Licence
Copyright (C) 2020 Barry
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[18]
一枚普通的程序员,工作中主要使用 C++进行桌面客户端开发,一毕业在山东做过一年多钢铁仿真教育软件,后来转战上海先后从事安防,在线教育相关领域工作,对音视频比较熟悉,对音视频领域如语音通话,直播教育,视频会议等相关解决方案有所了解。同时具有 android,linux 服务器等开发经验。
小福利
本文markdown格式介绍文原件下载可点击阅读原文下载,对学习markdown的朋友可以借鉴学习。
文中链接可通过点击阅读原文查看
Dotnet9网站常驻编辑。
长按关注我,欢迎技术交流!
-好东西要转发,设为"星标"★抢先看-
点击阅读原文,关注Dotnet9更多好文。