gpt4 book ai didi

javascript - jquery:将 4 个点排序为(左上、右上、右下、左下)

转载 作者:塔克拉玛干 更新时间:2023-11-03 06:24:46 29 4
gpt4 key购买 nike

给定:2 个数组,每个包含 4 个点的坐标:

point_array_a = [point_a_1_x, point_a_1_y, point_a_2_x, ..., point_a_4_y]
point_array_b = [point_b_1_x, ... ..., point_b_4_y]

任务:

  1. 对 point_array_a 进行排序,使得最后点按以下顺序列出:

    point_array_a_sorted = [top-left_x, top_left_y, top-right_x, top-right_y, bottom-right_x, bottom_right_y, bottom-left_x, bottom_left_y]
  2. 以同样的方式对 point_array_b 进行排序,使得 point_a_k_l 对应于 point_b_k_l,就像开始时一样。

最佳答案

恐怕对此没有简单的算法。但以下代码片段可以完成这项工作(假设 y 坐标较大的点低于 y 坐标较低的点):

var i, points = [], leftX = point_array_a[0], topY = point_array_a[1];

for (i = 0; i < 4; i++)
{
leftX = Math.min(leftX, point_array_a[i * 2]);
topY = Math.min(topY, point_array_b[i * 2]);
points.push([
[point_array_a[i * 2], point_array_a[i * 2 + 1]],
[point_array_b[i * 2], point_array_b[i * 2 + 1]]
]);
}

points.sort(function(first, second){
if (first[0][0] == leftX)
return first[0][1] == topY ? -1 : 1;
if (second[0][0] == leftX)
return second[0][1] == topY ? 1 : -1;
return first[0][1] < second[0][1] ? -1 : 1;
});

var point_array_a_sorted = [], point_array_b_sorted = [];

for (i = 0; i < 4; i++)
{
point_array_a_sorted.push(points[i][0][0], points[i][0][1]);
point_array_b_sorted.push(points[i][1][0], points[i][1][1]);
}

我们利用现有的 Array.sort 函数,为其提供正确的对象以进行比较和交换——点对。

关于javascript - jquery:将 4 个点排序为(左上、右上、右下、左下),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27386066/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com