2022-11-13 00:15:17 +00:00
|
|
|
/// <reference path="../../../udbscript.d.ts" />
|
|
|
|
|
2021-11-28 13:00:24 +00:00
|
|
|
// Inspired by ribbiks's DBX Lua script: https://github.com/ribbiks/doom_lua/
|
|
|
|
|
2022-01-06 17:46:37 +00:00
|
|
|
`#version 4`;
|
|
|
|
|
2021-11-28 13:00:24 +00:00
|
|
|
`#name Bevel Linedefs`;
|
|
|
|
|
|
|
|
`#description Bevels linedefs at their shared vertices. Only works when the vertices have only two linedefs connected`;
|
|
|
|
|
|
|
|
`#scriptoptions
|
|
|
|
|
|
|
|
size
|
|
|
|
{
|
|
|
|
description = "Bevel size";
|
|
|
|
type = 0;
|
|
|
|
default = 32;
|
|
|
|
}
|
|
|
|
`;
|
|
|
|
|
2022-01-06 17:46:37 +00:00
|
|
|
let lines = UDB.Map.getSelectedLinedefs();
|
2021-11-28 13:00:24 +00:00
|
|
|
|
|
|
|
if(lines.length < 2)
|
|
|
|
die('You need to select at least 2 connected linedefs');
|
|
|
|
|
|
|
|
let vertices = new Set();
|
|
|
|
|
|
|
|
// Collect all vertices that has exactly 2 linedefs and both of those are selected
|
|
|
|
lines.forEach(ld => [ ld.start, ld.end ].forEach(v => {
|
|
|
|
let vertexlines = v.getLinedefs();
|
|
|
|
|
|
|
|
if(vertexlines.length == 2 && vertexlines.every(ld2 => ld2.selected))
|
|
|
|
vertices.add(v);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
// Go through all collected vertices
|
|
|
|
vertices.forEach(v => {
|
|
|
|
// Split all lines at the given size from the vertex away
|
|
|
|
v.getLinedefs().forEach(ld => {
|
|
|
|
if(ld.start == v)
|
2022-01-06 17:46:37 +00:00
|
|
|
ld.split(ld.line.getCoordinatesAt(1.0 / ld.length * UDB.ScriptOptions.size));
|
2021-11-28 13:00:24 +00:00
|
|
|
else
|
2022-01-06 17:46:37 +00:00
|
|
|
ld.split(ld.line.getCoordinatesAt(1.0 - (1.0 / ld.length * UDB.ScriptOptions.size)));
|
2021-11-28 13:00:24 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
// Get one of the connected linedef...
|
|
|
|
let ld = v.getLinedefs()[0];
|
|
|
|
|
|
|
|
// ... and join the current vertex into the linedef's closer vertex
|
|
|
|
if(ld.start == v)
|
|
|
|
v.join(ld.end);
|
|
|
|
else
|
|
|
|
v.join(ld.start);
|
|
|
|
});
|