mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-11 23:06:51 +01:00
combine boolean
This commit is contained in:
parent
73d155674b
commit
7a692822b3
3 changed files with 82 additions and 37 deletions
Binary file not shown.
|
@ -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;
|
||||||
|
|
|
@ -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,16 +535,18 @@ 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;
|
||||||
|
|
||||||
for(int i = 0; i < opLength; i++) {
|
for(int i = 0; i < opLength; i++) {
|
||||||
opr = operations[i];
|
opr = operations[i];
|
||||||
|
@ -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) {
|
||||||
|
@ -636,7 +656,22 @@ float march(vec3 camera, vec3 direction, out vec3 blendIndx) {
|
||||||
return viewRange.y;
|
return viewRange.y;
|
||||||
}
|
}
|
||||||
|
|
||||||
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) {
|
||||||
|
@ -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));
|
|
||||||
mat3 rotMatrix = rx * ry * rz;
|
|
||||||
mat3 irotMatrix = inverse(rotMatrix);
|
|
||||||
|
|
||||||
vec3 c0 = useTexture[idx0] == 1?
|
float totalInfluences = 0.;
|
||||||
boxmap(int(TEXTURE_S) + idx0, irotMatrix * coll * textureScale[idx0], irotMatrix * norm, triplanar[idx0]).rgb * diffuseColor[idx0].rgb :
|
for(int i = 0; i < shapeAmount; i++)
|
||||||
diffuseColor[idx0].rgb;
|
totalInfluences += influences[i];
|
||||||
|
|
||||||
vec3 c1 = useTexture[idx1] == 1?
|
vec3 c = vec3(0.);
|
||||||
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);
|
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 irotMatrix = inverse(rotMatrix);
|
||||||
|
|
||||||
|
vec3 _c = useTexture[i] == 1?
|
||||||
|
boxmap(int(TEXTURE_S) + i, irotMatrix * coll * textureScale[i], irotMatrix * norm, triplanar[i]).rgb * diffuseColor[i].rgb :
|
||||||
|
diffuseColor[i].rgb;
|
||||||
|
|
||||||
|
c += _c * (influences[i] / totalInfluences);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue