猿问

计算与边界框相关的模拟时钟指针的动态长度

我需要创建一个模拟时钟,动态调整一只或多只手的长度以达到边界框边界附近。时钟指针的起点不一定在边界框的中心。

我需要获得起点和终点之间的距离 - 不仅仅是手与边界框边界处的 x,y。

  • 左上角的边界框内为 0,0

  • 盒子尺寸可以是例如 348x250

  • 时钟指针的起点可以位于中心 x:174, y:125 (50%,50%) 或偏离中心,例如 x:214, y:90

  • 由于手的实现方式,需要实际长度 - 不仅仅是手与边缘相交的 x,y

理想情况下,我会有这样的功能:


function getLength(angle) {// 0-360 degrees for rotating the hand with 0 in the top


    let boxWidth = 348;//top left is 0,0

    let boxHeight = 250;


    let clockX = 214;// center X for the 'clock'

    let clockY = 90;// center Y for the 'clock'


    // start the magic here

    let handlength;

    ....

    // end magic here


    return handLength //return the actual max length for the hand


}

不知道如何计算。有什么帮助吗?


素胚勾勒不出你
浏览 176回答 2
2回答

三国纷争

如果要计算长度,可以使用以下函数:// angle: 0-360. 0 = 12 o'clock, 90 = 3 o'clock, ...// top: the distance of the center to the top side// right: the distance of the center to the right side// bottom: the distance of the center to the bottom side// left: the distance of the center to the left sidefunction getLength(angle, top, right, bottom, left) {&nbsp; &nbsp; var sideToCompare1;&nbsp; &nbsp; var sideToCompare2;&nbsp; &nbsp; if (angle >= 0 && angle < 90) {&nbsp; &nbsp; &nbsp; &nbsp; sideToCompare1 = top;&nbsp; &nbsp; &nbsp; &nbsp; sideToCompare2 = right;&nbsp; &nbsp; }&nbsp; &nbsp; else if (angle >= 90 && angle < 180) {&nbsp; &nbsp; &nbsp; &nbsp; sideToCompare1 = right;&nbsp; &nbsp; &nbsp; &nbsp; sideToCompare2 = bottom;&nbsp; &nbsp; &nbsp; &nbsp; angle -= 90;&nbsp; &nbsp; }&nbsp; &nbsp; else if (angle >= 180 && angle < 270) {&nbsp; &nbsp; &nbsp; &nbsp; sideToCompare1 = bottom;&nbsp; &nbsp; &nbsp; &nbsp; sideToCompare2 = left;&nbsp; &nbsp; &nbsp; &nbsp; angle -= 180;&nbsp; &nbsp; }&nbsp; &nbsp; else {&nbsp; &nbsp; &nbsp; &nbsp; sideToCompare1 = left;&nbsp; &nbsp; &nbsp; &nbsp; sideToCompare2 = top;&nbsp; &nbsp; &nbsp; &nbsp; angle -= 270;&nbsp; &nbsp; }&nbsp; &nbsp; // change to radian&nbsp; &nbsp; angle = angle / 180 * Math.PI;&nbsp; &nbsp; return Math.min(sideToCompare1 / Math.cos(angle),&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; sideToCompare2 / Math.sin(angle)); //Math.cos(Math.PI / 2 - angle)}函数中的想法是取到时钟指针将穿过的垂直或水平边的最小距离。通过旋转,四个象限的计算是相同的。这就是if.注意cos(90-a) = sin(a)。这用于简化到每个象限第二边的距离。如果你想要一个填充到盒子的边界,你可以考虑垂直于盒子侧面或手方向的填充。在第一种情况下,您只需通过所需的填充减少输入参数。在第二种情况下,只需从该函数的结果中减去填充。

慕田峪4524236

你总是可以(从字面上)隐藏复杂性。Math.random.between = (min, max) => Math.floor(Math.random() * (max - min + 1) + min);const createWeb = (el) => {&nbsp; const clock = {&nbsp; &nbsp; $canvas: el,&nbsp; &nbsp; logicalCenter: [Math.random.between(100, 400), Math.random.between(100, 400)],&nbsp; &nbsp; segments: 12,&nbsp; };&nbsp; clock.segmentSize = (Math.PI * 2) / clock.segments;&nbsp; clock.$canvas.width = 500;&nbsp; clock.$canvas.height = 500;&nbsp; clock.ctx = clock.$canvas.getContext('2d');&nbsp; clock.ctx.strokeStyle = 'orangered';&nbsp; clock.ctx.lineWidth = 5;&nbsp; clock.ctx.fillStyle = 'white';&nbsp; const draw = {&nbsp; &nbsp; arm: (atSegment) => {&nbsp; &nbsp; &nbsp; atSegment = atSegment % clock.segments;&nbsp; &nbsp; &nbsp; const degree = atSegment * clock.segmentSize;&nbsp; &nbsp; &nbsp; const handLength = clock.$canvas.width * 2;&nbsp; &nbsp; &nbsp; const [x, y] = [Math.cos(degree) * handLength, Math.sin(degree) * handLength];&nbsp; &nbsp; &nbsp; clock.ctx.beginPath();&nbsp; &nbsp; &nbsp; clock.ctx.moveTo(...clock.logicalCenter);&nbsp; &nbsp; &nbsp; clock.ctx.lineTo(x + clock.logicalCenter[0], y + clock.logicalCenter[1]);&nbsp; &nbsp; &nbsp; clock.ctx.stroke();&nbsp; &nbsp; },&nbsp; &nbsp; center: (radius) => {&nbsp; &nbsp; &nbsp; clock.ctx.beginPath();&nbsp; &nbsp; &nbsp; clock.ctx.arc(...clock.logicalCenter, radius, 0, Math.PI * 2);&nbsp; &nbsp; &nbsp; clock.ctx.stroke();&nbsp; &nbsp; },&nbsp; &nbsp; border: (thickness) => {&nbsp; &nbsp; &nbsp; const [w, h] = [clock.$canvas.width, clock.$canvas.height];&nbsp; &nbsp; &nbsp; clock.ctx.fillRect(0, 0, thickness, h);&nbsp; &nbsp; &nbsp; clock.ctx.fillRect(0, 0, w, thickness);&nbsp; &nbsp; &nbsp; clock.ctx.fillRect(0, h - thickness, w, thickness);&nbsp; &nbsp; &nbsp; clock.ctx.fillRect(w - thickness, 0, thickness, h);&nbsp; &nbsp; }&nbsp; };&nbsp; draw.center(10);&nbsp; Array(clock.segments).fill(0)&nbsp; &nbsp; .map((_, i) => i)&nbsp; &nbsp; .forEach(draw.arm);&nbsp; draw.border(20);}document.querySelectorAll('.clock').forEach(createWeb);* {&nbsp; margin: 0;&nbsp; padding: 0;}.clock {&nbsp; position: relative;&nbsp; width: 200px;&nbsp; height: 200px;&nbsp; border: 3px orangered solid;&nbsp; box-sizing: border-box;}<canvas class="clock"></canvas><canvas class="clock"></canvas><canvas class="clock"></canvas>
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答