Detector.js 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. /**
  2. * @author alteredq / http://alteredqualia.com/
  3. * @author mr.doob / http://mrdoob.com/
  4. */
  5. var Detector = {
  6. canvas: !! window.CanvasRenderingContext2D,
  7. webgl: ( function () {
  8. try {
  9. var canvas = document.createElement( 'canvas' ); return !! ( window.WebGLRenderingContext && ( canvas.getContext( 'webgl' ) || canvas.getContext( 'experimental-webgl' ) ) );
  10. } catch ( e ) {
  11. return false;
  12. }
  13. } )(),
  14. webgl2: ( function () {
  15. try {
  16. var canvas = document.createElement( 'canvas' ); return !! ( window.WebGL2RenderingContext && ( canvas.getContext( 'webgl2' ) ) );
  17. } catch ( e ) {
  18. return false;
  19. }
  20. } )(),
  21. workers: !! window.Worker,
  22. fileapi: window.File && window.FileReader && window.FileList && window.Blob,
  23. getWebGLErrorMessage: function () {
  24. var element = document.createElement( 'div' );
  25. element.id = 'webgl-error-message';
  26. element.style.fontFamily = 'monospace';
  27. element.style.fontSize = '13px';
  28. element.style.fontWeight = 'normal';
  29. element.style.textAlign = 'center';
  30. element.style.background = '#fff';
  31. element.style.color = '#000';
  32. element.style.padding = '1.5em';
  33. element.style.width = '400px';
  34. element.style.margin = '5em auto 0';
  35. if ( ! this.webgl ) {
  36. element.innerHTML = window.WebGLRenderingContext ? [
  37. 'Your graphics card does not seem to support <a href="http://khronos.org/webgl/wiki/Getting_a_WebGL_Implementation" style="color:#000">WebGL</a>.<br />',
  38. 'Find out how to get it <a href="http://get.webgl.org/" style="color:#000">here</a>.'
  39. ].join( '\n' ) : [
  40. 'Your browser does not seem to support <a href="http://khronos.org/webgl/wiki/Getting_a_WebGL_Implementation" style="color:#000">WebGL</a>.<br/>',
  41. 'Find out how to get it <a href="http://get.webgl.org/" style="color:#000">here</a>.'
  42. ].join( '\n' );
  43. }
  44. return element;
  45. },
  46. addGetWebGLMessage: function ( parameters ) {
  47. var parent, id, element;
  48. parameters = parameters || {};
  49. parent = parameters.parent !== undefined ? parameters.parent : document.body;
  50. id = parameters.id !== undefined ? parameters.id : 'oldie';
  51. element = Detector.getWebGLErrorMessage();
  52. element.id = id;
  53. parent.appendChild( element );
  54. }
  55. };
  56. // browserify support
  57. if ( typeof module === 'object' ) {
  58. module.exports = Detector;
  59. }