combine boolean

This commit is contained in:
Tanasart 2024-06-15 18:54:48 +07:00
parent 73d155674b
commit 7a692822b3
3 changed files with 82 additions and 37 deletions

Binary file not shown.

View file

@ -234,7 +234,7 @@ function value_color_bg_array(i) { #region
#bd4882, //dynaSurf #bd4882, //dynaSurf
#83839b, //PCX #83839b, //PCX
#3ca370, //audiobit #3ca370, //audiobit
#c1007c, //3D SDF #4b5bab, //3D SDF
]; ];
if(i == 99) return $5dde8f; if(i == 99) return $5dde8f;

View file

@ -87,6 +87,8 @@ uniform vec3 lightPosition;
uniform int useEnv; uniform int useEnv;
float influences[MAX_SHAPES];
#region ////========== Transform ============ #region ////========== Transform ============
mat3 rotateX(float dg) { mat3 rotateX(float dg) {
float c = cos(radians(dg)); float c = cos(radians(dg));
@ -533,14 +535,16 @@ float sceneSDF(int index, vec3 p) {
float operateSceneSDF(vec3 p, out vec3 blendIndx) { float operateSceneSDF(vec3 p, out vec3 blendIndx) {
blendIndx = vec3(0.); blendIndx = vec3(0.);
if(operations[0] == -1) if(operations[0] == -1) {
influences[0] = 1.;
return sceneSDF(0, p); return sceneSDF(0, p);
}
float depth[MAX_OP]; float depth[MAX_OP];
float index[MAX_OP]; int index[MAX_OP];
float d1, d2, o1, o2; float d1, d2, mrg;
float mrg; int o1, o2;
int top = 0; int top = 0;
int opr = 0; int opr = 0;
@ -550,7 +554,7 @@ float operateSceneSDF(vec3 p, out vec3 blendIndx) {
if(opr < 100) { if(opr < 100) {
depth[top] = sceneSDF(opr, p); depth[top] = sceneSDF(opr, p);
index[top] = float(opr); index[top] = opr;
top++; top++;
} else if(top >= 2) { } else if(top >= 2) {
@ -566,38 +570,48 @@ float operateSceneSDF(vec3 p, out vec3 blendIndx) {
if(d1 < d2) { if(d1 < d2) {
depth[top] = d1; depth[top] = d1;
index[top] = o1; index[top] = o1;
blendIndx.x = o1; blendIndx.x = float(o1);
blendIndx.z = 0.;
influences[o1] = 1.;
influences[o2] = 0.;
} else { } else {
depth[top] = d2; depth[top] = d2;
index[top] = o2; index[top] = o2;
blendIndx.x = o2; blendIndx.x = float(o2);
blendIndx.z = 0.;
influences[o1] = 0.;
influences[o2] = 1.;
} }
} else if(opr == 101) { } else if(opr == 101) {
vec2 m = smin(d1, d2, mrg); vec2 m = smin(d1, d2, mrg);
blendIndx.x = o1; blendIndx.x = float(o1);
blendIndx.y = o2; blendIndx.y = float(o2);
blendIndx.z = m.y; blendIndx.z = m.y;
influences[o1] = 1. - m.y;
influences[o2] = m.y;
depth[top] = m.x; depth[top] = m.x;
index[top] = d1 < d2? o1 : o2; index[top] = d1 < d2? o1 : o2;
} else if(opr == 102) { } else if(opr == 102) {
float m = opSmoothSubtraction(d1, d2, mrg); float m = opSmoothSubtraction(d1, d2, mrg);
blendIndx.x = o2; blendIndx.x = float(o2);
blendIndx.z = 0.;
influences[o1] = 0.;
depth[top] = m; depth[top] = m;
index[top] = o2; index[top] = o2;
} else if(opr == 103) { } else if(opr == 103) {
float m = opSmoothIntersection(d1, d2, mrg); float m = opSmoothIntersection(d1, d2, mrg);
blendIndx.x = o1; blendIndx.x = float(o1);
blendIndx.z = 0.;
influences[o1] = 1.;
influences[o2] = 0.;
depth[top] = m; depth[top] = m;
index[top] = o1; index[top] = o1;
@ -616,11 +630,17 @@ float operateSceneSDF(vec3 p, out vec3 blendIndx) {
vec3 normal(vec3 p) { vec3 normal(vec3 p) {
vec3 b; vec3 b;
return normalize(vec3( vec2 e = vec2(1.0, -1.0) * 0.0001;
operateSceneSDF(vec3(p.x + EPSILON, p.y, p.z), b) - operateSceneSDF(vec3(p.x - EPSILON, p.y, p.z), b), return normalize( e.xyy * operateSceneSDF( p + e.xyy, b ) +
operateSceneSDF(vec3(p.x, p.y + EPSILON, p.z), b) - operateSceneSDF(vec3(p.x, p.y - EPSILON, p.z), b), e.yyx * operateSceneSDF( p + e.yyx, b ) +
operateSceneSDF(vec3(p.x, p.y, p.z + EPSILON), b) - operateSceneSDF(vec3(p.x, p.y, p.z - EPSILON), b) e.yxy * operateSceneSDF( p + e.yxy, b ) +
)); e.xxx * operateSceneSDF( p + e.xxx, b ) );
// return normalize(vec3(
// operateSceneSDF(vec3(p.x + EPSILON, p.y, p.z), b) - operateSceneSDF(vec3(p.x - EPSILON, p.y, p.z), b),
// operateSceneSDF(vec3(p.x, p.y + EPSILON, p.z), b) - operateSceneSDF(vec3(p.x, p.y - EPSILON, p.z), b),
// operateSceneSDF(vec3(p.x, p.y, p.z + EPSILON), b) - operateSceneSDF(vec3(p.x, p.y, p.z - EPSILON), b)
// ));
} }
float march(vec3 camera, vec3 direction, out vec3 blendIndx) { float march(vec3 camera, vec3 direction, out vec3 blendIndx) {
@ -639,6 +659,21 @@ float march(vec3 camera, vec3 direction, out vec3 blendIndx) {
return viewRange.y; return viewRange.y;
} }
float marchLinear(vec3 camera, vec3 direction, out vec3 blendIndx) {
float st = 1. / float(MAX_MARCHING_STEPS);
for (int i = 0; i <= MAX_MARCHING_STEPS; i++) {
float depth = mix(viewRange.x, viewRange.y, float(i) * st);
vec3 pos = camera + depth * direction;
float hit = operateSceneSDF(pos, blendIndx);
if (hit <= 0.)
return depth;
}
return viewRange.y;
}
float marchDensity(vec3 camera, vec3 direction) { float marchDensity(vec3 camera, vec3 direction) {
float st = 1. / float(MAX_MARCHING_STEPS); float st = 1. / float(MAX_MARCHING_STEPS);
float dens = 0.; float dens = 0.;
@ -671,7 +706,7 @@ vec4 scene() {
vec2 cps = (v_vTexcoord - .5) * 2.; vec2 cps = (v_vTexcoord - .5) * 2.;
cps.x *= camRatio; cps.x *= camRatio;
vec3 dir = normalize(vec3(cps, -dz)); vec3 dir = vec3(cps, -dz);
vec3 eye = vec3(0., 0., 5.); vec3 eye = vec3(0., 0., 5.);
dir = normalize(camIrotMatrix * dir); dir = normalize(camIrotMatrix * dir);
@ -696,21 +731,31 @@ vec4 scene() {
if(depth > viewRange.y - EPSILON) // Not hitting anything. if(depth > viewRange.y - EPSILON) // Not hitting anything.
return vec4(0.); return vec4(0.);
rx = rotateX(mix(rotation[idx0].x, rotation[idx1].x, rat)); ///////////////////////////////////////////////////////////
ry = rotateY(mix(rotation[idx0].y, rotation[idx1].y, rat));
rz = rotateZ(mix(rotation[idx0].z, rotation[idx1].z, rat)); float totalInfluences = 0.;
for(int i = 0; i < shapeAmount; i++)
totalInfluences += influences[i];
vec3 c = vec3(0.);
if(totalInfluences > 0.) {
for(int i = 0; i < shapeAmount; i++) {
if(influences[i] == 0.) continue;
rx = rotateX(rotation[i].x);
ry = rotateY(rotation[i].y);
rz = rotateZ(rotation[i].z);
mat3 rotMatrix = rx * ry * rz; mat3 rotMatrix = rx * ry * rz;
mat3 irotMatrix = inverse(rotMatrix); mat3 irotMatrix = inverse(rotMatrix);
vec3 c0 = useTexture[idx0] == 1? vec3 _c = useTexture[i] == 1?
boxmap(int(TEXTURE_S) + idx0, irotMatrix * coll * textureScale[idx0], irotMatrix * norm, triplanar[idx0]).rgb * diffuseColor[idx0].rgb : boxmap(int(TEXTURE_S) + i, irotMatrix * coll * textureScale[i], irotMatrix * norm, triplanar[i]).rgb * diffuseColor[i].rgb :
diffuseColor[idx0].rgb; diffuseColor[i].rgb;
vec3 c1 = useTexture[idx1] == 1? c += _c * (influences[i] / totalInfluences);
boxmap(int(TEXTURE_S) + idx1, irotMatrix * coll * textureScale[idx1], irotMatrix * norm, triplanar[idx1]).rgb * diffuseColor[idx1].rgb : }
diffuseColor[idx1].rgb; }
vec3 c = mix(c0, c1, rat);
/////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////