Skip to content

Commit

Permalink
Update 4.5.8
Browse files Browse the repository at this point in the history
  • Loading branch information
nimadez committed Nov 19, 2024
1 parent d98b011 commit cd39cca
Show file tree
Hide file tree
Showing 11 changed files with 46 additions and 36 deletions.
6 changes: 3 additions & 3 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "voxel-builder",
"version": "4.5.7",
"version": "4.5.8",
"description": "Voxel-based 3D modeling application",
"main": "electron.js",
"scripts": {
Expand All @@ -11,9 +11,9 @@
"license": "MIT",
"devDependencies": {
"electron": "^30.0.0",
"babylonjs": "^7.32.0",
"babylonjs": "^7.33.0",
"three": "^0.170.0",
"three-mesh-bvh": "^0.8.2",
"three-mesh-bvh": "^0.8.3",
"three-gpu-pathtracer": "^0.0.23",
"@tweenjs/tween.js": "^25.0.0"
}
Expand Down
15 changes: 8 additions & 7 deletions src/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
<meta name="description" content="Voxel-based 3D modeling application for desktop and mobile browsers">
<meta name="keywords" content="model, render, export, bake, electron, terrain, modeling, voxelizer, painting, symmetry, three-js, voxels, gltf, magicavoxel, voxel-generator, voxelization, babylon-js, three-mesh-bvh, three-gpu-pathtracer">
<meta name="author" content="@nimadez">
<meta name="twitter:card" content="summary">
<meta name="twitter:site" content="@nimadez">
Expand Down Expand Up @@ -83,7 +84,7 @@
ul { list-style-type: none; }
ul li { font-family: var(--font); font-size: var(--font-size); color: var(--btn-color); border-radius: 2px; text-align: center; }
ul li:hover, .tool_selector, .tool_mesh_selector { background: orange; color: #444; box-shadow: inset 10px 10px 10px var(--btn-shadow); }
#introscreen { z-index: 99999; display: unset; background: #1C2128; position: absolute; width: 100%; height: 100%; }
#introscreen { z-index: 99999; display: unset; position: absolute; width: 100%; height: 100%; }
#introscreen .logo { width: fit-content; padding: 10px 15px 10px 15px; position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); border-radius: 10px; text-align: center; }
#introscreen .logo img { width: 192px; height: 192px; image-rendering: optimizeQuality; }
#canvas { z-index: 0; pointer-events: none; background: #3c4253; position: absolute; width: 100%; height: 100%; }
Expand Down Expand Up @@ -159,7 +160,7 @@
#menu-inscreen-export button { width: 68px; height: 32px; font-size: 11px; }
#colorpicker { z-index: 500; width: 45px; height: 32px; }
#colorpicker :first-child { height: 32px; }
#info { z-index: 2; display: none; color: var(--info-color); letter-spacing: 0.06em; text-shadow: var(--text-shadow); font-size: 10px; position: absolute; padding: 2px; width: 100%; bottom: 2px; text-align: center; pointer-events: none; }
#info { z-index: 2; display: none; color: var(--info-color); letter-spacing: 0.06em; text-shadow: var(--text-shadow); font-size: 10px; position: absolute; margin-bottom: 2px; width: 100%; bottom: 2px; text-align: center; pointer-events: none; }
#info_tool { z-index: 2; display: none; opacity: 0.8; color: var(--info-color); letter-spacing: 0.06em; text-shadow: var(--text-shadow); font-size: 10px; position: absolute; padding: 2px; width: auto; top: 47px; left: 50%; transform: translateX(-50%); text-align: center; text-transform: uppercase; pointer-events: none; }
#info_render { z-index: 301; display: none; color: var(--info-color); letter-spacing: 0.06em; text-shadow: var(--text-shadow); font-size: 10px; position: absolute; padding: 2px; width: 100%; bottom: 2px; text-align: center; pointer-events: none; }
#progressbar { z-index: 2000; background: linear-gradient(90deg, orange, orange, orange, white); width: 0; max-width: 100%; height: 3px; bottom: 0; position: fixed; }
Expand All @@ -182,7 +183,7 @@
.row_input { display: flex; width: 100%; gap: 5px; align-items: center; }
.row_input :first-child { width: 100%; }
.row_panel { display: flex; width: 100%; height: 25px; align-items: center; gap: 0; }
.row_panel div { width: 31px; padding: 5px; text-align: center; }
.row_panel div { width: 100%; padding: 5px; text-align: center; }
.row_panel:hover { box-shadow: none; }
.material-icons { font-family: 'Material Icons'; font-weight: normal; font-style: normal; font-size: 16px; vertical-align: middle; text-align: center; line-height: 1; letter-spacing: normal; text-transform: none; display: inline-block; white-space: nowrap; word-wrap: normal; direction: ltr; pointer-events: none; font-feature-settings: 'liga'; -webkit-font-feature-settings: 'liga'; -webkit-font-smoothing: antialiased; }
::placeholder { color: #45515c; }
Expand Down Expand Up @@ -275,7 +276,7 @@
<li class="spacer"></li>
<li class="about">
VOXEL BUILDER
<br>&#8627; 4.5.7 Beta
<br>&#8627; 4.5.8 Beta
<br>&#8627; <a href="https://github.com/nimadez/voxel-builder/">GitHub</a>
<br>&#8627; <a href="https://github.com/nimadez/voxel-builder/releases">Changelog</a>
<br>Developer
Expand Down Expand Up @@ -415,7 +416,7 @@
<li class="category">MATERIAL</li>
<li class="row_input"><label for="input-pt-roughness">Roughness</label> <input id="input-pt-roughness" class="ignorekeys" type="number" value="0.8" min="0" step="0.01"></input></li>
<li class="row_input"><label for="input-pt-metalness" style="margin-right: 4px">Metalness</label> <input id="input-pt-metalness" class="ignorekeys" type="number" value="0" min="0" step="0.01"></input></li>
<li class="row_input"><label for="input-pt-transmission">Transmiss.</label> <input id="input-pt-transmission" class="ignorekeys" type="number" value="0" min="0" step="0.01"></input></li>
<li class="row_input"><label for="input-pt-transmission" style="font-size: 10px; margin-right: -1px">Transmission</label> <input id="input-pt-transmission" class="ignorekeys" type="number" value="0" min="0" step="0.01"></input></li>
<li class="row_input" title="Black voxels are emissive"><label style="margin-right: 5px">Emissive</label> <input type="color" id="input-pt-emissive" value="#5EC3C5"></li>
<li class="spacer"></li>
<li class="row_input">
Expand Down Expand Up @@ -534,7 +535,7 @@
<li><button id="btn_tool_bucket" class="tool_bucket">Bucket</button></li>
<li><button id="paint_all">Paint All</button></li>
<li class="category">PICK COLOR</li>
<li><button id="btn_tool_eyedrop" class="tool_eyedrop">Eyedropper</button></li>
<li><button id="btn_tool_eyedropper" class="tool_eyedropper">Eyedropper</button></li>
</ul>

<ul class="menu_L panel" id="menu-voxels">
Expand Down Expand Up @@ -631,7 +632,7 @@
<ul id="menu-inscreen-right">
<li id="colorpicker"><input type="color" id="input-color" value="#4674A4"></li>
<li><button id="btn_tool_bucket_inscreen" class="tool_bucket" title="Bucket Tool"><i class="material-icons">format_color_fill</i></button></li>
<li><button id="btn_tool_eyedrop_inscreen" class="tool_eyedrop" title="Eyedropper Tool"><i class="material-icons">colorize</i></button></li>
<li><button id="btn_tool_eyedrop_inscreen" class="tool_eyedropper" title="Eyedropper Tool"><i class="material-icons">colorize</i></button></li>
<li><button id="material-switch" title="Material Switch">CEL</button></li>
</ul>

Expand Down
2 changes: 1 addition & 1 deletion src/libs/babylon.gui.min.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion src/libs/babylon.inspector.bundle.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion src/libs/babylon.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion src/libs/babylonjs.loaders.min.js

Large diffs are not rendered by default.

7 changes: 4 additions & 3 deletions src/libs/three-mesh-bvh.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion src/main.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ const adapter = navigator.gpu && await navigator.gpu.requestAdapter();

CORE.preferences.init(adapter);

engine.init(CORE.preferences.isWebGPU()).then(eng => {
engine.init(adapter && CORE.preferences.isWebGPU()).then(eng => {

CORE.mainScene.create(eng).then(scn => {

Expand Down
31 changes: 17 additions & 14 deletions src/modules/core.js
Original file line number Diff line number Diff line change
Expand Up @@ -1700,7 +1700,8 @@ class MeshPool {
this.meshListSelect(mesh);
this.getMaterial();
helper.showBoundingBox(this.selected);
helper.highlightOutlineMesh(this.selected, COL_ORANGE_RGB);
if (!engine.engine.isWebGPU)
helper.highlightOutlineMesh(this.selected, COL_ORANGE_RGB);
}

deselectMesh() {
Expand Down Expand Up @@ -2352,7 +2353,7 @@ class Helper {
}

setBoxShapeSymmetry(pos, scale, color) {
this.boxShapeSymm.isVisible = true;
this.boxShapeSymm.isVisible = ui.domSymmPreview.checked;
this.boxShapeSymm.position = pos;
this.boxShapeSymm.scaling = scale;
this.boxShapeSymm.overlayColor = color;
Expand Down Expand Up @@ -2693,7 +2694,7 @@ class Tool {
}
}

eyedrop(hex) {
eyedropper(hex) {
currentColor = hex;
uix.colorPicker.value = color3FromHex(currentColor);
}
Expand All @@ -2718,7 +2719,7 @@ class Tool {
helper.setBoxShape(start.add(end).divide(VEC3_TWO), scale, color, this.boxCount < MAX_VOXELS_DRAW);
this.boxCount = helper.boxShape.scaling.x * helper.boxShape.scaling.y * helper.boxShape.scaling.z;

if (this.isSymmetry && ui.domSymmPreview.checked) {
if (this.isSymmetry) {
helper.setBoxShapeSymmetry(
symmetry.invertPos(start).add(symmetry.invertPos(end)).divide(VEC3_TWO),
scale, color);
Expand Down Expand Up @@ -2879,8 +2880,8 @@ class Tool {
case 'paint':
this.paint(index, this.pos);
break;
case 'eyedrop':
this.eyedrop(builder.voxels[index].color);
case 'eyedropper':
this.eyedropper(builder.voxels[index].color);
break;
case 'bucket':
this.bucket(builder.voxels[index].color);
Expand Down Expand Up @@ -2989,8 +2990,8 @@ class Tool {
case 'paint':
this.paint(index, this.pos);
break;
case 'eyedrop':
this.eyedrop(builder.voxels[index].color);
case 'eyedropper':
this.eyedropper(builder.voxels[index].color);
break;
case 'box_add':
if (this.startBox)
Expand Down Expand Up @@ -3535,7 +3536,7 @@ class Project {

serializeScene(voxels) {
const json = {
version: "Voxel Builder 4.5.7",
version: "Voxel Builder 4.5.8",
project: {
name: "name",
voxels: builder.voxels.length
Expand Down Expand Up @@ -4709,16 +4710,18 @@ class UserInterface {
item.style.display = 'none';
this.domToolbarL.children[0].style.display = 'unset';
this.domToolbarL.children[1].style.display = 'unset';
this.domToolbarL.children[2].style.display = 'unset';
this.domToolbarL.children[3].style.display = 'unset';

this.domMenuInScreenStore.style.display = 'flex';
this.domMenuInScreenRight.style.display = 'flex';
this.domMenuInScreenRight.children[3].style.opacity = '0.5';
this.domMenuInScreenRight.children[3].style.pointerEvents = 'none';
this.domMenuInScreenBottom.style.display = 'flex';
this.domMenuInScreenBottom.style.gap = '5px';
this.domMenuInScreenBottom.children[1].style.display = 'none';
this.domMenuInScreenBottom.children[2].style.display = 'none';

this.domMenuInScreenBottom.children[4].style.display = 'none';

this.domInfo[3].style.display = 'none';
this.domInfoParent.innerHTML = '&nbsp;' + this.domInfoParent.innerHTML;

Expand Down Expand Up @@ -5286,7 +5289,7 @@ document.addEventListener("keydown", (ev) => {
tool.toolSelector('bucket', true);
break;
case '8':
tool.toolSelector('eyedrop', true);
tool.toolSelector('eyedropper', true);
break;
case 't':
tool.toolSelector('transform_box', true);
Expand Down Expand Up @@ -5508,7 +5511,7 @@ ui.domMenuInScreenRight.children[1].onclick = () => {

ui.domMenuInScreenRight.children[2].onclick = () => {
if (ui.checkMode(0))
tool.toolSelector('eyedrop', true);
tool.toolSelector('eyedropper', true);
};

ui.domMenuInScreenRight.children[3].onclick = () => {
Expand Down Expand Up @@ -5854,7 +5857,7 @@ document.getElementById('btn_tool_box_paint').onclick = () => { if (ui.che
document.getElementById('btn_tool_rect_paint').onclick = () => { if (ui.checkMode(0)) tool.toolSelector('rect_paint') };
document.getElementById('btn_tool_bucket').onclick = () => { if (ui.checkMode(0)) tool.toolSelector('bucket') };
document.getElementById('paint_all').onclick = () => { if (ui.checkMode(0)) builder.setAllColorsAndUpdate() };
document.getElementById('btn_tool_eyedrop').onclick = () => { if (ui.checkMode(0)) tool.toolSelector('eyedrop') };
document.getElementById('btn_tool_eyedropper').onclick = () => { if (ui.checkMode(0)) tool.toolSelector('eyedropper') };
document.getElementById('btn_tool_transform_box').onclick = () => { if (ui.checkMode(0)) tool.toolSelector('transform_box') };
document.getElementById('btn_tool_transform_rect').onclick = () => { if (ui.checkMode(0)) tool.toolSelector('transform_rect') };
document.getElementById('btn_tool_transform_group').onclick = () => { if (ui.checkMode(0)) tool.toolSelector('transform_group') };
Expand Down
9 changes: 7 additions & 2 deletions src/modules/interfaces/panels.js
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,13 @@ class Panels {
};

div_reset.onclick = () => {
this.panels.forEach(panel => {
if (!panel.detach && panel.x == 0 && panel.y == 0) {
panel.elem.style.display = 'none';
if (panel.button)
panel.button.style.textDecoration = 'none';
}
});
this.resetPanel(idx);
};

Expand Down Expand Up @@ -177,9 +184,7 @@ class Panels {
this.panels[idx].elem.style.borderRadius = '3px';
this.panels[idx].elem.style.borderTopLeftRadius = '0';
this.panels[idx].elem.style.borderTopRightRadius = '0';
this.panels[idx].elem.style.display = 'none';
this.panels[idx].elem.style.zIndex = 1000;
this.panels[idx].button.style.textDecoration = 'none';
}

setTranslate(idx, x, y) {
Expand Down
4 changes: 2 additions & 2 deletions src/modules/sandbox/sandbox.js
Original file line number Diff line number Diff line change
Expand Up @@ -558,8 +558,8 @@ class PathTracer {
constructor() {
this.pt = new WebGLPathTracer(renderer);
this.pt.bounces = 1;
this.pt.renderDelay = 300;
this.pt.fadeDuration = 300;
this.pt.renderDelay = 100;
this.pt.fadeDuration = 250;
this.pt.minSamples = 1;
this.pt.renderToCanvas = true;
this.pt.textureSize = new THREE.Vector2(512, 512);
Expand Down

0 comments on commit cd39cca

Please sign in to comment.