12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- /**
- * @author sunag / http://www.sunag.com.br/
- */
- import { TempNode } from '../core/TempNode.js';
- import { TextureCubeUVNode } from './TextureCubeUVNode.js';
-
- function TextureCubeNode( value, coord ) {
- TempNode.call( this, 'v4' );
- this.value = value;
- this.coord = coord || new TextureCubeUVNode();
- };
- TextureCubeNode.prototype = Object.create( TempNode.prototype );
- TextureCubeNode.prototype.constructor = TextureCubeNode;
- TextureCubeNode.prototype.nodeType = "TextureCube";
- TextureCubeNode.prototype.generate = function ( builder, output ) {
- if ( builder.isShader( 'fragment' ) ) {
- var uv_10 = this.coord.build( builder ) + '.uv_10',
- uv_20 = this.coord.build( builder ) + '.uv_20',
- t = this.coord.build( builder ) + '.t';
-
- var color10 = builder.getTexelDecodingFunctionFromTexture( 'texture2D( ' + this.value.build( builder, 'sampler2D' ) + ', ' + uv_10 + ' )', this.value.value ),
- color20 = builder.getTexelDecodingFunctionFromTexture( 'texture2D( ' + this.value.build( builder, 'sampler2D' ) + ', ' + uv_20 + ' )', this.value.value );
- return builder.format( 'vec4( mix( ' + color10 + ', ' + color20 + ', ' + t + ' ).rgb, 1.0 )', this.getType( builder ), output );
-
- } else {
- console.warn( "THREE.TextureCubeNode is not compatible with " + builder.shader + " shader." );
- return builder.format( 'vec4( 0.0 )', this.getType( builder ), output );
- }
- };
- TextureCubeNode.prototype.toJSON = function ( meta ) {
- var data = this.getJSONNode( meta );
- if ( ! data ) {
- data = this.createJSONNode( meta );
- data.coord = this.coord.toJSON( meta ).uuid;
- data.textureSize = this.textureSize.toJSON( meta ).uuid;
- data.blinnExponentToRoughness = this.blinnExponentToRoughness.toJSON( meta ).uuid;
- if ( this.roughness ) data.roughness = this.roughness.toJSON( meta ).uuid;
- }
- return data;
- };
- export { TextureCubeNode };
|