- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我不确定如何正确设置游戏,所以我在数敌人。如果我能数出敌人数量,我相信我可以设置我的代码,这样我就可以确认是否成功,这样我就可以重新加载页面并可能制造更多敌人
我认为我的问题是基于我的 enemycount 变量。我不确定如何倒数到零。我也相信我的问题可能与没有基于 enemycount 的功能有关。
//This is the Variables that I have used for code as well as the codes based around the enemies.//
var canvasBg =document.getElementById("canvasBg"),
ctxBg = canvasBg.getContext("2d"),
canvasEntities =document.getElementById("canvasEntities"),
ctxEntities = canvasEntities.getContext("2d"),
canvasWidth = canvasBg.width,
canvasHeight = canvasBg.height,
player1 = new Player(),
enemies = [],
numEnemies = 5,
enemycount = numEnemies,
obstacles = [],
isPlaying = false,
function Enemy(){
this.srcX = 140;
this.srcY = 600;
this.width = 45;
this.height = 54;
this.drawX = randomRange(0, canvasWidth - this.width);
this.drawY = randomRange(0, canvasHeight - this.height);
this.centerX = this.drawX + (this.width / 2);
this.centerY = this.drawY + (this.height / 2);
this.targetX = this.centerX;
this.targetY = this.centerY;
this.randomMoveTime + randomRange(4000, 10000);
this.speed = 1;
var that = this;
this.moveInterval =setInterval(function(){that.setTargetLocation();}, that.randomMoveTime);
this.isDead = false;
}
Enemy.prototype.update = function (){
this.centerX = this.drawX + (this.width / 2);
this.centerY = this.drawY + (this.height / 2);
this.checkDirection();
};
Enemy.prototype.draw = function(){
ctxEntities.drawImage(imgSprite, this.srcX, this.srcY, this.width, this.height, this.drawX, this.drawY, this.width, this.height);
};
function initEnemies(){
for(var i = 0; i < numEnemies; i++){
enemies[enemies.length] = new Enemy();
}
}
function updateAllEnemies(){
for(var i = 0; i < enemies.length; i++){
enemies[i].update();
}
}
function drawAllEnemies(){
for(var i = 0; i < enemies.length; i++){
enemies[i].draw();
}
}
Enemy.prototype.setTargetLocation = function(){
this.randomMoveTime = randomRange(4000, 10000);
var minX = this.centerX - 50,
maxX = this.centerX + 50,
minY = this.centerY - 50,
maxY = this.centerY + 50;
//no ghosts off canvas
if(minX < 0){
minX = 0;
}
if(maxX > canvasWidth){
maxX = canvasWidth;
}
if(minY < 0){
minY = 0;
}
if(maxY > canvasHeight){
maxY = canvasHeight;
}
this.targetX = randomRange(minX, maxX);
this.targetY = randomRange(minY, maxY);
};
Enemy.prototype.checkDirection = function(){
if(this.centerX < this.targetX){
this.drawX += this.speed;
}else if(this.centerX > this.targetX){
this.drawX -= this.speed;
}
if(this.centerY < this.targetY){
this.drawY += this.speed;
}else if(this.centerY > this.targetY){
this.drawY -= this.speed;
}
};
Enemy.prototype.die = function (){
var soundEffect = new Audio("audio/dying.wav");
soundEffect.play();
clearInterval(this.moveInterval);
this.srcX = 185;
this.isDead = true;
//this.enemycount -=;
};
function collision(a, b){
return a.drawX <= b.drawX + b.width &&
a.drawX >= b.drawX &&
a.drawY <= b.drawY + b.height &&
a.drawY > b.drawY;
}
if (enemycount == 0){
alert("WELL DONE");
// confirm('Congrats \n Level Complete!!! \n Play Again')location.reload();
}
我想做的是,当没有更多敌人时,我想添加一个类似于以下的 if 语句:if(enemycount === 0){confirm('Congratulations You Win\n Play Again ?') window.location.reload();}
最佳答案
enemycount 值在全局范围内。改变 this.enemycount ==> enemycount;
并且您需要检查您正在触发的确认提示的响应。
理想情况下你需要这样的东西
var enemycount = 5;
document.getElementById('counter').addEventListener('click',function(){
enemycount--;
die();
})
function die() {
if(enemycount === 0){
doContinue();
}
}
function doContinue() {
var resp = confirm('Congratulations You Win \n Play Again?')
if (resp) {
window.location.reload();
} else {
//stay in the same window
}
}
关于javascript - 如何添加一个计数器,稍后将用于 if 语句以执行重新加载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57598704/
我在leetcode上看到这段代码,是一道求众数的题,下面是题目描述: 给定一个大小为 n 的数组,找到多数元素。众数元素是出现次数超过 ⌊ n/2 ⌋ 次的元素。 你可以假设数组是非空的并且多数元素
每次在 JavaScript 中执行特定操作时,例如: $(function() { $('#typing').keyup(function () { switch($(this)
我一直在为网页设计一个计数器,但我一直被这个我无法解决的功能所困扰。 我有一个 4 个 div 的计数器,因为其中两个是小数字,另外两个是大数字,所以第一个运行得很快,我看不到它们的功能。 有人知道如
我已经在文档中进行了一些搜索,并在网上花了一段时间,但找不到解决方案!我希望警报告诉我单击 .thumb 时它处于each() 的哪一次迭代。 EG:有六个.thumb,我点击数字3,浏览器弹出3!
在 Handlebars 中,假设我有 names 的集合.我能怎么做 {{#each names}} {{position}} {{name}} {{/each}} 在哪里 {{position}}
这个问题在这里已经有了答案: Numbering rows within groups in a data frame (9 个回答) 4年前关闭。 我们如何在数据帧的每组中生成唯一的 ID 号?以下
我正在努力解决以下问题。我希望为给定的“一”序列创建一个计数器。例如,我有以下内容: 1 1 1 1 0 0 1 1 1 0 0 1 1 1 1 鉴于该序列,我希望为 1 的每个序列设置一个计数器直到
我正在努力解决以下问题。我希望为给定的“一”序列创建一个计数器。例如,我有以下内容: 1 1 1 1 0 0 1 1 1 0 0 1 1 1 1 鉴于该序列,我希望为 1 的每个序列设置一个计数器直到
我有一个jsfiddle here 这是一个简单的 JavaScript 函数,可以计算出设定的数字。 是否可以进行这种计数,但也保留一位小数 所以它算 1.1、1.2、1.3 等。 func
我正在构建一个计数器,当我按下鼠标时,它应该增加到 maxValue 并且减少不超过 0。我还可以选择将计数器重置为其初始值:0。另外,如果 maxValue 是偶数,它应该计数到该数字。但是,如果
所以我成功地为字母和单词构建了其他计数器,但现在我只能用这个来计算句子。我的代码如下,当我运行它时,它会返回很多错误消息: #include #include #include int main
Closed. This question is off-topic。它当前不接受答案。
我需要一个计数器,它会随着某些任务的完成而递增。我们只需要最后一小时的值,即窗口将移动而不是静态时间。 解决此问题的最佳方法是什么?我能想到的一种方法是拥有一个大小为 60 的数组,每分钟一个,并更新
我希望使用计数器来为我提供独特的引用系统。我想单击一个按钮,然后检查一个字段/文件中的最后一个数字,然后简单地向其添加 1,然后将其插入到屏幕上的字段中? 不确定执行此操作的最佳方法或具体如何执行此操
我有一个用 php 制作的表格,在该表格内我显示了数据库中的一些内容。我在每个 td 中创建了一个简单的按钮(类似于 Like),我希望每次点击它都会增加 1。这是带有按钮的行: echo "
如何将数据库中的值转换为可用于 if else 函数的 int 值? 例如:在我的数据库“armnumber = 3”中,如何在 if else 函数中使用它? 代码 string myConnect
我需要生成唯一的“ids”,问题是,它只能在 1 - 99999 之间。 “好”的是,它仅在与另一列组合时必须是唯一的。 我们有组,每个组都有自己的“group_id”,每个组都需要类似 unique
有这个简单的代码: UPDATE counter SET c= c +1 where id = 1; 并且它在开头的 c 字段中为 null 的情况下不起作用。它只有在已经输入了一些数字时才有效,也就
我正在尝试在 python 中构建一个具有闭包属性的计数器。以下工作中的代码: def generate_counter(): CNT = [0] def add_one():
我使用 CSS 来计算 HTML 文档中的部分: body {counter-reset: sect;} section:before { counter-increment: sect;
我是一名优秀的程序员,十分优秀!