This commit is contained in:
Sanford Pun
2020-10-25 14:51:19 +08:00
committed by Chris Tsang
parent 00375567cc
commit 1544f54b99
2 changed files with 444 additions and 444 deletions

View File

@@ -1,5 +1,5 @@
<!DOCTYPE html>
<html>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>VTracer</title>
@@ -182,4 +182,4 @@
</div>
<script src="./bootstrap.js"></script>
</body>
</html>
</html>

View File

@@ -1,20 +1,20 @@
import { BinaryImageConverter, ColorImageConverter } from 'vtracer';
import { BinaryImageConverter, ColorImageConverter } from 'vtracer';
let runner;
const canvas = document.getElementById('frame');
const ctx = canvas.getContext('2d');
const svg = document.getElementById('svg');
const img = new Image();
const progress = document.getElementById('progressbar');
const progressregion = document.getElementById('progressregion');
let mode = 'spline', clustering_mode = 'color';
let runner;
const canvas = document.getElementById('frame');
const ctx = canvas.getContext('2d');
const svg = document.getElementById('svg');
const img = new Image();
const progress = document.getElementById('progressbar');
const progressregion = document.getElementById('progressregion');
let mode = 'spline', clustering_mode = 'color';
// Hide canas and svg on load
canvas.style.display = 'none';
svg.style.display = 'none';
// Hide canas and svg on load
canvas.style.display = 'none';
svg.style.display = 'none';
// Paste from clipboard
document.addEventListener('paste', function (e) {
// Paste from clipboard
document.addEventListener('paste', function (e) {
if (e.clipboardData) {
var items = e.clipboardData.items;
if (!items) return;
@@ -31,10 +31,10 @@
}
e.preventDefault();
}
});
});
// Download as SVG
document.getElementById('export').addEventListener('click', function (e) {
// Download as SVG
document.getElementById('export').addEventListener('click', function (e) {
const blob = new Blob([new XMLSerializer().serializeToString(svg)], {type: 'octet/stream'}),
url = window.URL.createObjectURL(blob);
@@ -42,10 +42,10 @@
this.target = '_blank';
this.download = 'export-' + new Date().toISOString().slice(0, 19).replace(/:/g, '').replace('T', ' ') + '.svg';
});
});
// Function to load a given config WITHOUT restarting
function loadConfig(config) {
// Function to load a given config WITHOUT restarting
function loadConfig(config) {
mode = config.mode;
clustering_mode = config.clustering_mode;
@@ -73,121 +73,121 @@
document.getElementById('layerdifferencevalue').innerHTML = globallayerdifference;
document.getElementById('layerdifference').value = globallayerdifference;
}
}
// Upload button
var imageSelect = document.getElementById('imageSelect'),
imageInput = document.getElementById('imageInput');
imageSelect.addEventListener('click', function (e) {
// Upload button
var imageSelect = document.getElementById('imageSelect'),
imageInput = document.getElementById('imageInput');
imageSelect.addEventListener('click', function (e) {
imageInput.click();
e.preventDefault();
});
});
imageInput.addEventListener('change', function (e) {
imageInput.addEventListener('change', function (e) {
setSourceAndRestart(this.files[0]);
});
});
// Drag-n-Drop
var drop = document.getElementById('drop');
var droptext = document.getElementById('droptext');
drop.addEventListener('dragenter', function (e) {
// Drag-n-Drop
var drop = document.getElementById('drop');
var droptext = document.getElementById('droptext');
drop.addEventListener('dragenter', function (e) {
if (e.preventDefault) e.preventDefault();
e.dataTransfer.dropEffect = 'copy';
droptext.classList.add('hovering');
return false;
});
});
drop.addEventListener('dragleave', function (e) {
drop.addEventListener('dragleave', function (e) {
if (e.preventDefault) e.preventDefault();
e.dataTransfer.dropEffect = 'copy';
droptext.classList.remove('hovering');
return false;
});
});
drop.addEventListener('dragover', function (e) {
drop.addEventListener('dragover', function (e) {
if (e.preventDefault) e.preventDefault();
e.dataTransfer.dropEffect = 'copy';
droptext.classList.add('hovering');
return false;
});
});
drop.addEventListener('drop', function (e) {
drop.addEventListener('drop', function (e) {
if (e.preventDefault) e.preventDefault();
droptext.classList.remove('hovering');
setSourceAndRestart(e.dataTransfer.files[0]);
return false;
});
});
// Get Input from UI controls
var globalcorner = parseInt(document.getElementById('corner').value),
// Get Input from UI controls
var globalcorner = parseInt(document.getElementById('corner').value),
globallength = parseFloat(document.getElementById('length').value),
globalsplice = parseInt(document.getElementById('splice').value),
globalfilterspeckle = parseInt(document.getElementById('filterspeckle').value),
globalcolorprecision = parseInt(document.getElementById('colorprecision').value),
globallayerdifference = parseInt(document.getElementById('layerdifference').value);
document.getElementById('none').addEventListener('click', function (e) {
document.getElementById('none').addEventListener('click', function (e) {
mode = 'none';
restart();
}, false);
}, false);
document.getElementById('polygon').addEventListener('click', function (e) {
document.getElementById('polygon').addEventListener('click', function (e) {
mode = 'polygon';
restart();
}, false);
}, false);
document.getElementById('spline').addEventListener('click', function (e) {
document.getElementById('spline').addEventListener('click', function (e) {
mode = 'spline';
restart();
}, false);
}, false);
document.getElementById('clustering-binary').addEventListener('click', function (e) {
document.getElementById('clustering-binary').addEventListener('click', function (e) {
clustering_mode = 'binary';
restart();
}, false);
}, false);
document.getElementById('clustering-color').addEventListener('click', function (e) {
document.getElementById('clustering-color').addEventListener('click', function (e) {
clustering_mode = 'color';
restart();
}, false);
}, false);
document.getElementById('filterspeckle').addEventListener('change', function (e) {
document.getElementById('filterspeckle').addEventListener('change', function (e) {
globalfilterspeckle = parseInt(this.value);
document.getElementById('filterspecklevalue').innerHTML = this.value;
restart();
});
});
document.getElementById('colorprecision').addEventListener('change', function (e) {
document.getElementById('colorprecision').addEventListener('change', function (e) {
globalcolorprecision = parseInt(this.value);
document.getElementById('colorprecisionvalue').innerHTML = this.value;
restart();
});
});
document.getElementById('layerdifference').addEventListener('change', function (e) {
document.getElementById('layerdifference').addEventListener('change', function (e) {
globallayerdifference = parseInt(this.value);
document.getElementById('layerdifferencevalue').innerHTML = this.value;
restart();
});
});
document.getElementById('corner').addEventListener('change', function (e) {
document.getElementById('corner').addEventListener('change', function (e) {
globalcorner = parseInt(this.value);
document.getElementById('cornervalue').innerHTML = this.value;
restart();
});
});
document.getElementById('length').addEventListener('change', function (e) {
document.getElementById('length').addEventListener('change', function (e) {
globallength = parseFloat(this.value);
document.getElementById('lengthvalue').innerHTML = this.value;
restart();
});
});
document.getElementById('splice').addEventListener('change', function (e) {
document.getElementById('splice').addEventListener('change', function (e) {
globalsplice = parseInt(this.value);
document.getElementById('splicevalue').innerHTML = this.value;
restart();
});
});
function setSourceAndRestart(source) {
function setSourceAndRestart(source) {
img.src = source instanceof File ? URL.createObjectURL(source) : source;
img.onload = function () {
svg.setAttribute('viewBox', `0 0 ${img.naturalWidth} ${img.naturalHeight}`);
@@ -200,9 +200,9 @@
svg.style.display = 'block';
// Hide upload text
droptext.style.display = 'none';
}
}
function restart() {
function restart() {
document.getElementById('clustering-binary').classList.remove('selected');
document.getElementById('clustering-color').classList.remove('selected');
document.getElementById('clustering-' + clustering_mode).classList.add('selected');
@@ -246,13 +246,13 @@
progress.value = 0;
progressregion.style.display = 'block';
runner.run();
}
}
function deg2rad(deg) {
function deg2rad(deg) {
return deg/180*3.141592654;
}
}
class ConverterRunner {
class ConverterRunner {
constructor (converter_params) {
this.converter =
clustering_mode == 'color' ?
@@ -291,4 +291,4 @@
stop () {
this.stopped = true;
}
}
}