index : btroops | |
Virtual board game-aid for BattleTroops, an infantry combat simulator wargame published by FASA in 1989. |
aboutsummaryrefslogtreecommitdiff |
diff options
author | Catalin Mititiuc <Catalin.Mititiuc@gmail.com> | 2024-03-21 16:42:22 -0700 |
---|---|---|
committer | Catalin Mititiuc <Catalin.Mititiuc@gmail.com> | 2024-03-21 16:42:22 -0700 |
commit | 7da963cd8eb13a91d337e7d7268c3fdb3fd48797 (patch) | |
tree | 1ed6ce08edd80fe7dc8f1de275dc407eb4d58540 /index.js | |
parent | 2159804c11ff9a69ade3b45c1dde98a16626542f (diff) |
WIP: firing arc cone angle does not change while rotating about pivot point
Diffstat (limited to 'index.js')
-rw-r--r-- | index.js | 52 |
1 files changed, 33 insertions, 19 deletions
@@ -98,23 +98,37 @@ rect.addEventListener('mousemove', e => { } } + let width = x2px - x1px; + let height = -(y2px - y1px); + let angle = Math.abs(Math.atan(height / width)); - let slope = (y2px - y1px) / (x2px - x1px); - let inverseSlope = -1 / slope; + if (width < 0 && height > 0) { + // angle = 180 - angle; + angle = Math.PI - angle; + } else if (width < 0 && height < 0) { + // angle = 180 + angle; + angle = Math.PI + angle; + } else if (width > 0 && height < 0) { + // angle = 360 - angle; + angle = 2 * Math.PI - angle; + } - console.log('slope', slope); - console.log('inverse slope', inverseSlope); + console.log('angle', angle, 'degrees', radToDeg(angle)); let smlArcAngle = Math.atan(pointDistanceInInches / (6 * calcY)) * 2; let distance = Math.sqrt((x2px - x1px)**2 + (y2px - y1px)**2); - let newY1 = y2px + distance * Math.atan(smlArcAngle / 2); - let newY2 = y2px - distance * Math.atan(smlArcAngle / 2); + + let newY1 = y2px + (distance * Math.cos(angle)) * Math.atan(smlArcAngle / 2); + let newY2 = y2px - (distance * Math.cos(angle)) * Math.atan(smlArcAngle / 2); + + let newX1 = x2px + (distance * Math.sin(angle)) * Math.atan(smlArcAngle / 2); + let newX2 = x2px - (distance * Math.sin(angle)) * Math.atan(smlArcAngle / 2); // p.setAttributeNS(null, 'points', `${newX},${newY} ${x1px},${y1px} ${newX},${newY}`); // p.setAttributeNS(null, 'points', `${x2px},${y2px} ${x1px},${y1px} ${x2px},${y2px}`); - p.setAttributeNS(null, 'points', `${x2px},${newY1} ${x1px},${y1px} ${x2px},${newY2}`); + p.setAttributeNS(null, 'points', `${newX1},${newY1} ${x1px},${y1px} ${newX2},${newY2}`); - console.log(p); + // console.log(p); if (x2 - x1 > 0 && y2 - y1 > 0) { let yWhenXisMax = yIntercept(maxX); @@ -165,19 +179,19 @@ rect.addEventListener('mousemove', e => { aim.setAttributeNS(null, 'x2', `${newX}in`); aim.setAttributeNS(null, 'y2', `${newY}in`); - let width = aim.x2.baseVal.value - aim.x1.baseVal.value; - let height = -(aim.y2.baseVal.value - aim.y1.baseVal.value); - let angle = Math.abs(radToDeg(Math.atan(height / width))); + // let width = aim.x2.baseVal.value - aim.x1.baseVal.value; + // let height = -(aim.y2.baseVal.value - aim.y1.baseVal.value); + // let angle = Math.abs(radToDeg(Math.atan(height / width))); - if (width < 0 && height > 0) { - angle = 180 - angle; - } else if (width < 0 && height < 0) { - angle = 180 + angle; - } else if (width > 0 && height < 0) { - angle = 360 - angle; - } + // if (width < 0 && height > 0) { + // angle = 180 - angle; + // } else if (width < 0 && height < 0) { + // angle = 180 + angle; + // } else if (width > 0 && height < 0) { + // angle = 360 - angle; + // } - console.log(`${toFixed(angle)}\u00B0`); + // console.log(`${toFixed(angle)}\u00B0`); } }); |