投屏软件的原理是什么?它为什么比用 adb 快许多?

2018-05-03 12:20:32 +08:00
 clouduan

我试过用 adb 操作手机截图和点击,延迟都挺大的,但是投屏软件的按键几乎可以实现实时响应。

我觉得投屏软件的底层实现应该还是用的 adb,但是它是如何做到那么快的呢?

或者其不是靠 adb 实现的,那它的原理是什么呢?

28500 次点击
所在节点    Android
31 条回复
bfdh
2018-05-03 12:29:28 +08:00
mirrorcast、mirrorlink、vnc 了解下?
blackbbc
2018-05-03 12:35:08 +08:00
想知道,最近在研究手机投射到电脑上吃鸡的东西
做过 benchmark
tc games 的延迟在 400ms 左右
scrcpy 的延迟在 100ms 左右
目标是降低到 30ms 以内
youstu
2018-05-03 12:40:36 +08:00
主要的应该都还是传输延迟吧,chrome 上有个插件,叫 vysor,也是通过 adb 协议进行远程操作,如果是数据线直连,感觉延迟也很小。
clouduan
2018-05-03 12:45:54 +08:00
@youstu 是的我后来就是用的 vysor...
xomix
2018-05-03 13:00:16 +08:00
不是,我最早看到投屏技术的时候应该是 intel 的 widi,当然还有 nvdia 的自带无线网卡的显卡。

接下来 Linux mac windows 平台上各自衍生出了自己的投屏技术,再接下来 N A 两家显卡公司也做出了自己的对应技术。

不管这个技术名称叫什么平台在哪里,他都是讲当前系统运行的状态转换成视屏流发送出去的技术。

那这样就能很快明白为什么他比 adb 快了,adb 是可以在投屏端操作的,因此是双向的,无线投屏则是单向的。
siknet
2018-05-03 13:12:00 +08:00
那么问题来了,想要把电脑上的操作通过安卓盒子投射到电视上,哪家 APP 最顺畅?
TestSmirk
2018-05-03 13:35:38 +08:00
Android Studio 中的 adb 是 1:1 传输,就是说 2k 屏幕的手机截图下来也是 2k.录屏也是,不过录屏可以通过`-size`设置分辨率
投屏的话一般就是几种协议 DLNA,Miracast,无非就是在 WLAN,上封装的一层.
楼上说的 vysor 和 airdroid 类似,就是降低分辨率(480X800 或者更低)这种,实现高速无延时.
busfool
2018-05-03 13:38:21 +08:00
我也不知道
我看过 adb 底层的 framebuffer 命令,实现出来比较慢。
hicdn
2018-05-03 13:53:01 +08:00
@siknet 用 chromecast 可以用 chrome 投射桌面,很流畅。
乐播投屏,同时支持 DLNA 和 AirPlay,Mac OS 可以直接选乐播的 AirPlay 输出图像+声音。
siknet
2018-05-03 14:15:15 +08:00
@hicdn 乐播蛋疼啊,飞讯 T1 内置了这个,以前还正常,我前天清空了 APP 的数据之后,电脑 DLNA 过去的画面左上角居然有水印!!!四个字:乐播投屏

疯了,好像还没见别人说过这个,折腾了半天,只能强顶着看完 WW S2E02
hicdn
2018-05-03 14:21:33 +08:00
@siknet 没看到过水印,你卸载从网站下载 apk 安装试试
qq471847975
2018-05-03 14:26:18 +08:00
usb 线带宽有限,5G 无线最好了
siknet
2018-05-03 14:26:52 +08:00
@hicdn 内置的。。。不 root 没法卸载,连禁用都不行,所以想找个替代品
zhaohui318
2018-05-03 14:27:10 +08:00
beginor
2018-05-03 18:25:16 +08:00
搭各位老司机的车,求一款能够完美原生 Miracast 接收的 app, 乐播投屏没声音, 而且不是原生 Miracast。

Windows 10 自带了 Miracast 接收, 堪称完美。
somebody
2018-05-03 18:57:24 +08:00
这里有个开源的实现,效果很好,可以看下实现 https://github.com/Genymobile/scrcpy
gam2046
2018-05-03 21:05:05 +08:00
@somebody 似乎很好,不过试了试手头的两个设备都以不同的错误告终

华为 EMUI [API 22]
小米 MIUI [API 26]
nicevar
2018-05-03 22:10:59 +08:00
情况不一样的,adb 截图默认没有优化处理,截图完成之后直接把 png 拉过来,那么大的图片当然慢,投屏的时候无论是截屏还是传输都是有优化处理的,你 pull 一张 png 的图片时间够投屏的时候传很多帧了
applehater
2018-05-03 23:09:55 +08:00
@beginor 好像现在很多手机都不支持有线视频输出,比如我看黑鲨手机就完全看不到视频输出的介绍
jinyang656
2018-05-03 23:13:21 +08:00
scrcpy 基于 adb, 延迟已经很不错了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/451708

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX