腹黑的消炎药 · python使用openpyxl清空表格 ...· 3 月前 · |
发呆的小蝌蚪 · MySQL误删数据后,查找操作日志并恢复数据 ...· 1 年前 · |
飘逸的地瓜 · HostName Class ...· 1 年前 · |
低调的镜子 · SonarScanner扫描Maven项目使 ...· 1 年前 · |
我想让双色渐变透明。在下面的图片中你可以看到。
左边是最后一个网格,右边是一个单一的面。我试着用一个顶点着色器和一个片段着色器来实现这一点。但不幸的是,我搞不懂。希望有人能帮我
到目前为止,我有这样的看法:
var custom3Material = new this.$three.ShaderMaterial({
uniforms: {
vlak3color1: { value: new this.$three.Color('#31c7de')},
vlak3color2: {type: 'vec2', value: new this.$three.Color('#de3c31')},
positionVlak3: {value: -3.5},
vertexShader: `
varying vec3 vUv;
void main() {
vUv = position;
gl_Position = projectionMatrix * modelViewMatrix * vec4(position,1.0);
fragmentShader: `
uniform vec3 vlak3color1;
uniform vec3 vlak3color2;
uniform float positionVlak3;
varying vec3 vUv;
void main() {
gl_FragColor = vec4(mix(vlak3color1, vlak3color2, vUv.y-positionVlak3), 1);
});
我希望以后能调整两种颜色之间的位置和透明度。
提前感谢!
发布于 2020-07-29 20:47:50
attributes.
vlak3color2: {type: 'vec2', value: new this.$three.Color('#de3c31')}
transparent: true
添加到它的
transparent: true
来使您的材料变得透明,这是令人困惑的。你为什么要做一个
vec2
类型的颜色?只要摆脱这种类型,你就不需要了。当Three.js看到它是一个颜色时,它会自动识别这个类型。
,
gl_FragColor
的第四个值是alpha。现在你把它设置为一个常数
1
,所以你得到了一个完全不透明的颜色。尝试用
smoothstep()
使它从0-1褪色。
void main() {
// y < 0 = transparent, > 1 = opaque
float alpha = smoothstep(0.0, 1.0, vUv.y);