Fix length-input element: shrinking and clicking is possible again

This commit is contained in:
pietervdvn 2022-07-28 23:47:00 +02:00
parent 3bd912db5a
commit 00d9adee46

View file

@ -14,10 +14,10 @@ import BaseUIElement from "../BaseUIElement";
* Selects a length after clicking on the minimap, in meters * Selects a length after clicking on the minimap, in meters
*/ */
export default class LengthInput extends InputElement<string> { export default class LengthInput extends InputElement<string> {
public readonly IsSelected: UIEventSource<boolean> = new UIEventSource<boolean>(false);
private readonly _location: UIEventSource<Loc>; private readonly _location: UIEventSource<Loc>;
private readonly value: UIEventSource<string>; private readonly value: UIEventSource<string>;
private background; private readonly background: UIEventSource<any>;
constructor(mapBackground: UIEventSource<any>, constructor(mapBackground: UIEventSource<any>,
location: UIEventSource<Loc>, location: UIEventSource<Loc>,
@ -36,7 +36,7 @@ export default class LengthInput extends InputElement<string> {
IsValid(str: string): boolean { IsValid(str: string): boolean {
const t = Number(str) const t = Number(str)
return !isNaN(t) && t >= 0 && t <= 360; return !isNaN(t) && t >= 0;
} }
protected InnerConstructElement(): HTMLElement { protected InnerConstructElement(): HTMLElement {
@ -63,7 +63,7 @@ export default class LengthInput extends InputElement<string> {
} }
const crosshair = new Combine([Svg.length_crosshair_svg().SetStyle( const crosshair = new Combine([Svg.length_crosshair_svg().SetStyle(
`position: absolute;top: 0;left: 0;transform:rotate(${this.value.data ?? 0}deg);`) `position: absolute;top: 0;left: 0;transform:rotate(${this.value.data ?? 0}deg);`)
]) .SetClass("block length-crosshair-svg relative") ]) .SetClass("block length-crosshair-svg relative pointer-events-none")
.SetStyle("z-index: 1000; visibility: hidden") .SetStyle("z-index: 1000; visibility: hidden")
const element = new Combine([ const element = new Combine([
@ -112,33 +112,31 @@ export default class LengthInput extends InputElement<string> {
lastClickXY = undefined; lastClickXY = undefined;
} }
} }
if (isUp) {
const distance = Math.sqrt((dy - firstClickXY[1]) * (dy - firstClickXY[1]) + (dx - firstClickXY[0]) * (dx - firstClickXY[0]))
if (distance > 15) {
lastClickXY = [dx, dy]
}
if (firstClickXY === undefined) {
} else if (lastClickXY !== undefined) { measurementCrosshair.style.visibility = "hidden"
return; return;
} }
// const measurementCrosshair = htmlElement.getElementsByClassName("length-crosshair-svg")[0] as HTMLElement
const measurementCrosshairInner: HTMLElement = <HTMLElement>measurementCrosshair.firstChild const distance = Math.sqrt((dy - firstClickXY[1]) * (dy - firstClickXY[1]) + (dx - firstClickXY[0]) * (dx - firstClickXY[0]))
if (firstClickXY === undefined) { if (isUp) {
measurementCrosshair.style.visibility = "hidden" if (distance > 15) {
} else { lastClickXY = [dx, dy]
}
} else if (lastClickXY !== undefined) {
return;
}
measurementCrosshair.style.visibility = "unset" measurementCrosshair.style.visibility = "unset"
measurementCrosshair.style.left = firstClickXY[0] + "px"; measurementCrosshair.style.left = firstClickXY[0] + "px";
measurementCrosshair.style.top = firstClickXY[1] + "px" measurementCrosshair.style.top = firstClickXY[1] + "px"
const angle = 180 * Math.atan2(firstClickXY[1] - dy, firstClickXY[0] - dx) / Math.PI; const angle = 180 * Math.atan2(firstClickXY[1] - dy, firstClickXY[0] - dx) / Math.PI;
const angleGeo = (angle + 270) % 360 const angleGeo = (angle + 270) % 360
const measurementCrosshairInner: HTMLElement = <HTMLElement>measurementCrosshair.firstChild
measurementCrosshairInner.style.transform = `rotate(${angleGeo}deg)`; measurementCrosshairInner.style.transform = `rotate(${angleGeo}deg)`;
const distance = Math.sqrt((dy - firstClickXY[1]) * (dy - firstClickXY[1]) + (dx - firstClickXY[0]) * (dx - firstClickXY[0]))
measurementCrosshairInner.style.width = (distance * 2) + "px" measurementCrosshairInner.style.width = (distance * 2) + "px"
measurementCrosshairInner.style.marginLeft = -distance + "px" measurementCrosshairInner.style.marginLeft = -distance + "px"
measurementCrosshairInner.style.marginTop = -distance + "px" measurementCrosshairInner.style.marginTop = -distance + "px"
@ -154,8 +152,6 @@ export default class LengthInput extends InputElement<string> {
} }
}
htmlElement.ontouchstart = (ev: TouchEvent) => { htmlElement.ontouchstart = (ev: TouchEvent) => {
onPosChange(ev.touches[0].clientX, ev.touches[0].clientY, true); onPosChange(ev.touches[0].clientX, ev.touches[0].clientY, true);