Background.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. import DataMap from './DataMap.js';
  2. import { Color, Mesh, BoxGeometry, BackSide } from 'three';
  3. import { context, positionWorldDirection, MeshBasicNodeMaterial } from '../../nodes/Nodes.js';
  4. let _clearAlpha;
  5. const _clearColor = new Color();
  6. class Background extends DataMap {
  7. constructor( renderer, nodes ) {
  8. super();
  9. this.renderer = renderer;
  10. this.nodes = nodes;
  11. this.boxMesh = null;
  12. this.boxMeshNode = null;
  13. }
  14. update( scene, renderList, renderContext ) {
  15. const renderer = this.renderer;
  16. const background = ( scene.isScene === true ) ? this.nodes.getBackgroundNode( scene ) || scene.background : null;
  17. let forceClear = false;
  18. if ( background === null ) {
  19. // no background settings, use clear color configuration from the renderer
  20. _clearColor.copy( renderer._clearColor );
  21. _clearAlpha = renderer._clearAlpha;
  22. } else if ( background.isColor === true ) {
  23. // background is an opaque color
  24. _clearColor.copy( background );
  25. _clearAlpha = 1;
  26. forceClear = true;
  27. } else if ( background.isNode === true ) {
  28. const sceneData = this.get( scene );
  29. const backgroundNode = background;
  30. _clearColor.copy( renderer._clearColor );
  31. _clearAlpha = renderer._clearAlpha;
  32. let boxMesh = this.boxMesh;
  33. if ( boxMesh === null ) {
  34. this.boxMeshNode = context( backgroundNode, {
  35. // @TODO: Add Texture2D support using node context
  36. getUVNode: () => positionWorldDirection
  37. } );
  38. const nodeMaterial = new MeshBasicNodeMaterial();
  39. nodeMaterial.colorNode = this.boxMeshNode;
  40. nodeMaterial.side = BackSide;
  41. nodeMaterial.depthTest = false;
  42. nodeMaterial.depthWrite = false;
  43. nodeMaterial.fog = false;
  44. this.boxMesh = boxMesh = new Mesh( new BoxGeometry( 1, 1, 1 ), nodeMaterial );
  45. boxMesh.frustumCulled = false;
  46. boxMesh.onBeforeRender = function ( renderer, scene, camera ) {
  47. const scale = camera.far;
  48. this.matrixWorld.makeScale( scale, scale, scale ).copyPosition( camera.matrixWorld );
  49. };
  50. }
  51. const backgroundCacheKey = backgroundNode.getCacheKey();
  52. if ( sceneData.backgroundCacheKey !== backgroundCacheKey ) {
  53. this.boxMeshNode.node = backgroundNode;
  54. boxMesh.material.needsUpdate = true;
  55. sceneData.backgroundCacheKey = backgroundCacheKey;
  56. }
  57. renderList.unshift( boxMesh, boxMesh.geometry, boxMesh.material, 0, 0, null );
  58. } else {
  59. console.error( 'THREE.Renderer: Unsupported background configuration.', background );
  60. }
  61. //
  62. if ( renderer.autoClear === true || forceClear === true ) {
  63. _clearColor.multiplyScalar( _clearAlpha );
  64. const clearColorValue = renderContext.clearColorValue;
  65. clearColorValue.r = _clearColor.r;
  66. clearColorValue.g = _clearColor.g;
  67. clearColorValue.b = _clearColor.b;
  68. clearColorValue.a = _clearAlpha;
  69. renderContext.depthClearValue = renderer._clearDepth;
  70. renderContext.stencilClearValue = renderer._clearStencil;
  71. renderContext.clearColor = renderer.autoClearColor === true;
  72. renderContext.clearDepth = renderer.autoClearDepth === true;
  73. renderContext.clearStencil = renderer.autoClearStencil === true;
  74. } else {
  75. renderContext.clearColor = false;
  76. renderContext.clearDepth = false;
  77. renderContext.clearStencil = false;
  78. }
  79. }
  80. }
  81. export default Background;