繁体   English   中英

数组不会拆分(使用splice(0))

[英]Array won't split (using splice(0))

我正在尝试类似perlin噪声贴图的方法,但是我的阵列不会重复! 结果,数组值超过了预期值(> 2)。

数组“ map ”仅包含1和0。

制作一个map副本(称为cache ),并将数组“ cache ”中的值添加到数组“ map ”中。

一些缓存值被添加以多次映射

问题是对“ map ”所做的任何更改似乎都在“ cache ”上重复了,非常令人沮丧。 我对javascript不够熟悉,无法知道我做错了什么。

相对代码:

    var map = terrainSeed(); //returns an array of 1's & 0's (random)
    map = terrainGen(map, map, 2, 2);   

    function terrainGen(mapNew, mapOld, x, y)          
    {            
        var cache = mapOld.slice(0);
        var asdf = 0;

        //if(x >=2) if(y >=2)
        for(var i = 0; i < cache.length; i++)
        {
            for(var j = 0; j < cache[i].length; j++)
            {
                var save = mapNew[i][j];
                asdf = cache[(Math.floor(i/x))][(Math.floor(j/y))];
                mapNew[i][j] += asdf;    

                if(mapNew[i][j]>2) alert(save + " + " + asdf + " = " + mapNew[i][j] + " (" + i + ", " + j + ")");                        
            }
         }
        return mapNew;
    }

由于slice正在执行浅表复制,因此您需要的是深表复制。 因此,要么使用诸如JQuery,Lo-Dash之类的第三方库,要么自行实现它。

使用JQuery

var cache = $.extend(true, [], mapOld);

使用Lo-Dash

var cache = _.cloneDeep(mapOld);

作为使用纯JavaScript的elaijuh答案的替代方法,您需要遍历mapOld数组值以创建一个新数组...这是这样的:

var cache = new Array;
for (var i=0;i<mapOld.length;i++) {
  cache[i] = mapOld[i];
}

您只需从mapOld提取值并将其放入cache ……这可能是库如何实现它,在函数中接受...这是您将如何创建函数:

clone = function(input){
  if (input instanceof Array) {
    var output = new Array;
    for (var i=0;i<input.length;i++) {
      output[i] = input[i];
    }
    return output;
  }
}

// Then using...
cache = clone(mapOld);

这是一个JSFiddle示例

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM