gpt4 book ai didi

javascript - 检查节点的对 Angular 邻居

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

我正在尝试比较节点的值。使用 flood-fill 算法,我能够垂直和水平检查网格的每个节点。现在我必须更新我的代码以检查位于对 Angular 线上的单元格,如下图所示:

enter image description here

红色是当前节点,黄色是需要检查的单元格。

这是我目前所拥有的片段:

var mapWidth = Math.sqrt(mapData.length);
var currentCell = $('[data-x="'+ x +'"][data-y="'+ y +'"]');
if (x < 0 || y < 0 || x > mapWidth || y > mapWidth) {
return;
}
if(mapData[x*mapWidth+y] !== 0 || currentCell.hasClass('cell-grey')) {
if(mapData[x*mapWidth+y] > 0) {
currentCell.addClass('cell-grey').css('opacity', '1');
}
if(mapData[(x-1)*mapWidth+(y-1)] > 0 && mapData[(x-1)*mapWidth+(y-1)] < mapWidth) {
currentCell.addClass('cell-grey').css('opacity', '1');
return;
}
if(mapData[(x-1)*mapWidth+(y+1)] > 0 && mapData[(x-1)*mapWidth+(y+1)] < mapWidth) {
currentCell.addClass('cell-grey').css('opacity', '1');
return;
}
if(mapData[(x+1)*mapWidth+(y-1)] > 0 && mapData[(x+1)*mapWidth+(y-1)] < mapWidth) {
currentCell.addClass('cell-grey').css('opacity', '1');
return;
}
if(mapData[(x+1)*mapWidth+(y+1)] > 0 && mapData[(x+1)*mapWidth+(y+1)] < mapWidth) {
currentCell.addClass('cell-grey').css('opacity', '1');
return;
}
return true;
}

mapWidth是包含网格所有单元格的变量,currentCell是当前节点单元格。这段代码对我来说并不是真的有用。

最佳答案

当您评估 mapData[(x-1)*mapWidth+(y-1)] 时,x-1y-1 可能会导致越界引用,返回 undefined。您必须在访问数组之前验证单元格坐标。

您可以像这样遍历四个对 Angular 线邻居:

for (var neighborX = x - 1; neighborX <= x + 1; neighborX += 2) { 
if (neighborX < 0 || neighborX >= mapWidth) {
continue;
}
for (var neighborY = y - 1; neighborY <= y + 1; neighborY += 2) {
if (neighborY < 0 || neighborY >= mapWidth) {
continue;
}
currentCell.addClass('cell-grey').css('opacity', '1');
}
}

我不确定您到底想完成什么,但看起来您的代码中还有其他错误。例如,您可能不想在单元格变灰后立即return。如果您希望每个对 Angular 线邻居都变成灰色,上面的循环应该可以解决问题。

代码开头附近的这一行包含一个细微错误:

if (x < 0 || y < 0 || x > mapWidth || y > mapWidth) {

有效索引范围从 0mapWidth - 1,所以你应该写:

if (x < 0 || y < 0 || x >= mapWidth || y >= mapWidth) {

关于javascript - 检查节点的对 Angular 邻居,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34450266/

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