2025-09-16 19:41:05 +00:00
|
|
|
<meta charset="UTF-8" />
|
2025-09-16 19:14:17 +00:00
|
|
|
<input id="fileInput" type="file" multiple />
|
|
|
|
|
<button id="uploadBtn">Upload</button>
|
|
|
|
|
<progress id="bar" max="100" value="0" style="width:300px;"></progress>
|
2025-09-18 13:57:14 +00:00
|
|
|
<br><br><br>
|
|
|
|
|
<label>flow_threshold:
|
|
|
|
|
<input id="flow" type="text" placeholder="" />
|
|
|
|
|
</label>
|
|
|
|
|
<br><br>
|
|
|
|
|
<label>cellprob_threshold:
|
|
|
|
|
<input id="cellprob" type="text" placeholder="" />
|
|
|
|
|
</label>
|
|
|
|
|
<br><br>
|
2025-09-18 13:57:31 +00:00
|
|
|
<label>diameter:
|
|
|
|
|
<input id="diameter" type="text" placeholder="" />
|
|
|
|
|
</label>
|
|
|
|
|
<br><br>
|
2025-09-18 13:57:14 +00:00
|
|
|
<label>模型(下拉单选):
|
|
|
|
|
<select id="model">
|
|
|
|
|
<option value="cpsam">cpsam</option>
|
|
|
|
|
</select>
|
|
|
|
|
</label>
|
2025-09-16 19:14:17 +00:00
|
|
|
|
|
|
|
|
<script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
|
|
|
|
|
<script>
|
2025-09-18 13:57:14 +00:00
|
|
|
const API = "http://10.147.18.141:5000/upload";
|
2025-09-16 19:14:17 +00:00
|
|
|
|
2025-09-18 13:57:14 +00:00
|
|
|
function buildUrl() {
|
2025-09-18 13:57:31 +00:00
|
|
|
// 获取参数
|
2025-09-18 13:57:14 +00:00
|
|
|
const model = document.getElementById('model')?.value;
|
|
|
|
|
const flow = (document.getElementById('flow')?.value || '').trim();
|
|
|
|
|
const cellp = (document.getElementById('cellprob')?.value || '').trim();
|
2025-09-18 13:57:31 +00:00
|
|
|
const diameter = (document.getElementById('diameter')?.value || '').trim();
|
2025-09-16 19:14:17 +00:00
|
|
|
|
2025-09-18 13:57:31 +00:00
|
|
|
// 用 URLSearchParams 组装查询串
|
2025-09-18 13:57:14 +00:00
|
|
|
const qs = new URLSearchParams({
|
|
|
|
|
model: model,
|
|
|
|
|
flow_threshold: flow,
|
2025-09-18 13:57:31 +00:00
|
|
|
cellprob_threshold: cellp,
|
|
|
|
|
diameter: diameter
|
2025-09-16 19:14:17 +00:00
|
|
|
});
|
2025-09-18 13:57:14 +00:00
|
|
|
|
|
|
|
|
return `${API}?${qs.toString()}`;
|
2025-09-16 19:14:17 +00:00
|
|
|
}
|
2025-09-18 13:57:14 +00:00
|
|
|
|
|
|
|
|
document.getElementById("uploadBtn").addEventListener("click", async () => {
|
|
|
|
|
const input = document.getElementById("fileInput");
|
|
|
|
|
if (!input.files.length) return alert("请选择文件");
|
|
|
|
|
|
|
|
|
|
const fd = new FormData();
|
|
|
|
|
for (const f of input.files) fd.append("files", f);
|
|
|
|
|
|
|
|
|
|
const bar = document.getElementById("bar");
|
|
|
|
|
try {
|
|
|
|
|
const URL = buildUrl();
|
|
|
|
|
const res = await axios.post(URL, fd, {
|
|
|
|
|
onUploadProgress: (e) => {
|
|
|
|
|
if (e.total) bar.value = Math.round((e.loaded * 100) / e.total);
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
alert("上传成功:" + JSON.stringify(res.data));
|
|
|
|
|
window.location.href = `preview.html?id=${encodeURIComponent(res.data['id'])}`;
|
|
|
|
|
} catch (e) {
|
|
|
|
|
alert("上传失败:" + (e.response?.data?.message || e.message));
|
|
|
|
|
} finally {
|
|
|
|
|
bar.value = 0;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
</script>
|