Android WebView播放视频flash(判断是否安装flash插件)

简介: Android WebView播放flash(判断是否安装flash插件)  最近帮一个同学做一个项目,断断续续的一些知识点记录一下。一个页面中有一个WebView,用来播放swf,如果系统中未安装flash插件,必须提示用户到market中安装。
Android WebView播放flash(判断是否安装flash插件) 

最近帮一个同学做一个项目,断断续续的一些知识点记录一下。一个页面中有一个WebView,用来播放swf,如果系统中未安装flash插件,必须提示用户到market中安装。

下面做一个demo,效果图如下:


首先布局文件,很简单:

[html]  view plain copy
  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent" >  
  5.     <WebView  
  6.         android:id="@+id/webview"   
  7.         android:layout_width="fill_parent"  
  8.         android:layout_height="fill_parent"  
  9.         android:layout_centerInParent="true" />  
  10. </RelativeLayout>  
接着activity,得先检测系统中是否已经安装了adobe flash player插件,插件的packageName是com.adobe.flashplayer:

[java]  view plain copy
  1. private boolean check() {  
  2.         PackageManager pm = getPackageManager();  
  3.         List<PackageInfo> infoList = pm  
  4.                 .getInstalledPackages(PackageManager.GET_SERVICES);  
  5.         for (PackageInfo info : infoList) {  
  6.             if ("com.adobe.flashplayer".equals(info.packageName)) {  
  7.                 return true;  
  8.             }  
  9.         }  
  10.         return false;  
  11. }  
如果未安装,则要做出提醒,为了提供良好的体验,我通过WebView加载一个简单的html文件来提醒,html文件放在assets下,如图一:

[html]  view plain copy
  1. <html>  
  2. <head></head>  
  3. <body>  
  4. <h3>Not install adobe flash player!</h3>  
  5. <p>  
  6. <a href="#" onclick="window.android.goMarket()">go market to install.</a>  
  7. </p>  
  8. </body>  
  9. </html>  
这个html文件中有一个链接,点击这个链接则会跳转到market中去下载,这就涉及到了在Javascript中调用Java本地方法,下面说如何调用,看上面链接的onclick中,它调用window.android对象的goMarket()方法,普通浏览器打开这个页面的,window.android是未定义的,则我们就需要在Java中构建这么一个对象,WebView有一个
[java]  view plain copy
  1. addJavascriptInterface(Object obj, String interfaceName);  
方法,第一个参数就是我们需要构建的绑定到javascript的那个对象,第二个参数就是在javascript中调用的名字,这儿就是android。

[java]  view plain copy
  1. private void install() {  
  2.         mWebView.addJavascriptInterface(new AndroidBridge(), "android");  
  3.         mWebView.loadUrl("file:///android_asset/go_market.html");  
  4. }  
我们所构建的对象如下:

[java]  view plain copy
  1. private class AndroidBridge {  
  2.         public void goMarket() {  
  3.             handler.post(new Runnable() {  
  4.                 public void run() {  
  5.                     Intent installIntent = new Intent(  
  6.                             "android.intent.action.VIEW");  
  7.                     installIntent.setData(Uri  
  8.                             .parse("market://details?id=com.adobe.flashplayer"));  
  9.                     startActivity(installIntent);  
  10.                 }  
  11.             });  
  12.         }  
  13. }  
javascript如果调用goMarket()方法,则进入的是专用于浏览器的特殊线程,如果涉及的UI更新,则要通过handler来操作。这样点击链接后会调用你手机中的market软件,如图二。安装之后就能播放flash了。有一个a.swf在assets下,如图三:

[java]  view plain copy
  1. String url="file:///android_asset/a.swf";  
  2. mWebView.loadUrl(url);  
当然一开始要对WebView进行一些设置:

[java]  view plain copy
  1. WebSettings setting=mWebView.getSettings();  
  2. setting.setPluginState(PluginState.ON);  
  3. setting.setJavaScriptEnabled(true);  
android4.0以上还得开启硬件加速,在manifest文件中,这个activity标签下加上如下属性:

[html]  view plain copy
  1. android:hardwareAccelerated="true"  

demo打包下载。

WebView播放flash,兼容问题还不少,我不太推荐使用。

相关文章
|
21天前
|
程序员 开发工具 Android开发
Android|WebView 禁止长按,限制非白名单域名的跳转层级
如何限制 WebView 仅域名白名单网址能随意跳转,并禁用长按选择文字。
28 2
|
21天前
|
Android开发
我是一位Android工程师,用通义灵码的AS插件做开发工作助手,对比之前没有灵码,现在提效了60%
我是一位Android工程师,用通义灵码的AS插件做开发工作助手,对比之前没有灵码,现在提效了60%
34 0
|
3月前
|
JavaScript 前端开发 Android开发
Flutter笔记:关于WebView插件的用法(下)
Flutter笔记:关于WebView插件的用法(下)
211 5
|
3月前
|
Android开发
解决android apk安装后出现2个相同的应用图标
解决android apk安装后出现2个相同的应用图标
335 2
|
3月前
|
存储 缓存 JavaScript
Flutter笔记:关于WebView插件的用法(上)
Flutter笔记:关于WebView插件的用法(上)
1472 4
|
5月前
|
安全 JavaScript 前端开发
kotlin开发安卓app,JetPack Compose框架,给webview新增一个按钮,点击刷新网页
在Kotlin中开发Android应用,使用Jetpack Compose框架时,可以通过添加一个按钮到TopAppBar来实现WebView页面的刷新功能。按钮位于右上角,点击后调用`webViewState?.reload()`来刷新网页内容。以下是代码摘要:
|
5月前
|
JavaScript 前端开发 Android开发
kotlin安卓在Jetpack Compose 框架下使用webview , 网页中的JavaScript代码如何与native交互
在Jetpack Compose中使用Kotlin创建Webview组件,设置JavaScript交互:`@Composable`函数`ComposableWebView`加载网页并启用JavaScript。通过`addJavascriptInterface`添加`WebAppInterface`类,允许JavaScript调用Android方法如播放音频。当页面加载完成时,执行`onWebViewReady`回调。
|
4月前
|
Oracle Java 关系型数据库
Android studio 安装以及第一个程序
Android studio 安装以及第一个程序
125 0
|
4月前
|
Web App开发 JavaScript 前端开发
Android端使用WebView注入一段js代码实现js调用android
Android端使用WebView注入一段js代码实现js调用android
108 0
|
5月前
|
存储 Android开发
详细解读Android获取已安装应用信息(图标,名称,版本号,包)
详细解读Android获取已安装应用信息(图标,名称,版本号,包)
76 0