猿问

从给定的坐标(x,y)计算边界框的宽度和高度

我有一个坐标列表

const coords = [{x:10, y:20}, {x:5, y:6}, {x:1, y:25}, {x:11, y:2}];

我想知道是否有一种方法可以计算仅具有这些坐标的边界框宽度和高度?



梵蒂冈之花
浏览 157回答 3
3回答

慕田峪4524236

使用该map()函数将输入数组转换为x或y值的数组。然后,您可以将这些转换后的数组提供给Math.min()并Math.max()获得left、right,bottom并top计算bounding box。当你有 时bounding box,宽度和高度的计算是直接的(从最大值中减去最小值)。请参阅下面的代码片段。const coords = [{x:10, y:20}, {x:5, y:6}, {x:1, y:25}, {x:11, y:2}];const xArr = coords.map(c => c.x);const yArr = coords.map(c => c.y);const l = Math.min(...xArr);const r = Math.max(...xArr);const b = Math.min(...yArr);const t = Math.max(...yArr);const width  = r - l;const height = t - b;console.log(width, height);

慕村9548890

x我想,这将是(宽度)和(高度)的最小值和最大值之间的差异y。虽然计算这些的明显方法似乎是使用Math.max()/Math.min()过度提取坐标数组,但它需要多次不必要地循环源数组,而单次传递(例如 with Array.prototype.reduce())就足够了,并且当输入数组相对大的:const points = [{x:10, y:20}, {x:5, y:6}, {x:1, y:25}, {x:11, y:2}],&nbsp; &nbsp; &nbsp; {width, height} = points.reduce((acc, {x,y}) => {&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; const {min, max} = Math&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; if(!acc.mX || x < acc.mX){&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; acc.mX = x&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; } else if (!acc.MX || x > acc.MX){&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; acc.MX = x&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; }&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; if(!acc.mY || y < acc.mY){&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; acc.mY = y&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; } else if (!acc.MY || y > acc.MY){&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; acc.MY = y&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; }&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; acc.width = acc.MX - acc.mX&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; acc.height = acc.MY - acc.mY&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; return acc&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; }, {width: 0, height: 0})&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;console.log(`width: ${width}; height: ${height}`)

慕无忌1623718

看看这个片段。猜猜这是一种开始的方法。一些解释:我们正在使用 计算坐标集的 minX、maxX、minY 和 maxY 值Math.operationMinOrMax(...coords.map(c => c.propertyXorY))。边界框的 min-x 坐标(=> 左角)是 minX 值。边界框的 min-y 坐标 (&nbsp;=> top&nbsp;) 是 minY 值。边界框的 max-x 坐标(=> 右角)是 maxX 值。边界框 (&nbsp;=> bottom&nbsp;) 的 max-y 坐标是 maxY 值。大小(属性w和hmaxX - minX&nbsp;)可以通过减去和来计算maxY - minY。const boundingBox = (coords) => {&nbsp; const minX = Math.min(...coords.map(c => c.x)), maxX = Math.max(...coords.map(c => c.x));&nbsp; const minY = Math.min(...coords.map(c => c.y)), maxY = Math.max(...coords.map(c => c.y));&nbsp; return {&nbsp; &nbsp; x: minX,&nbsp; &nbsp; y: minY,&nbsp; &nbsp; w: maxX - minX,&nbsp; &nbsp; h: maxY - minY&nbsp; }}console.log(&nbsp; boundingBox( [ {x:10,y:5}, {x:100,y:0}, {x:100,y:100}, {x:12,y:50}, {x:0,y:100}, {x:27,y:22} ]));
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答