Three.js利用Detector.js插件如何实现兼容性检测详解
2017-09-26 08:59
1001 查看
前言
本文主要给大家介绍了关于Three.js用Detector.js插件实现兼容性检测的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。
其实Detector.js插件的代码很短,但是功能很全,
(1)判断canvas兼容。
(2)判断webgl兼容性。
(3)在页面添加不兼容提示信息。
这三个功能已经对兼容性检测足够了。
使用方式也很简单:
首先,将插件引入到页面:
<script src="examples/js/Detector.js"></script>
然后,在js里面添加一个判断:
if ( ! Detector.webgl ) Detector.addGetWebGLMessage();
就实现了兼容性的检测,是不是很简单,去测试一下吧。
下面,附上Detector.js插件代码:
/** * @author alteredq / http://alteredqualia.com/ * @author mr.doob / http://mrdoob.com/ */ var Detector = { canvas: !! window.CanvasRenderingContext2D, webgl: ( function () { try { var canvas = document.createElement( 'canvas' ); return !! ( window.WebGLRenderingContext && ( canvas.getContext( 'webgl' ) || canvas.getContext( 'experimental-webgl' ) ) ); } catch ( e ) { return false; } } )(), workers: !! window.Worker, fileapi: window.File && window.FileReader && window.FileList && window.Blob, getWebGLErrorMessage: function () { var element = document.createElement( 'div' ); element.id = 'webgl-error-message'; element.style.fontFamily = 'monospace'; element.style.fontSize = '13px'; element.style.fontWeight = 'normal'; element.style.textAlign = 'center'; element.style.background = '#fff'; element.style.color = '#000'; element.style.padding = '1.5em'; element.style.width = '400px'; element.style.margin = '5em auto 0'; if ( ! this.webgl ) { element.innerHTML = window.WebGLRenderingContext ? [ 'Your graphics card does not seem to support <a href="http://khronos.org/webgl/wiki/Getting_a_WebGL_Implementation" rel="external nofollow" rel="external nofollow" style="color:#000">WebGL</a>.<br />', 'Find out how to get it <a href="http://get.webgl.org/" rel="external nofollow" rel="external nofollow" style="color:#000">here</a>.' ].join( '\n' ) : [ 'Your browser does not seem to support <a href="http://khronos.org/webgl/wiki/Getting_a_WebGL_Implementation" rel="external nofollow" rel="external nofollow" style="color:#000">WebGL</a>.<br/>', 'Find out how to get it <a href="http://get.webgl.org/" rel="external nofollow" rel="external nofollow" style="color:#000">here</a>.' ].join( '\n' ); } return element; }, addGetWebGLMessage: function ( parameters ) { var parent, id, element; parameters = parameters || {}; parent = parameters.parent !== undefined ? parameters.parent : document.body; id = parameters.id !== undefined ? parameters.id : 'oldie'; element = Detector.getWebGLErrorMessage(); element.id = id; parent.appendChild( element ); } }; // browserify support if ( typeof module === 'object' ) { module.exports = Detector; }
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
您可能感兴趣的文章:
相关文章推荐
- 11 Three.js使用Detector.js插件实现兼容性检测
- Three.js如何用轨迹球插件(trackball)增加对模型的交互功能详解
- Three.js利用性能插件stats实现性能监听的方法
- Three.js利用dat.GUI如何简化试验流程详解
- 利用Three.js如何实现阴影效果实例代码
- node.js下如何利用jqpaginator插件实现ajax分页
- Three.js利用orbit controls插件(轨道控制)控制模型交互动作详解
- vue2利用Bus.js如何实现非父子组件通信详解
- React利用插件和不用插件实现双向绑定的方法详解
- JSP中如何利用JS实现登录页面的跳转(JSP中如何利用JS实现跳转页面)
- 如何实现星星评价(jquery.raty.js插件)
- 如何利用js操作cookie实现记住密码功能
- 拷贝到剪切板——一个flash实现、兼容性不错的js插件ZeroClipboard
- JS中如何实现Laravel的route函数详解
- 关于如何使用js 插件实现打印的功能
- 利用fullpage.js插件实现全屏滚动
- vue.js内部自定义指令与全局自定义指令的实现详解(利用directive)
- 利用FullPage.js实现全屏滚动插件
- 利用jquery-fform.js插件实现图片所见即所得效果
- 利用jQuery的ResourceLoader插件实现JS和CSS脚本的动态按需加载