Background.js 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. import DataMap from './DataMap.js';
  2. import Color4 from './Color4.js';
  3. import { vec4, context, normalWorld, backgroundBlurriness, backgroundIntensity, NodeMaterial, modelViewProjection } from '../../nodes/Nodes.js';
  4. import { Mesh } from '../../objects/Mesh.js';
  5. import { SphereGeometry } from '../../geometries/SphereGeometry.js';
  6. import { BackSide, LinearSRGBColorSpace } from '../../constants.js';
  7. const _clearColor = /*@__PURE__*/ new Color4();
  8. class Background extends DataMap {
  9. constructor( renderer, nodes ) {
  10. super();
  11. this.renderer = renderer;
  12. this.nodes = nodes;
  13. }
  14. update( scene, renderList, renderContext ) {
  15. const renderer = this.renderer;
  16. const background = this.nodes.getBackgroundNode( scene ) || scene.background;
  17. let forceClear = false;
  18. if ( background === null ) {
  19. // no background settings, use clear color configuration from the renderer
  20. renderer._clearColor.getRGB( _clearColor, LinearSRGBColorSpace );
  21. _clearColor.a = renderer._clearColor.a;
  22. } else if ( background.isColor === true ) {
  23. // background is an opaque color
  24. background.getRGB( _clearColor, LinearSRGBColorSpace );
  25. _clearColor.a = 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. let backgroundMesh = sceneData.backgroundMesh;
  32. if ( backgroundMesh === undefined ) {
  33. const backgroundMeshNode = context( vec4( backgroundNode ).mul( backgroundIntensity ), {
  34. // @TODO: Add Texture2D support using node context
  35. getUV: () => normalWorld,
  36. getTextureLevel: () => backgroundBlurriness
  37. } );
  38. let viewProj = modelViewProjection();
  39. viewProj = viewProj.setZ( viewProj.w );
  40. const nodeMaterial = new NodeMaterial();
  41. nodeMaterial.name = 'Background.material';
  42. nodeMaterial.side = BackSide;
  43. nodeMaterial.depthTest = false;
  44. nodeMaterial.depthWrite = false;
  45. nodeMaterial.fog = false;
  46. nodeMaterial.lights = false;
  47. nodeMaterial.vertexNode = viewProj;
  48. nodeMaterial.colorNode = backgroundMeshNode;
  49. sceneData.backgroundMeshNode = backgroundMeshNode;
  50. sceneData.backgroundMesh = backgroundMesh = new Mesh( new SphereGeometry( 1, 32, 32 ), nodeMaterial );
  51. backgroundMesh.frustumCulled = false;
  52. backgroundMesh.name = 'Background.mesh';
  53. backgroundMesh.onBeforeRender = function ( renderer, scene, camera ) {
  54. this.matrixWorld.copyPosition( camera.matrixWorld );
  55. };
  56. }
  57. const backgroundCacheKey = backgroundNode.getCacheKey();
  58. if ( sceneData.backgroundCacheKey !== backgroundCacheKey ) {
  59. sceneData.backgroundMeshNode.node = vec4( backgroundNode ).mul( backgroundIntensity );
  60. backgroundMesh.material.needsUpdate = true;
  61. sceneData.backgroundCacheKey = backgroundCacheKey;
  62. }
  63. renderList.unshift( backgroundMesh, backgroundMesh.geometry, backgroundMesh.material, 0, 0, null );
  64. } else {
  65. console.error( 'THREE.Renderer: Unsupported background configuration.', background );
  66. }
  67. //
  68. if ( renderer.autoClear === true || forceClear === true ) {
  69. _clearColor.multiplyScalar( _clearColor.a );
  70. const clearColorValue = renderContext.clearColorValue;
  71. clearColorValue.r = _clearColor.r;
  72. clearColorValue.g = _clearColor.g;
  73. clearColorValue.b = _clearColor.b;
  74. clearColorValue.a = _clearColor.a;
  75. renderContext.depthClearValue = renderer._clearDepth;
  76. renderContext.stencilClearValue = renderer._clearStencil;
  77. renderContext.clearColor = renderer.autoClearColor === true;
  78. renderContext.clearDepth = renderer.autoClearDepth === true;
  79. renderContext.clearStencil = renderer.autoClearStencil === true;
  80. } else {
  81. renderContext.clearColor = false;
  82. renderContext.clearDepth = false;
  83. renderContext.clearStencil = false;
  84. }
  85. }
  86. }
  87. export default Background;