Android 双屏异显(Presentation) 开发,将第二个页面投屏到副屏上

article/2025/7/21 12:49:29

1. 背景

最近开发的一个项目,有两个屏幕,需要将第二个页面投屏到副屏上,
这就需要用到Android的双屏异显(Presentation)技术了,研究了一下,这里做下笔记。
我们那个副屏是一块汽车的后视镜(流媒体后视镜),是一块长条块的屏幕,分辨率是400 * 1920 px

如何将需要显示的内容正确摆放地显示到这块屏幕上,是我们开发中的一个重点。
并且,我们是使用平板横屏进行开发的,对于横屏情况下双屏异显的处理,也是我们开发中的一个重点。

我们先来了解一下双屏异显(Presentation)技术是什么 ?
Android Presentation是Android系统中的一个显示设备,
它可以在同一时间连接多个显示设备,并且可以在不同的显示设备上显示不同的内容。
它可以通过HDMI或VGA等接口连接外部显示器, 从而扩展或切换屏幕。
使用Presentation,可以在不同的屏幕上显示不同的内容, 例如在投影仪上显示演示文稿,同时在笔记本上显示备注。
这可以更好地展示信息,提高演示效果。

2. 创建主屏布局

主屏就用MainActivity就好

class MainActivity : AppCompatActivity() {override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_main)//...}
}

3. 创建副屏布局

这里,继承了MyPresentation接口
其中有

class MyPresentation(outerContext: Context, display: Display) :Presentation(outerContext, display) {override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.dialog_normal)//绑定副屏显示的布局}//显示时调用override fun onStart() {super.onStart()}//消失时调用override fun onStop() {super.onStop()}
}

4. 将页面投屏到副屏上

投屏到副屏上有多种方式,我们只需要在MainActivity中去调用这些代码就可以了。

4.1 方式一 : MediaRouter

MediaRouter mediaRouter = (MediaRouter) getSystemService(Context.MEDIA_ROUTER_SERVICE);
MediaRouter.RouteInfo route = mediaRouter.getSelectedRoute(MediaRouter.ROUTE_TYPE_LIVE_AUDIO);
if (route != null) {Display presentationDisplay = route.getPresentationDisplay();if (presentationDisplay != null) {MyPresentation myPresentation = new MyPresentation(MainActivity.this, presentationDisplay);myPresentation.show();}
}

4.2 方式二 : DisplayManager

DisplayManager mDisplayManager = (DisplayManager) getSystemService(Context.DISPLAY_SERVICE);
Display[] displays = mDisplayManager.getDisplays();
if (displays.length > 1) {//displays[0] 主屏,displays[1] 副屏MyPresentation myPresentation = new MyPresentation(MainActivity.this, displays[1]);myPresentation.show();
}

5. 横屏状态下双屏异显的处理

在我们那个副屏上,副屏的显示逻辑是,主屏是竖屏,副屏就以副屏显示,主屏是横屏,副屏就以横屏显示。
如下图所示
在这里插入图片描述

而我们想要达到的效果是,主屏是横屏,而主屏是竖屏。
后来,我们想到了一个办法,就是搞两个Activity
Activity1负责显示主屏的页面,而Activity2负责副屏的显示。
首先启动Activity2,然后迅速启动Activity1,当Activity1关闭的时候,也去关闭Activity1
这样就可以实现主屏和副屏方向显示不一样的情况了。

6. 将需要显示的内容正确摆放到副屏上

由于我们的副屏是一块长条块的屏幕,分辨率是400 * 1920 px,我们现在主屏上是横屏显示,
而副屏通过上述的操作,显示的是竖屏。
在这里插入图片描述
而我们真正期望显示的内容是蓝色这部分
在这里插入图片描述

所以,我们需要对View做一下旋转并位移

val rotation: ObjectAnimator = ObjectAnimator.ofFloat(binding.textureView, "rotation", 0f, 90f)
val translationX: ObjectAnimator =ObjectAnimator.ofFloat(binding.textureView, "translationX", 0f, -720F)
val translationY: ObjectAnimator =ObjectAnimator.ofFloat(binding.textureView, "translationY", 0f, 420F)
val animatorSet = AnimatorSet()
animatorSet.playSequentially(rotation, translationX, translationY)
animatorSet.duration = 0
animatorSet.start()

最终显示为这样
在这里插入图片描述

7. 其他

7.1 没有副屏的情况下,如何调试 ?

如果手头上没有副屏,可以在开发者选项中,打开模拟辅助显示设备
在这里插入图片描述

这里我们可以选择1080P720P4K等都是可以的

在这里插入图片描述

选择后,显示出来的虚拟副屏如下所示

在这里插入图片描述
这样,我们在没有真实的副屏的情况下,就可以通过虚拟的副屏进行调试了。

7.2 双屏异显的应用场景

Android Presentation 可以用于以下场景:

  • 酒店登记信息:酒店员工可以通过一个屏幕进行操作,而顾客则可以通过另一个屏幕查看相关信息。
  • 医疗设备:一些医疗设备可能需要同时连接多个屏幕,以便医生能够同时查看多个病人的信息。
  • 演示文稿:演示者可以在一个屏幕上播放演示文稿,同时在另一个屏幕上显示备注或相关数据。
  • 多屏协同:多个屏幕可以连接在一起,每个屏幕上可以显示不同的内容,提高多任务处理效率。

所以说Android的双屏异显在特定领域还是很有用的。

7.3 本文源码下载

本文Demo下载地址 : Android 双屏异显(Presentation) 开发示例Demo

7.4 参考

感谢
Android 双屏异显实现的三种方式
Android Presentation实现双屏异显
Presentation 官方文档


http://chatgpt.dhexx.cn/article/tOge70D4.shtml

相关文章

父子div元素水平垂直居中的七种方法

效果样式图如下: 方法一:利用定位和transform的方法来进行居中 说明:首先利用定位中的子元素绝对定位和父元素相对定位的方法来,top:50% 和left:50%会使子元素在父元素中向下移动250px,向右移动250px,子元素因自身有高度和宽度,这会导致子元素不能完全居中的情况,t…

用户体验思考与flex三坑:元素不均分、溢出不省略和垂直不滚动

flex已经越来越成为前端不可避免的话题。曾经为了搞清flex的原理偶然画了一张图。但后来发现只是冰山一角。 在某些你想实现的交互效果中使用flex后可能会发现并不起作用。通过我的实践,大致有三个问题:子元素不平分父元素空间、对文字设置了溢出省略却…

DIV居中的经典方法

参考:https://www.cnblogs.com/rubykakas/articles/7992662.html 1. 实现DIV水平居中 设置DIV的宽高,使用margin设置边距0 auto,CSS自动算出左右边距,使得DIV居中。 div{width: 100px;height: 100px;margin: 0 auto; } 缺点&…

局域网屏幕共享_给安卓手机连一个大屏幕——多端协作(六)

好久不见,时下情势严峻,我们这儿封村了,生活变得更加不方便了。本来在网上买了肉,等到终于发货送到县城,我却不能进城去取了…… 希望顺丰营业点有冰箱,我的肉不会坏掉 今天给大家介绍的是Android系统的无线投屏功能,简单来说就是将支持的设备作为安卓手机的外接屏幕,以…

安卓手机与蓝牙模块联合调试(二)—— 单片机蓝牙控制LED灯亮灭(上)

系列博文: (1)安卓手机与蓝牙模块联合调试(一)——蓝牙模块的串口通讯 (2)安卓手机与蓝牙模块联合调试(二)—— 单片机蓝牙控制LED灯亮灭(上) …

android 多屏幕显示activity,副屏,无线投屏

目录 1. 首先,需要一个副屏 1. 1 可以通过代码的形式自己创建VirtualDispaly ,创建副屏。 1.2 或者,在手机的开发者模式中直接开启模拟副屏,也是可以的。 2.0 怎么利用这个副屏幕? 2.1 用作 presentation 演示ppt&#xff1…

【Android 屏幕扩展/共享】5分钟搞定—电脑 与 手机共享屏幕

回去看看老家是不是还有旧平板电脑,可以跨设备,共享屏幕哦 一些远程控制软件,诸如:TeamViewer、AnyDesk等。 但是这次我要介绍的是 一款远程显示软件,甚至可以理解成一款简易的KVM系统。 虽然市面上许多远程控制软件…

Android设备之间投屏功能实现

简介 简单实现两个android设备之间的投屏功能。设备间通信是通过局域网,需要连接同一个wifi。 录屏用到系统的MediaProjection,MediaProjectionManager,而编解码用的是MediaCodec,所以设备需要有DSP芯片,大部分手机应…

CSS实现垂直居中的5种方法

第一种 position定位margin负距离 前提是知道居中元素的宽高&#xff0c;首先给居中元素定位&#xff0c;之后设置margin的负距离为具体宽高的一半便可达到垂直居中效果 <style>.box1 {height: 300px;width: 300px;border: 10px solid pink;position: relative;}.box2 {…

在html中如何使div在页面中居中显示

在html中如何使div在页面中居中显示 最近无聊中又再温习了下html,发现好多东西都忘了。尝试着写了一个html网页&#xff0c;结果就连div如何在页面中居中显示都查了好久才弄出来。其实我不知道为什么这样可以实现&#xff0c;因为css还没仔细研究过&#xff0c;等我参加完复试定…

实现div里的img图片水平垂直居中

body结构 <body><div><img src"1.jpg" alt"haha"></div> </body>方法一&#xff1a; 将display设置成table-cell&#xff0c;然后水平居中设置text-align为center&#xff0c;垂直居中设置vertical-align为middle。 <s…

程序运行的错误

程序的运行当可能会出现的问题 没有找到文件&#xff0c;可能是相应的文件没有编写&#xff0c;或者文件名输入的有错误 程序运行可能会出现500的错误&#xff0c;错误原因大概有&#xff0c;下面几种

小程序错误

小程序报错1&#xff1a;unknown: Unexpected token, expected “,” [ appservice 生成错误] pages/page04/page04.js: file: pages/page04/page04.js unknown: Unexpected token, expected “,” (25:4) 错误原因&#xff1a;没有逗号。 小程序报错2 设置 enable-flex 属…

winword.exe应用程序错误0xc0000142

正常使用Word&#xff0c;关机再开机&#xff0c;发现提示错误“winword.exe应用程序错误0xc0000142”&#xff0c;有效解决方法 1、winR&#xff0c;输入CMD 2、输入sfc/scannow 注&#xff1a;sfc/scannow&#xff1a;立即扫描所有受保护系统文件的完整性&#xff0c;并尽可…

解决devenv.exe应用程序错误,应用程序发生异常

解决devenv.exe应用程序错误&#xff0c;应用程序发生异常 打开VS2008/2010时&#xff0c;经常碰到:devenv.exe应用程序错误&#xff0c;应用程序发生异常&#xff0c;造成的原因是多种的&#xff0c;可能是环境变量配置出错&#xff0c;可能是你安装了冲突的插件&#xff0c;如…

添加或删除程序 rundll32.exe-应用程序错误

rundll32.exe-应用程序错误 点击开始-运行&#xff0c;输入 “cmd”&#xff0c;单击确定。 在打开的命令提示符窗口中依次输入第三步中的命令复制&#xff0c;然后粘贴到命令提示符窗口中运行。 regsvr32 Appwiz.cpl regsvr32 Jscript.dll regsvr32 Mshtml.dll regsvr32…

ps无法完成请求因为程序错误

目录 方法一&#xff1a;兼容性 方法二&#xff1a;清空缓存 方法三&#xff1a;图形处理器 方法一&#xff1a;兼容性 1、右击PS软件图标&#xff0c;选择“属性” 2.选择“兼容性”选项卡&#xff0c;勾选“以兼容模式运行这个程序”&#xff0c;并选择兼容的系统&#xf…

ArcGIS遇到严重的应用程序错误的解决办法

ArcGIS遇到严重的应用程序错误的解决办法 GIS思维 很多ArcGIS用户经常会碰到程序突然崩溃遇到严重错误的时候且重启无法解决。网上给出的方法基本就是几种没有&#xff0c;基本也解决不了。 也可以去测试&#xff0c;基本就是&#xff1a; ArcGIS找打不到配置信息&#xff0c…

Photoshop储存为psd出现程序错误提示怎么办?程序错误解决教程

Photoshop是大家进行平面设计是不可或缺的图像处理工具&#xff0c;然而大家在使用Photoshop做图像处理&#xff0c;准备将psd文件保存到电脑&#xff0c;是不是经常遇到过弹出了Photoshop【无法完成请求&#xff0c;因为程序错误】的提醒窗口&#xff0c;无法完成保存工作。具…

java程序出错_java程序错误类型及异常处理

一、程序的错误类型 在程序设计中,无论规模是大是小,错误总是难免的。程序的设计很少有能够一次完成,没有错误的(不是指HelloWorld这样的程序,而是要实现一定的功能,具备一定实用价值的程序),在编程的过程中由于种种原因,总会出现这样或那样的错误,这些程序的错误就是我…