changed zoom to difficulty; removed zoom use
This commit is contained in:
parent
3163a65b1a
commit
d3ae0abac4
@ -10,8 +10,8 @@ class PingPong_CTX2D {
|
|||||||
static get STATE_PLAYING() { return 1; };
|
static get STATE_PLAYING() { return 1; };
|
||||||
static get STATE_ENDED() { return 2; };
|
static get STATE_ENDED() { return 2; };
|
||||||
static get BALL_SIZE() { return 8; };
|
static get BALL_SIZE() { return 8; };
|
||||||
static get SPEED_HUMAN() { return 180; };
|
// static get SPEED_HUMAN() { return 180; };
|
||||||
static get SPEED_CPU() { return 210; };
|
// static get SPEED_CPU() { return 210; };
|
||||||
|
|
||||||
static get PADDLE_WIDTH() { return 10; };
|
static get PADDLE_WIDTH() { return 10; };
|
||||||
static get PADDLE_HEIGHT() { return 60; };
|
static get PADDLE_HEIGHT() { return 60; };
|
||||||
@ -28,12 +28,13 @@ class PingPong_CTX2D {
|
|||||||
animationRequestId = 0;
|
animationRequestId = 0;
|
||||||
running = false;
|
running = false;
|
||||||
|
|
||||||
constructor(divId, width, height, zoom = 1, showFps = false) {
|
constructor(divId, width, height, difficulty = 1, showFps = false) {
|
||||||
this.createCanvas(divId, width, height, zoom);
|
this.createCanvas(divId, width, height);
|
||||||
this.canvasEl.title = "Playing: PingPong";
|
this.canvasEl.title = "Playing: PingPong";
|
||||||
this.ctx = this.canvasEl.getContext("2d");
|
this.ctx = this.canvasEl.getContext("2d");
|
||||||
this.ctx.textAlign = "center";
|
this.ctx.textAlign = "center";
|
||||||
|
|
||||||
|
this.difficulty = difficulty;
|
||||||
this.audioCtx = new AudioContext();
|
this.audioCtx = new AudioContext();
|
||||||
this.sounds = [];
|
this.sounds = [];
|
||||||
this.sounds[0] = new Audio('./snd/glass-knock.mp3');
|
this.sounds[0] = new Audio('./snd/glass-knock.mp3');
|
||||||
@ -70,7 +71,7 @@ class PingPong_CTX2D {
|
|||||||
if (typeof WTerminal === "function") {
|
if (typeof WTerminal === "function") {
|
||||||
WTerminal.terminalAddCommand("restartgame", (t) => this.terminalRestartGame(t));
|
WTerminal.terminalAddCommand("restartgame", (t) => this.terminalRestartGame(t));
|
||||||
WTerminal.terminalAddCommand("printgame", (t) => t.printVar(this, "pong"));
|
WTerminal.terminalAddCommand("printgame", (t) => t.printVar(this, "pong"));
|
||||||
WTerminal.printLn("new PingPong: @", divId, ' ', width, 'x', height, ':', zoom, ' showFps=', showFps);
|
WTerminal.printLn("new PingPong: @", divId, ' ', width, 'x', height, ' difficulty=', difficulty, ' showFps=', showFps);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.drawCanvas();
|
this.drawCanvas();
|
||||||
@ -95,10 +96,33 @@ class PingPong_CTX2D {
|
|||||||
newRound() {
|
newRound() {
|
||||||
this.countDown = 3; // seconds;
|
this.countDown = 3; // seconds;
|
||||||
this.gameState = PingPong_CTX2D.STATE_COUNTDOWN;
|
this.gameState = PingPong_CTX2D.STATE_COUNTDOWN;
|
||||||
|
// set paddle speeds
|
||||||
|
if (this.difficulty == 0) {
|
||||||
|
this.speedHuman = 100;
|
||||||
|
this.speedCPU = 80;
|
||||||
|
} else if (this.difficulty == 1) {
|
||||||
|
this.speedHuman = 180;
|
||||||
|
this.speedCPU = 210;
|
||||||
|
} else {
|
||||||
|
this.speedHuman = 150 + 30 * this.difficulty;
|
||||||
|
this.speedCPU = 170 + 40 * this.difficulty;
|
||||||
|
}
|
||||||
|
|
||||||
// randomize ball speed
|
// randomize ball speed
|
||||||
let vx = 200 + Math.random() * 100;
|
let vx = 100;
|
||||||
let vy = -20 + Math.random() * 20;
|
let vy = 0;
|
||||||
if (Math.random() > 0.5) vx = - vx;
|
if (this.difficulty == 0) {
|
||||||
|
vx = 100 + Math.random() * 50;
|
||||||
|
vy = -10 + Math.random() * 10;
|
||||||
|
} else if (this.difficulty == 1) {
|
||||||
|
vx = 200 + Math.random() * 100;
|
||||||
|
vy = -20 + Math.random() * 20;
|
||||||
|
if (Math.random() > 0.5) vx = - vx;
|
||||||
|
} else {
|
||||||
|
vx = 200 + 100 * this.difficulty + Math.random() * 80 * this.difficulty;
|
||||||
|
vy = -30 + 10 * this.difficulty + Math.random() * 10 * this.difficulty;
|
||||||
|
if (Math.random() > 0.5) vx = - vx;
|
||||||
|
}
|
||||||
if (Math.random() > 0.5) vy = - vy;
|
if (Math.random() > 0.5) vy = - vy;
|
||||||
// generate objects
|
// generate objects
|
||||||
this.ball = new Ball(this.width / 2 - PingPong_CTX2D.BALL_SIZE / 2, this.height / 2 - PingPong_CTX2D.BALL_SIZE / 2,
|
this.ball = new Ball(this.width / 2 - PingPong_CTX2D.BALL_SIZE / 2, this.height / 2 - PingPong_CTX2D.BALL_SIZE / 2,
|
||||||
@ -235,9 +259,9 @@ class PingPong_CTX2D {
|
|||||||
} else if (this.gameState == PingPong_CTX2D.STATE_PLAYING) {
|
} else if (this.gameState == PingPong_CTX2D.STATE_PLAYING) {
|
||||||
//cpu actions
|
//cpu actions
|
||||||
if (this.ball.y + this.ball.height / 2 < this.cpu.y + this.cpu.height / 2) {
|
if (this.ball.y + this.ball.height / 2 < this.cpu.y + this.cpu.height / 2) {
|
||||||
this.cpu.vy = -PingPong_CTX2D.SPEED_CPU;
|
this.cpu.vy = -this.speedCPU;
|
||||||
} else if (this.ball.y > this.cpu.y + this.cpu.height / 2) {
|
} else if (this.ball.y > this.cpu.y + this.cpu.height / 2) {
|
||||||
this.cpu.vy = PingPong_CTX2D.SPEED_CPU;
|
this.cpu.vy = this.speedCPU;
|
||||||
} else {
|
} else {
|
||||||
this.cpu.vy = 0;
|
this.cpu.vy = 0;
|
||||||
}
|
}
|
||||||
@ -351,11 +375,11 @@ class PingPong_CTX2D {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (e.key == PingPong_CTX2D.KEY_ARROW_UP || e.key == PingPong_CTX2D.KEY_W) {
|
if (e.key == PingPong_CTX2D.KEY_ARROW_UP || e.key == PingPong_CTX2D.KEY_W) {
|
||||||
this.human.vy = -PingPong_CTX2D.SPEED_HUMAN;
|
this.human.vy = -this.speedHuman;
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
return false;
|
return false;
|
||||||
} else if (e.key == PingPong_CTX2D.KEY_ARROW_DOWN || e.key == PingPong_CTX2D.KEY_S) {
|
} else if (e.key == PingPong_CTX2D.KEY_ARROW_DOWN || e.key == PingPong_CTX2D.KEY_S) {
|
||||||
this.human.vy = PingPong_CTX2D.SPEED_HUMAN;
|
this.human.vy = this.speedHuman;
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
return false;
|
return false;
|
||||||
} else if (e.key == PingPong_CTX2D.KEY_ENTER || e.key == PingPong_CTX2D.KEY_SPACEBAR) {
|
} else if (e.key == PingPong_CTX2D.KEY_ENTER || e.key == PingPong_CTX2D.KEY_SPACEBAR) {
|
||||||
@ -466,6 +490,6 @@ class Paddle extends Rectangle {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function startPingPong(divId, width = 480, height = 320, zoom = 1, showFps = true) {
|
function startPingPong(divId, width = 480, height = 320, difficulty = 1, showFps = true) {
|
||||||
return new PingPong_CTX2D(divId, width, height, zoom, showFps);
|
return new PingPong_CTX2D(divId, width, height, difficulty, showFps);
|
||||||
}
|
}
|
||||||
|
@ -5,7 +5,7 @@ class Tetris_CTX2D {
|
|||||||
static get DEBUG_PARENT_OBJECT() { return true; };
|
static get DEBUG_PARENT_OBJECT() { return true; };
|
||||||
static get AUTO_CONTINUE_ON_FOCUS() { return false; };
|
static get AUTO_CONTINUE_ON_FOCUS() { return false; };
|
||||||
static get SHOW_FPS_INTERVAL() { return 1000 / 4; }; // four times per second
|
static get SHOW_FPS_INTERVAL() { return 1000 / 4; }; // four times per second
|
||||||
static get TICK_TIME() { return 1 / 4; };
|
// static get TICK_TIME() { return 1 / 4; };
|
||||||
|
|
||||||
static get STATE_RUNNING() { return 0; };
|
static get STATE_RUNNING() { return 0; };
|
||||||
static get STATE_ENDED() { return 1; };
|
static get STATE_ENDED() { return 1; };
|
||||||
@ -58,11 +58,12 @@ class Tetris_CTX2D {
|
|||||||
running = false;
|
running = false;
|
||||||
animationRequestId = 0;
|
animationRequestId = 0;
|
||||||
|
|
||||||
constructor(divId, width, height, zoom = 1, showFps = false) {
|
constructor(divId, width, height, difficulty = 1, showFps = false) {
|
||||||
this.createCanvas(divId, width, height, zoom);
|
this.createCanvas(divId, width, height);
|
||||||
this.canvasEl.title = "Playing: Tetris";
|
this.canvasEl.title = "Playing: Tetris";
|
||||||
this.ctx = this.canvasEl.getContext("2d");
|
this.ctx = this.canvasEl.getContext("2d");
|
||||||
this.ctx.textAlign = "center";
|
this.ctx.textAlign = "center";
|
||||||
|
this.difficulty = difficulty;
|
||||||
|
|
||||||
this.BLOCK_WIDTH = this.width / Tetris_CTX2D.GRID_COLUMS;
|
this.BLOCK_WIDTH = this.width / Tetris_CTX2D.GRID_COLUMS;
|
||||||
this.BLOCK_HEIGHT = this.height / Tetris_CTX2D.GRID_ROWS;
|
this.BLOCK_HEIGHT = this.height / Tetris_CTX2D.GRID_ROWS;
|
||||||
@ -103,7 +104,7 @@ class Tetris_CTX2D {
|
|||||||
|
|
||||||
if (Tetris_CTX2D.DEBUG_PARENT_OBJECT) window.game = this;
|
if (Tetris_CTX2D.DEBUG_PARENT_OBJECT) window.game = this;
|
||||||
if (typeof terminalAddCommand === "function") terminalAddCommand("restartgame", (t) => this.terminalRestartGame(t));
|
if (typeof terminalAddCommand === "function") terminalAddCommand("restartgame", (t) => this.terminalRestartGame(t));
|
||||||
if (typeof terminalPrintLn === "function") terminalPrintLn("new Tetris_CTX2D: @", divId, ' ', width, 'x', height, ':', zoom, ' showFps=', showFps);
|
if (typeof terminalPrintLn === "function") terminalPrintLn("new Tetris_CTX2D: @", divId, ' ', width, 'x', height, ' difficulty=', difficulty, ' showFps=', showFps);
|
||||||
|
|
||||||
this.drawCanvas();
|
this.drawCanvas();
|
||||||
}
|
}
|
||||||
@ -288,6 +289,12 @@ class Tetris_CTX2D {
|
|||||||
newGame() {
|
newGame() {
|
||||||
this.gameState = Tetris_CTX2D.STATE_RUNNING;
|
this.gameState = Tetris_CTX2D.STATE_RUNNING;
|
||||||
this.tickTime = 0;
|
this.tickTime = 0;
|
||||||
|
this.stepTime = 1/4;
|
||||||
|
if(this.difficulty == 0){
|
||||||
|
this.stepTime = 1/2;
|
||||||
|
}else{
|
||||||
|
this.stepTime = this.stepTime/ this.difficulty;
|
||||||
|
}
|
||||||
this.initBoard();
|
this.initBoard();
|
||||||
this.score = 0;
|
this.score = 0;
|
||||||
this.nextShape = this.newShape();
|
this.nextShape = this.newShape();
|
||||||
@ -339,8 +346,8 @@ class Tetris_CTX2D {
|
|||||||
//#state switch
|
//#state switch
|
||||||
if (this.gameState == Tetris_CTX2D.STATE_RUNNING) {
|
if (this.gameState == Tetris_CTX2D.STATE_RUNNING) {
|
||||||
this.tickTime += timeDelta;
|
this.tickTime += timeDelta;
|
||||||
if (this.tickTime >= Tetris_CTX2D.TICK_TIME) {
|
if (this.tickTime >= this.stepTime) {
|
||||||
this.tickTime -= Tetris_CTX2D.TICK_TIME;
|
this.tickTime -= this.stepTime;
|
||||||
this.tick();
|
this.tick();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -416,7 +423,7 @@ class Tetris_CTX2D {
|
|||||||
}
|
}
|
||||||
// tickTime
|
// tickTime
|
||||||
ctx.strokeStyle = '#8080B0';
|
ctx.strokeStyle = '#8080B0';
|
||||||
const rotation = this.tickTime / Tetris_CTX2D.TICK_TIME * Math.PI / 2;
|
const rotation = this.tickTime / this.stepTime * Math.PI / 2;
|
||||||
for (let i = 0; i < 4; i++) {
|
for (let i = 0; i < 4; i++) {
|
||||||
const r = rotation + i * Math.PI / 2;
|
const r = rotation + i * Math.PI / 2;
|
||||||
ctx.beginPath();
|
ctx.beginPath();
|
||||||
@ -498,9 +505,8 @@ class Tetris_CTX2D {
|
|||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
return false;
|
return false;
|
||||||
} else if (e.key == Tetris_CTX2D.KEY_ARROW_DOWN || e.key == Tetris_CTX2D.KEY_S) {
|
} else if (e.key == Tetris_CTX2D.KEY_ARROW_DOWN || e.key == Tetris_CTX2D.KEY_S) {
|
||||||
if (this.isValidMove(0, 1)) {
|
this.tick();
|
||||||
this.currentY++;
|
this.tickTime = 0;
|
||||||
}
|
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
return false;
|
return false;
|
||||||
} else if (e.key == Tetris_CTX2D.KEY_ARROW_LEFT || e.key == Tetris_CTX2D.KEY_A) {
|
} else if (e.key == Tetris_CTX2D.KEY_ARROW_LEFT || e.key == Tetris_CTX2D.KEY_A) {
|
||||||
@ -555,6 +561,6 @@ class Tetris_CTX2D {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function startTetris(divId, width = 300, height = 600, zoom = 1, showFps = true) {
|
function startTetris(divId, width = 300, height = 600, difficulty = 1, showFps = true) {
|
||||||
return new Tetris_CTX2D(divId, width, height, zoom, showFps);
|
return new Tetris_CTX2D(divId, width, height, difficulty, showFps);
|
||||||
}
|
}
|
||||||
|
@ -47,7 +47,7 @@ class GamesLauncher {
|
|||||||
|
|
||||||
this.widthEl = createElement('input', { type: 'number', id: 'width', value: '480', style: 'float: right;' });
|
this.widthEl = createElement('input', { type: 'number', id: 'width', value: '480', style: 'float: right;' });
|
||||||
this.heightEl = createElement('input', { type: 'number', id: 'height', value: '320', style: 'float: right;' });
|
this.heightEl = createElement('input', { type: 'number', id: 'height', value: '320', style: 'float: right;' });
|
||||||
this.zoomEl = createElement('input', { type: 'number', id: 'zoom', value: '1', style: 'float: right;' });
|
this.difficultyEl = createElement('input', { type: 'number', id: 'difficulty', value: '1', style: 'float: right;' });
|
||||||
this.showFpsEl = createElement('input', { type: 'checkbox', id: 'showFps', style: 'float: right;' });
|
this.showFpsEl = createElement('input', { type: 'checkbox', id: 'showFps', style: 'float: right;' });
|
||||||
|
|
||||||
this.gameEl.appendChild(createElement('label', { for: 'width' }, 'Width: '));
|
this.gameEl.appendChild(createElement('label', { for: 'width' }, 'Width: '));
|
||||||
@ -56,8 +56,8 @@ class GamesLauncher {
|
|||||||
this.gameEl.appendChild(createElement('label', { for: 'height' }, 'Height: '));
|
this.gameEl.appendChild(createElement('label', { for: 'height' }, 'Height: '));
|
||||||
this.gameEl.appendChild(this.heightEl);
|
this.gameEl.appendChild(this.heightEl);
|
||||||
this.gameEl.appendChild(createElement('br'));
|
this.gameEl.appendChild(createElement('br'));
|
||||||
this.gameEl.appendChild(createElement('label', { for: 'zoom' }, 'Zoom: '));
|
this.gameEl.appendChild(createElement('label', { for: 'difficulty' }, 'difficulty: '));
|
||||||
this.gameEl.appendChild(this.zoomEl);
|
this.gameEl.appendChild(this.difficultyEl);
|
||||||
this.gameEl.appendChild(createElement('br'));
|
this.gameEl.appendChild(createElement('br'));
|
||||||
this.gameEl.appendChild(createElement('label', { for: 'showFps' }, 'showFps: '));
|
this.gameEl.appendChild(createElement('label', { for: 'showFps' }, 'showFps: '));
|
||||||
this.gameEl.appendChild(this.showFpsEl);
|
this.gameEl.appendChild(this.showFpsEl);
|
||||||
@ -86,12 +86,12 @@ class GamesLauncher {
|
|||||||
case 'pong-context2d':
|
case 'pong-context2d':
|
||||||
this.widthEl.value = 480;
|
this.widthEl.value = 480;
|
||||||
this.heightEl.value = 320;
|
this.heightEl.value = 320;
|
||||||
this.zoomEl.value = 1;
|
// this.difficultyEl.value = 1;
|
||||||
break;
|
break;
|
||||||
case 'tetris-context2d':
|
case 'tetris-context2d':
|
||||||
this.widthEl.value = 300;
|
this.widthEl.value = 300;
|
||||||
this.heightEl.value = 600;
|
this.heightEl.value = 600;
|
||||||
this.zoomEl.value = 1;
|
// this.difficultyEl.value = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -100,17 +100,17 @@ class GamesLauncher {
|
|||||||
const selectedValue = this.selectGameEl.value;//this.selectGameEl.options[this.selectGameEl.selectedIndex].value;
|
const selectedValue = this.selectGameEl.value;//this.selectGameEl.options[this.selectGameEl.selectedIndex].value;
|
||||||
const width = this.widthEl.value;
|
const width = this.widthEl.value;
|
||||||
const height = this.heightEl.value;
|
const height = this.heightEl.value;
|
||||||
const zoom = this.zoomEl.value;
|
const difficulty = this.difficultyEl.value;
|
||||||
const showFps = this.showFpsEl.checked;
|
const showFps = this.showFpsEl.checked;
|
||||||
switch (selectedValue) {
|
switch (selectedValue) {
|
||||||
case 'pong-context2d':
|
case 'pong-context2d':
|
||||||
this.createCloseExitGameButton();
|
this.createCloseExitGameButton();
|
||||||
this.currentGame = new PingPong_CTX2D(this.gameId, width, height, zoom, showFps);
|
this.currentGame = new PingPong_CTX2D(this.gameId, width, height, difficulty, showFps);
|
||||||
this.currentGame.canvasEl.focus();
|
this.currentGame.canvasEl.focus();
|
||||||
break;
|
break;
|
||||||
case 'tetris-context2d':
|
case 'tetris-context2d':
|
||||||
this.createCloseExitGameButton();
|
this.createCloseExitGameButton();
|
||||||
this.currentGame = new Tetris_CTX2D(this.gameId, width, height, zoom, showFps);
|
this.currentGame = new Tetris_CTX2D(this.gameId, width, height, difficulty, showFps);
|
||||||
this.currentGame.canvasEl.focus();
|
this.currentGame.canvasEl.focus();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
Loading…
Reference in New Issue
Block a user