Javascript洪水填充功能只能部分工作[扫雷]
Javascript flood-fill function working only partially [Minesweeper]
几个月来,我一直在尝试创建自己的扫雷游戏(为了好玩)。我唯一真正被阻止的是如何制作递归函数(洪水填充)来填充游戏中的空白区域。
洪水填充仅部分起作用。它不会从任何单击的节点延伸到右侧或底部节点。
当前完整代码
溢流填充-部分:
function floodFill(node) {
if (node < 0) {return};
if (document.getElementById("cell" + node).style.backgroundColor == "white") {return};
if (document.getElementById("cell" + node).classList.contains("nearby")) {return};
document.getElementById("cell" + node).style.backgroundColor = "white";
floodFill(node -= 1);
floodFill(node += 1);
floodFill(node -= 16);
floodFill(node += 16);
return
};
floodFill(here);
"此处"表示单击的节点。网格的大小为16,因此底部节点为当前节点+16。
这个小游戏项目对我来说意义重大,所以我们非常感谢您的帮助。
运算符-=
和+=
表示将某个值减去/添加到变量中。
a += 10;
相当于
a = a + 10;
因此,在您的代码中
floodFill(node -= 1);
floodFill(node += 1);
floodFill(node -= 16);
floodFill(node += 16);
CCD_ 3在每个函数调用中都被更改。
例如,如果node
为10,则会发生以下情况:
node
将递减1(node -= 1
),现在为9floodFill
将被调用,node == 9
node
将增加1(node += 1
),现在是10- 等等
不要使用赋值运算符(-=
/+=
),而是使用普通运算符(-
/+
)。
解决方案:更改
floodFill(node -= 1);
floodFill(node += 1);
floodFill(node -= 16);
floodFill(node += 16);
至
floodFill(node - 1);
floodFill(node + 1);
floodFill(node - 16);
floodFill(node + 16);
希望这能有所帮助!
相关文章:
- Javascript:selenium Web驱动程序isDisplayed()不工作
- jQuery UI自动完成突然停止工作
- AngularJS UI路由器不能像ng路由器那样工作
- HTML5音频加载和播放获胜'我不能在iPad上工作
- JavaScript打印功能使日历停止工作
- Javascript.getHours()工作不正常
- 为什么这在IE中的工作方式与在Firefox中不同
- 视频HTML没有'无法在Internet Explorer 11上工作
- 扩展移相器按钮类不工作
- Firebase迁移-简单的Firebase.set没有'不再工作了——旧的还是新的
- 谷歌地图不是以HTML显示,而是在JS Fiddle上工作
- 正在尝试使用if和else添加类,但无法正常工作
- Jquery FadeIn FadeOut 只工作一次
- Foreach无法在Typescript中工作
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- 为什么不是't窗口.恢复正常工作吗?(javascript/jquery)
- JS可以在Chrome中工作,但不能在Firefox中工作
- ajaxToolkit PopupControlExtender不工作.过时的
- HTML标记在脚本标记中工作
- Javascript洪水填充功能只能部分工作[扫雷]