prog8/examples/vm/bouncegfx.p8

61 lines
1.7 KiB
Plaintext
Raw Normal View History

2022-07-03 00:41:04 +02:00
; NOTE: meant to test to virtual machine output target (use -target virtual)
%import math
2022-07-03 00:41:04 +02:00
main {
sub start() {
word[128] @split particleX
word[128] @split particleY
2022-07-03 00:41:04 +02:00
byte[128] particleDX
byte[128] particleDY
ubyte pi
for pi in 0 to 127 {
particleX[pi] = math.rndw() % 319 as word
particleY[pi] = math.rndw() % 240 as word
particleDX[pi] = (math.rnd() & 1)*2 as byte - 1
particleDY[pi] = (math.rnd() & 1)*2 as byte - 1
2022-07-03 00:41:04 +02:00
}
sys.gfx_enable(0) ; enable lo res screen
repeat {
fade()
plot_particles()
sys.wait(1)
2022-07-03 00:41:04 +02:00
sys.waitvsync()
}
sub fade() {
uword xx
uword yy
for yy in 0 to 239 {
for xx in 0 to 319 {
ubyte pixel = sys.gfx_getpixel(xx, yy)
if pixel>4 {
2022-07-03 00:41:04 +02:00
pixel-=4
sys.gfx_plot(xx, yy, pixel)
}
2022-07-03 00:41:04 +02:00
}
}
}
sub plot_particles() {
for pi in 0 to 127 {
particleX[pi] += particleDX[pi]
particleY[pi] += particleDY[pi]
if particleX[pi]<0 or particleX[pi]>319 {
particleDX[pi] *= -1
particleX[pi] += particleDX[pi] * 2
}
if particleY[pi]<0 or particleY[pi]>239 {
particleDY[pi] *= -1
particleY[pi] += particleDY[pi] * 2
}
sys.gfx_plot(particleX[pi] as uword, particleY[pi] as uword, 255)
}
}
}
}