目前有三种方式可以实现在Unity工程中实现内嵌网页的功能:

1、  UnityWebCore:只支持Windows平台,调用浏览器内核,将网页渲染到mesh,作为gameObject。

2、  Unity-Webview:只适用于Andriod和ios平台,调用移动平台的Webview。

3、  UniWebView:适用于Andriod、ios和Mac os,在移动端效果最好。2.0版本之后支持WP8,不支持windows桌面系统,包括编辑器状态。

二、使用的主要思路

  1. <span style="font-size:18px;">        void OpenURL()  //打开网址
  2. {
  3. _cachedView.TitleLabel.text = "资讯";
  4. _webView = _uiTrans.gameObject.GetComponent<UniWebView> ();
  5. if (_webView == null)
  6. {
  7. _webView=_uiTrans.gameObject.AddComponent<UniWebView>();
  8. //_webView.OnReceivedMessage += OnReceivedMessage;
  9. //_webView.OnLoadComplete += OnLoadComplete;
  10. //_webView.OnWebViewShouldClose += OnWebViewShouldClose;
  11. //_webView.OnEvalJavaScriptFinished += OnEvalJavaScriptFinished;
  12. _webView.InsetsForScreenOreitation += InsetsForScreenOreitation;
  13. }
  14. if(InformationManager.Instance.ArticleType == EArticleType.Notice)
  15. {
  16. _webView.url = AppManager.Instance.GameIP + "/gatj?ad=" + InformationManager.Instance.ArticleId;
  17. }
  18. else if(InformationManager.Instance.ArticleType == EArticleType.V)
  19. {
  20. _webView.url = AppManager.Instance.GameIP + "/detaifdav.jsp?articleId=" + InformationManager.Instance.VId;
  21. }
  22. _webView.Load();    //加载网页
  23. ShowOrHide(true);       //控制显示
  24. }
  25. public void ShowOrHide(bool flag)
  26. {
  27. if(flag)
  28. {
  29. _webView.Show ();
  30. }
  31. else
  32. {
  33. _webView.Hide();
  34. }
  35. }
  36. void CloseWeb(UniWebView webView)   //关闭网页
  37. {
  38. webView.Hide();
  39. UnityEngine.Object.Destroy(webView);
  40. //webView.OnReceivedMessage -= OnReceivedMessage;
  41. //webView.OnLoadComplete -= OnLoadComplete;
  42. //webView.OnWebViewShouldClose -= OnWebViewShouldClose;
  43. //webView.OnEvalJavaScriptFinished -= OnEvalJavaScriptFinished;
  44. webView.InsetsForScreenOreitation -= InsetsForScreenOreitation;
  45. _webView = null;
  46. }</span>

代码来自实际项目,只提供主要思路。

调用安卓和ios自身平台的方法封装在jar和mm文件中,提供了UniWebView类调用这些方法。打开网页时将UniWebView作为组件挂在一个gameObject上。将网址字符串赋值给UniWebView中的url字段,调用Load()方法加载网址,Show()方法显示在屏幕上,对应Hide()方法。关闭时,先隐藏,再销毁UniWebView组件。

UniWebView类中提供了一些回调方法,本项目中用到了UniWebViewEdgeInsets。默认打开网页是全屏方式,UniWebViewEdgeInsets是使网页偏移。也就是控制网页显示的区域和位置。需要注意,在安卓平台插入的值以像素为单位,在ios平台,因为不同机型屏幕scale值不同,同一个值插入效果不一样,建议判断机型根据效果将数值写死:

  1. <span style="font-size:18px;">        UniWebViewEdgeInsets InsetsForScreenOreitation(UniWebView webView, UniWebViewOrientation orientation)
  2. {
  3. #if UNITY_IOS
  4. var iphoneGen=UnityEngine.iOS.Device.generation;
  5. if(iphoneGen==UnityEngine.iOS.DeviceGeneration.iPhone5S)
  6. {
  7. topInset=54;
  8. bottomInset=34;
  9. }
  10. else if(iphoneGen==UnityEngine.iOS.DeviceGeneration.iPhone6)
  11. {
  12. topInset=64;
  13. bottomInset=40;
  14. }
  15. else if(iphoneGen==UnityEngine.iOS.DeviceGeneration.iPhone6Plus)
  16. {
  17. topInset=70;
  18. bottomInset=44;
  19. }
  20. #endif
  21. if (orientation == UniWebViewOrientation.Portrait)
  22. {
  23. return new UniWebViewEdgeInsets(topInset,0,bottomInset,0);
  24. }
  25. else
  26. {
  27. return new UniWebViewEdgeInsets(topInset,0,bottomInset,0);
  28. }
  29. }</span>

三、需要注意的问题

在安卓平台使用最大的问题是Unity失去焦点的问题。经过使用OnApplicationFocus方法测试,调用平台WebView打开界面时默认打开另一个Activity,Unity本身为一个Activity,当打开另外一个Activity时Unity会失去焦点,此时焦点不在Unity程序身上,如果锁屏或者按Home键再打开后只会调出最后一个显示的Activity,也就是UniWebView打开的网页,而不是Unity程序。也就是在打开网页的界面按下Home键或者锁屏后程序将无法正常返回。主要的问题在于Unity程序和打开的网页属于不同的Activity,解决的方法为更改Unity工程中的安卓配置文件,使一个Activity继承于另一个,显示在同一个Activity上。

另外,打开的网页有缓存。经过测试,在打开一个网页后,修改网页,再次打开,显示的还是之前的网页,关闭Unity程序也无法清除缓存。解决的方法为关闭网页时调用插件自身的CleanCache ()方法,清除缓存,这样每次打开的都是新的网页。

Unity中内嵌网页插件UniWebView使用总结的更多相关文章

  1. Unity中内嵌网页插件UniWebView

    一.常见Unity中内嵌网页实现方式: 1.UnityWebCore只支持windows 2.Unity-Webview支持Android,IOS 3.UniWebView支持mac os,Andro ...

  2. Unity 内嵌网页

    uniwebview 官网 http://uniwebview.onevcat.com/reference/class_uni_web_view.html http://uniwebview.onev ...

  3. 关于Unity程序在IOS和Android上显示内嵌网页的方式

    近期因为有须要在Unity程序执行在ios或android手机上显示内嵌网页.所以遍从网上搜集了一下相关的资料.整理例如以下: UnityWebCore 从搜索中先看到了这个.下载下来了以后发现这个的 ...

  4. WPF应用程序内嵌网页

    原文:WPF应用程序内嵌网页 版权声明:本文为博主原创文章,转载请注明出处. https://blog.csdn.net/shaynerain/article/details/78160984 WPF ...

  5. WPF内嵌网页的两种方式

    在wpf程序中,有时会内嵌网页.内嵌网页有两种方法,一种是使用wpf自带WebBrowser控件来调用IE内核,另一种是使用CefSharp包来调用chrom内核. 一.第一种使用自带WebBrows ...

  6. Qt和JavaScript使用QWebChannel交互一——和Qt内嵌网页交互

    Qt和JavaScript使用QWebChannel交互一--和Qt内嵌网页交互 目录 Qt和JavaScript使用QWebChannel交互一--和Qt内嵌网页交互 前言 一.效果 二.实现过程 ...

  7. iOS 之 内嵌网页

    现在iOS 有两种内嵌网页的技术,一种是UIWebView,而另一种WKWebView则是iOS8之后出现的技术. iOS 之 UIWebView WKWebView

  8. [小程序开发] 微信小程序内嵌网页web-view开发教程

    为了便于开发者灵活配置小程序,微信小程序开放了内嵌网页能力.这意味着小程序的内容不再局限于pages和large,我们可以借助内嵌网页丰富小程序的内容.下面附上详细的开发教程(含视频操作以及注意事项) ...

  9. APP中内嵌H5页面为什么不能下载?

    在APP中内嵌H5页面,若页面上存在下载链接,没有任何反应,为什么呢? 原因是app中内嵌的H5页面是WebView解析的,什么是WebView呢? 在Android手机中内置了一款高性能webkit ...

随机推荐

  1. 安装Vagrant出错 安装Homestead出错失败

    安装Vagrant出错 安装Homestead出错     我们也可以在电脑上创建其它文件夹,只需保证创建的文件夹路径跟 Homestead.yaml 文件中的 folders - map 保持一致即 ...

  2. 细说linux IPC(一):基于socket的进程间通信(上)

        [版权声明:尊重原创.转载请保留出处:blog.csdn.net/shallnet 或 .../gentleliu,文章仅供学习交流,请勿用于商业用途]     在一个较大的project其中 ...

  3. Tomcat日志、项目中的log4j日志、e.printStackTrace()——我的日志最后到底跑哪去了?

    1.Tomcat自带日志功能,即时你的项目中有log4j也不会影响到Tomcat自己记录日志. 2.你的项目中的log4j中的日志指定打印到什么地方(控制台或者文件),便会打印到什么地方,和Tomat ...

  4. python-__init__.py 与模块对象的关系

    python中的Module是比较重要的概念.常见的情况是,事先写好一个.py文件,在另一个文件中需要import时,将事先写好的.py文件拷贝 到当前目录,或者是在sys.path中增加事先写好的. ...

  5. Could not create and/or set value back on to object .

    严重: Error building beanorg.springframework.beans.factory.UnsatisfiedDependencyException: Error creat ...

  6. bootstrap学习笔记一 登录水平表单

    先上效果图: 样式定义: <form class="form-horizontal"> <div class="control-group"& ...

  7. 修改select下拉框的下拉按钮

    ie上的下拉框下拉按钮真是太丑了,如何把他自定义一下呢? 首先,把浏览器自带的下拉框去掉:  select::-ms-expand { display: none; } 接下来,用自己喜欢的下拉图片去 ...

  8. js操作时间 加法 减法 计算 格式化时间

    Date.prototype.Format = function (fmt) { var o = { "M+": this.getMonth() + 1, //月份 "d ...

  9. pandas DataFrame 数据处理常用操作

    Xgboost调参: https://wuhuhu800.github.io/2018/02/28/XGboost_param_share/ https://blog.csdn.net/hx2017/ ...

  10. 打败 IE 的葵花宝典:CSS Bug Table

    博主说:本博客文章来源包括转载,翻译,原创,且在文章内均有标明.鼓励原创,支持创作共享,请勿用于商业用途,转载请注明文章链接.本文链接:http://www.kein.pw/?p=35 原文发表于:A ...