android媒体在二级设备上呈现和播放

2024-04-23 01:08

本文主要是介绍android媒体在二级设备上呈现和播放,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

public class PresentationWithMediaRouterActivity extends Activity {private final String TAG = "PresentationWithMediaRouterActivity";// MediaRouter用于和MediaRouterService交互一起管理多媒体的播放行为,并维护当前已经配对上的remote// display设备,包括Wifi diplay、蓝牙A2DP设备、chromecast设备。private MediaRouter mMediaRouter;// MediaRouter提供了快速获得系统中用于演示(presentations)默认显示设备的方法。private DemoPresentation mPresentation;private GLSurfaceView mSurfaceView;private TextView mInfoTextView;private boolean mPaused;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);/** 获取到媒体路由,当媒体路由被选择或取消选择或者路由首选的presentation显示屏幕发生变化时,* 它都会发送通知消息。一个应用程序可以非常简单通过地观察这些通知消息来自动地在首选的presentation* 显示屏幕上显示或隐藏一个presentation。*/mMediaRouter = (MediaRouter) getSystemService(Context.MEDIA_ROUTER_SERVICE);setContentView(R.layout.presentation_with_media_router_activity);mSurfaceView = (GLSurfaceView) findViewById(R.id.surface_view);// 设置我们要渲染的图形为CubeRenderermSurfaceView.setRenderer(new CubeRenderer(false));mInfoTextView = (TextView) findViewById(R.id.info);}@Overrideprotected void onResume() {super.onResume();/*** 注册一个具体的MediaRouter.Callback回调对象,并用来启动与特定MediaRouteSelector相匹配的媒体路由的发现* , 以及监听发现的媒体路由的相关事件,如用户已选择连接到某个媒体路由设备、某个媒体路由设备的特性发生改变或者断开某个媒体路由等事件。* 应用为了使用相关的媒体路由,必须调用该函数来启动媒体路由的发现,并通过登记的回调函数接收相关的事件。*/// 设置对媒体路由变化的监听mMediaRouter.addCallback(MediaRouter.ROUTE_TYPE_LIVE_VIDEO,mMediaRouterCallback);mPaused = false;updatePresentation();}@Overrideprotected void onPause() {super.onPause();// 移除回调监听mMediaRouter.removeCallback(mMediaRouterCallback);mPaused = true;updateContents();}@Overrideprotected void onStop() {super.onStop();// 当Activity不可见时,清除Presentationif (mPresentation != null) {Log.i(TAG,"Dismissing presentation because the activity is no longer visible.");mPresentation.dismiss();mPresentation = null;}}@Overridepublic boolean onCreateOptionsMenu(Menu menu) {super.onCreateOptionsMenu(menu);// 加载菜单getMenuInflater().inflate(R.menu.presentation_with_media_router_menu,menu);MenuItem mediaRouteMenuItem = menu.findItem(R.id.menu_media_route);MediaRouteActionProvider mediaRouteActionProvider = (MediaRouteActionProvider) mediaRouteMenuItem.getActionProvider();mediaRouteActionProvider.setRouteTypes(MediaRouter.ROUTE_TYPE_LIVE_VIDEO);// 显示菜需要返回truereturn true;}/*** 代码示例展示了Presentation实现对象的作为一个单独方法的控制层.当一个显示器处理不可选状态或者失去联系时,该方法负责清除无效的展示对象,* 而在一个显示设备连接时负责创建一个展示对象。* * @description:* @author ldm* @date 2016-6-4 上午9:34:05*/private void updatePresentation() {// 获取当前路由MediaRouter.RouteInfo route = mMediaRouter.getSelectedRoute(MediaRouter.ROUTE_TYPE_LIVE_VIDEO);// 判断route信息是否为空,如果不为空则返回被选择演示(presentation)设备。该方法只对// route信息类型为ROUTE_TYPE_LIVE_VIDEO有效。Display presentationDisplay = route != null ? route.getPresentationDisplay() : null;// 清除无用的展示对象if (mPresentation != null&& mPresentation.getDisplay() != presentationDisplay) {Log.i(TAG,"Dismissing presentation because the current route no longer "+ "has a presentation display.");mPresentation.dismiss();mPresentation = null;}// 根据需要显示展示 对象if (mPresentation == null && presentationDisplay != null) {Log.i(TAG, "Showing presentation on display: "+ presentationDisplay);mPresentation = new DemoPresentation(this, presentationDisplay);mPresentation.setOnDismissListener(mOnDismissListener);try {mPresentation.show();} catch (WindowManager.InvalidDisplayException ex) {Log.w(TAG,"Couldn't show presentation!  Display was removed in "+ "the meantime.", ex);mPresentation = null;}}// 更新Activity中内容updateContents();}/*** 更新内容* * @description:* @author ldm* @date 2016-6-4 上午9:27:40*/private void updateContents() {if (mPresentation != null) {mInfoTextView.setText(getResources().getString(R.string.presentation_with_media_router_now_playing_remotely,mPresentation.getDisplay().getName()));mSurfaceView.setVisibility(View.INVISIBLE);mSurfaceView.onPause();if (mPaused) {mPresentation.getSurfaceView().onPause();} else {mPresentation.getSurfaceView().onResume();}} else {mInfoTextView.setText(getResources().getString(R.string.presentation_with_media_router_now_playing_locally,getWindowManager().getDefaultDisplay().getName()));mSurfaceView.setVisibility(View.VISIBLE);if (mPaused) {mSurfaceView.onPause();} else {mSurfaceView.onResume();}}}private final MediaRouter.SimpleCallback mMediaRouterCallback = new MediaRouter.SimpleCallback() {// 当用户连接到一个媒体路由输出设备上时调用。@Overridepublic void onRouteSelected(MediaRouter router, int type, RouteInfo info) {Log.d(TAG, "onRouteSelected: type=" + type + ", info=" + info);updatePresentation();}// 当用户断开一个媒体路由输出设备时调用。@Overridepublic void onRouteUnselected(MediaRouter router, int type,RouteInfo info) {Log.d(TAG, "onRouteUnselected: type=" + type + ", info=" + info);updatePresentation();}// 当展示的显示器改变现实像素,如从720p变到1080p分辨率。@Overridepublic void onRoutePresentationDisplayChanged(MediaRouter router,RouteInfo info) {Log.d(TAG, "onRoutePresentationDisplayChanged: info=" + info);updatePresentation();}};/*** Listens for when presentations are dismissed.*/private final DialogInterface.OnDismissListener mOnDismissListener = new DialogInterface.OnDismissListener() {@Overridepublic void onDismiss(DialogInterface dialog) {if (dialog == mPresentation) {Log.i(TAG, "Presentation was dismissed.");mPresentation = null;updateContents();}}};/*** 要为辅助显示屏创建独特的内容,您需要扩展Presentation类,并实现onCreate()回调方法。在onCreate()中,* 调用setContentView()来指定您要在辅助显示屏上显示的UI。* 作为Dialog类的扩展,Presentation类提供了一个区域,在其中, 您的应用可以在辅助显示屏上显示不同的UI。* * @description:* @author ldm* @date 2016-6-4 上午9:08:45*/private final static class DemoPresentation extends Presentation {/*** GLSurfaceView是一个视图,继承至SurfaceView,它内嵌的surface专门负责OpenGL渲染。* GLSurfaceView提供了下列特性: 1>* 管理一个surface,这个surface就是一块特殊的内存,能直接排版到android的视图view上。 2> 管理一个EGL* display,它能让opengl把内容渲染到上述的surface上。 3> 用户自定义渲染器(render)。 4>* 让渲染器在独立的线程里运作,和UI线程分离。 5> 支持按需渲染(on-demand)和连续渲染(continuous)。* 6>一些可选工具,如调试。*/private GLSurfaceView mSurfaceView;public DemoPresentation(Context context, Display display) {super(context, display);}@Overrideprotected void onCreate(Bundle savedInstanceState) {// 必须要写下面这句话,调用父类的onCreate();super.onCreate(savedInstanceState);// 设置布局setContentView(R.layout.presentation_with_media_router_content);// mSurfaceView对象获取:建立有趣的视觉mSurfaceView = (GLSurfaceView) findViewById(R.id.surface_view);mSurfaceView.setRenderer(new CubeRenderer(false));}public GLSurfaceView getSurfaceView() {return mSurfaceView;}}
}

相关代码请见:https://github.com/ldm520/ANDROID_API_DEMOS
参考博客:
http://blog.csdn.net/lilian0118/article/details/22940943
http://blog.csdn.net/michaelcao1980/article/details/9293441

这篇关于android媒体在二级设备上呈现和播放的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/927372

相关文章

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

Python如何将OpenCV摄像头视频流通过浏览器播放

《Python如何将OpenCV摄像头视频流通过浏览器播放》:本文主要介绍Python如何将OpenCV摄像头视频流通过浏览器播放的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完... 目录方法1:使用Flask + MJPEG流实现代码使用方法优点缺点方法2:使用WebSocket传输视

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

Python数据分析与可视化的全面指南(从数据清洗到图表呈现)

《Python数据分析与可视化的全面指南(从数据清洗到图表呈现)》Python是数据分析与可视化领域中最受欢迎的编程语言之一,凭借其丰富的库和工具,Python能够帮助我们快速处理、分析数据并生成高质... 目录一、数据采集与初步探索二、数据清洗的七种武器1. 缺失值处理策略2. 异常值检测与修正3. 数据

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

Android NDK版本迭代与FFmpeg交叉编译完全指南

《AndroidNDK版本迭代与FFmpeg交叉编译完全指南》在Android开发中,使用NDK进行原生代码开发是一项常见需求,特别是当我们需要集成FFmpeg这样的多媒体处理库时,本文将深入分析A... 目录一、android NDK版本迭代分界线二、FFmpeg交叉编译关键注意事项三、完整编译脚本示例四

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I

嵌入式Linux之使用设备树驱动GPIO的实现方式

《嵌入式Linux之使用设备树驱动GPIO的实现方式》:本文主要介绍嵌入式Linux之使用设备树驱动GPIO的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、设备树配置1.1 添加 pinctrl 节点1.2 添加 LED 设备节点二、编写驱动程序2.1