@@ -17,15 +17,20 @@ import {
17
17
NodeOperation
18
18
} from '../NodeMesh' ;
19
19
20
+ import {
21
+ getColorMapTexture
22
+ } from '../utils/colormaps' ;
23
+
20
24
21
25
export
22
26
class IsoColor extends Effect {
23
27
24
- constructor ( parent : Block , input : Input , min : number , max : number ) {
28
+ constructor ( parent : Block , input : Input , min : number , max : number , colorMap : string = 'Black-Body Radiation' ) {
25
29
super ( parent , input ) ;
26
30
27
- const textureLoader = new THREE . TextureLoader ( ) ;
28
- this . textureNode = new Nodes . TextureNode ( textureLoader . load ( '' ) ) ;
31
+ this . texture = getColorMapTexture ( colorMap ) ;
32
+
33
+ this . textureNode = new Nodes . TextureNode ( this . texture ) ;
29
34
30
35
const functionNode = new Nodes . FunctionNode (
31
36
`vec3 isoColorFunc${ this . id } (sampler2D textureMap, float min, float max, float data){
@@ -82,13 +87,19 @@ class IsoColor extends Effect {
82
87
return 1 ;
83
88
}
84
89
90
+ set colorMap ( colorMap : string ) {
91
+ this . texture = getColorMapTexture ( colorMap ) ;
92
+ this . textureNode . value = this . texture ;
93
+ }
94
+
85
95
private initialized : boolean = false ;
86
96
87
97
private functionCallNode : Nodes . FunctionCallNode ;
88
98
89
99
private minNode : Nodes . FloatNode ;
90
100
private maxNode : Nodes . FloatNode ;
91
101
102
+ private texture : THREE . DataTexture ;
92
103
private textureNode : Nodes . TextureNode ;
93
104
94
105
protected inputs : [ Component ] ;
0 commit comments