如何在单个for循环中覆盖网格中的每个正方形

How to cover every square in a grid in a single for loop?

本文关键字:网格 正方形 覆盖 单个 for 循环      更新时间:2023-09-26

我正在实现动态映射瓦片,遇到了一个令人困惑的问题。假设我有一个8x8正方形的网格,就像棋盘一样。我需要在每个正方形上放置一个图像,最好从中心开始,然后从那里开始。

这可能在一个for循环中完成吗?还是需要几个循环?正如我所说,这些图像是正方形的,并且被放置在地图上。它们的纬度/经度都是0.025°。

这是我最初的想法:

for (var i=-0.25; i<=0.25; i+=0.025) {
    var adjustedLatitude = (requestedLatitude + i);
    var adjustedLongitude = (requestedLongitude + i);
}

当然,这只会以对角线模式填充网格。最好的方法是什么?

我个人认为使用嵌套循环最可读:

for (var i=-0.25; i<=0.25; i+=0.025) {
    for (var j=-0.25; j<=0.25; j+=0.025) {
        var adjustedLatitude = (requestedLatitude + i);
        var adjustedLongitude = (requestedLongitude + j);
        doStuffWithAxes(adjustedLatitude, adjustedLongitude);
    }
}

然而,您可以使用单个循环来完成它,如下所示:

for (var i=0; i<=20*20; i++) {
    var xoffset = (i % 20 - 10) / 40;
    var yoffset = (i / 20 - 10) / 40;
    var adjustedLatitude = (requestedLatitude + xoffset);
    var adjustedLongitude = (requestedLongitude + yoffset);
    doStuffWithAxes(adjustedLatitude, adjustedLongitude);
}