基本上我想生成一个不在多个其他角度的指定范围内的角度(0 - 360 度)。我已经做了这个功能来检查两个角度:
function check(angle1, angle2, range) {
var diff = angle1 - angle2;
if(Math.abs(diff % 360) <= range || (360-Math.abs(diff % 360)) <= range) {
return true;
} else {
return false;
}
}
很简单,但我需要检查一个随机角度与所有其他角度,如果它通过则继续,生成一个新角度并重新检查它是否失败,并识别何时不可能通过任何新角度。
我认为这会起作用:
var others = [array of objects];
...
for(var i = 0; i < 360; i++) {
var pass = true;
for(var n = 0; n < others.length; n++) {
if(check(i, others[n].angle, 5)) {
pass = false;
break;
}
}
if(pass) return i;
}
return false;
然而,这是很多循环,我更喜欢随机角度而不是递增。有没有更快更好的方法来做到这一点?谢谢。
编辑:决定做这样的事情,从@TheBronx的回答中得到了这个想法。
var angles = [];
var range = 5;
function alterAngle(a, n) {
var angle = a + n;
if(angle < 0) angle = 360 + angle;
if(angle > 360) angle = angle - 360;
return angle;
}
// in the function
var angle = Math.floor(Math.random() * 360);
if(angles.indexOf(angle) == -1) {
for(var i = -range; i <= range; i++)
angles.push(alterAngle(angle, i));
}