mirror of
https://github.com/irmen/prog8.git
synced 2025-01-23 15:30:10 +00:00
simple sound effects
This commit is contained in:
parent
b040e5ddad
commit
7f36d08acc
@ -3,7 +3,6 @@
|
|||||||
;
|
;
|
||||||
|
|
||||||
; @todo: holding a block
|
; @todo: holding a block
|
||||||
; @todo: simple sound effects? slight click when moving, swish when rotating/dropping, soft explosion when lines are cleared, buzz at game over
|
|
||||||
; @todo: joystick control
|
; @todo: joystick control
|
||||||
; @todo: sometimes the game gets confused about what the current tetromino is and will draw the wrong one. Maybe occurs when rotating directly after dropping the previous?
|
; @todo: sometimes the game gets confused about what the current tetromino is and will draw the wrong one. Maybe occurs when rotating directly after dropping the previous?
|
||||||
|
|
||||||
@ -44,7 +43,6 @@ waitkey:
|
|||||||
if blocklogic.noCollision(xpos, ypos+1) {
|
if blocklogic.noCollision(xpos, ypos+1) {
|
||||||
; slowly move the block down
|
; slowly move the block down
|
||||||
ypos++
|
ypos++
|
||||||
sound.blockmove()
|
|
||||||
drawBlock(xpos, ypos, 160) ; show block on new position
|
drawBlock(xpos, ypos, 160) ; show block on new position
|
||||||
} else {
|
} else {
|
||||||
; block can't move further down!
|
; block can't move further down!
|
||||||
@ -76,7 +74,6 @@ waitkey:
|
|||||||
drawBlock(xpos, ypos, 32)
|
drawBlock(xpos, ypos, 32)
|
||||||
if blocklogic.noCollision(xpos-1, ypos) {
|
if blocklogic.noCollision(xpos-1, ypos) {
|
||||||
xpos--
|
xpos--
|
||||||
sound.blockrotatedrop()
|
|
||||||
}
|
}
|
||||||
drawBlock(xpos, ypos, 160)
|
drawBlock(xpos, ypos, 160)
|
||||||
}
|
}
|
||||||
@ -85,7 +82,6 @@ waitkey:
|
|||||||
drawBlock(xpos, ypos, 32)
|
drawBlock(xpos, ypos, 32)
|
||||||
if blocklogic.noCollision(xpos+1, ypos) {
|
if blocklogic.noCollision(xpos+1, ypos) {
|
||||||
xpos++
|
xpos++
|
||||||
sound.blockrotatedrop()
|
|
||||||
}
|
}
|
||||||
drawBlock(xpos, ypos, 160)
|
drawBlock(xpos, ypos, 160)
|
||||||
}
|
}
|
||||||
@ -94,7 +90,6 @@ waitkey:
|
|||||||
drawBlock(xpos, ypos, 32)
|
drawBlock(xpos, ypos, 32)
|
||||||
if blocklogic.noCollision(xpos, ypos+1) {
|
if blocklogic.noCollision(xpos, ypos+1) {
|
||||||
ypos++
|
ypos++
|
||||||
sound.blockrotatedrop()
|
|
||||||
}
|
}
|
||||||
drawBlock(xpos, ypos, 160)
|
drawBlock(xpos, ypos, 160)
|
||||||
}
|
}
|
||||||
@ -110,7 +105,7 @@ waitkey:
|
|||||||
}
|
}
|
||||||
if dropypos>ypos {
|
if dropypos>ypos {
|
||||||
ypos = dropypos
|
ypos = dropypos
|
||||||
sound.blockrotatedrop()
|
sound.blockdrop()
|
||||||
drawBlock(xpos, ypos, 160)
|
drawBlock(xpos, ypos, 160)
|
||||||
checkForLines()
|
checkForLines()
|
||||||
spawnNextBlock()
|
spawnNextBlock()
|
||||||
@ -121,17 +116,17 @@ waitkey:
|
|||||||
drawBlock(xpos, ypos, 32)
|
drawBlock(xpos, ypos, 32)
|
||||||
if blocklogic.canRotateCCW(xpos, ypos) {
|
if blocklogic.canRotateCCW(xpos, ypos) {
|
||||||
blocklogic.rotateCCW()
|
blocklogic.rotateCCW()
|
||||||
sound.blockrotatedrop()
|
sound.blockrotate()
|
||||||
}
|
}
|
||||||
else if blocklogic.canRotateCCW(xpos-1, ypos) {
|
else if blocklogic.canRotateCCW(xpos-1, ypos) {
|
||||||
xpos--
|
xpos--
|
||||||
blocklogic.rotateCCW()
|
blocklogic.rotateCCW()
|
||||||
sound.blockrotatedrop()
|
sound.blockrotate()
|
||||||
}
|
}
|
||||||
else if blocklogic.canRotateCCW(xpos+1, ypos) {
|
else if blocklogic.canRotateCCW(xpos+1, ypos) {
|
||||||
xpos++
|
xpos++
|
||||||
blocklogic.rotateCCW()
|
blocklogic.rotateCCW()
|
||||||
sound.blockrotatedrop()
|
sound.blockrotate()
|
||||||
}
|
}
|
||||||
drawBlock(xpos, ypos, 160)
|
drawBlock(xpos, ypos, 160)
|
||||||
}
|
}
|
||||||
@ -140,17 +135,17 @@ waitkey:
|
|||||||
drawBlock(xpos, ypos, 32)
|
drawBlock(xpos, ypos, 32)
|
||||||
if blocklogic.canRotateCW(xpos, ypos) {
|
if blocklogic.canRotateCW(xpos, ypos) {
|
||||||
blocklogic.rotateCW()
|
blocklogic.rotateCW()
|
||||||
sound.blockrotatedrop()
|
sound.blockrotate()
|
||||||
}
|
}
|
||||||
else if blocklogic.canRotateCW(xpos-1, ypos) {
|
else if blocklogic.canRotateCW(xpos-1, ypos) {
|
||||||
xpos--
|
xpos--
|
||||||
blocklogic.rotateCW()
|
blocklogic.rotateCW()
|
||||||
sound.blockrotatedrop()
|
sound.blockrotate()
|
||||||
}
|
}
|
||||||
else if blocklogic.canRotateCW(xpos+1, ypos) {
|
else if blocklogic.canRotateCW(xpos+1, ypos) {
|
||||||
xpos++
|
xpos++
|
||||||
blocklogic.rotateCW()
|
blocklogic.rotateCW()
|
||||||
sound.blockrotatedrop()
|
sound.blockrotate()
|
||||||
}
|
}
|
||||||
drawBlock(xpos, ypos, 160)
|
drawBlock(xpos, ypos, 160)
|
||||||
}
|
}
|
||||||
@ -170,6 +165,7 @@ waitkey:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if num_lines {
|
if num_lines {
|
||||||
|
sound.lineclear()
|
||||||
c64.TIME_LO=0
|
c64.TIME_LO=0
|
||||||
while c64.TIME_LO<20 {
|
while c64.TIME_LO<20 {
|
||||||
; slight delay to flash the line
|
; slight delay to flash the line
|
||||||
@ -228,7 +224,6 @@ waitkey:
|
|||||||
}
|
}
|
||||||
|
|
||||||
sub spawnNextBlock() {
|
sub spawnNextBlock() {
|
||||||
sound.blockmove()
|
|
||||||
c64.TIME_LO = 0
|
c64.TIME_LO = 0
|
||||||
blocklogic.newCurrentBlock(nextBlock)
|
blocklogic.newCurrentBlock(nextBlock)
|
||||||
nextBlock = (rnd() + c64.RASTER) % 7
|
nextBlock = (rnd() + c64.RASTER) % 7
|
||||||
@ -521,22 +516,46 @@ waitkey:
|
|||||||
~ sound {
|
~ sound {
|
||||||
|
|
||||||
sub init() {
|
sub init() {
|
||||||
; todo
|
c64.MVOL = 15
|
||||||
}
|
}
|
||||||
|
|
||||||
sub blockmove() {
|
sub blockrotate() {
|
||||||
; todo soft click
|
; soft click
|
||||||
|
c64.MVOL = 5
|
||||||
|
c64.AD1 = %00100010
|
||||||
|
c64.SR1 = %00000000
|
||||||
|
c64.FREQ1 = 15600
|
||||||
|
c64.CR1 = %10000000
|
||||||
|
c64.CR1 = %10000001
|
||||||
}
|
}
|
||||||
|
|
||||||
sub blockrotatedrop() {
|
sub blockdrop() {
|
||||||
; todo swish
|
; swish
|
||||||
|
c64.MVOL = 5
|
||||||
|
c64.AD1 = %01010111
|
||||||
|
c64.SR1 = %00000000
|
||||||
|
c64.FREQ1 = 4600
|
||||||
|
c64.CR1 = %10000000
|
||||||
|
c64.CR1 = %10000001
|
||||||
}
|
}
|
||||||
|
|
||||||
sub lineclear() {
|
sub lineclear() {
|
||||||
; todo explosion like
|
; explosion
|
||||||
|
c64.MVOL = 15
|
||||||
|
c64.AD1 = %01100110
|
||||||
|
c64.SR1 = %00000000
|
||||||
|
c64.FREQ1 = 1600
|
||||||
|
c64.CR1 = %10000000
|
||||||
|
c64.CR1 = %10000001
|
||||||
}
|
}
|
||||||
|
|
||||||
sub gameover() {
|
sub gameover() {
|
||||||
; todo buzz?
|
; buzz
|
||||||
|
c64.MVOL = 15
|
||||||
|
c64.FREQ2 = 600
|
||||||
|
c64.AD2 = %00111010
|
||||||
|
c64.SR2 = %00000000
|
||||||
|
c64.CR2 = %00110000
|
||||||
|
c64.CR2 = %00110001
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user