prog8/examples/cx16/highresbitmap.p8

85 lines
2.2 KiB
Plaintext
Raw Normal View History

%import monogfx
%import floats
%import textio
%import math
2021-04-05 21:45:39 +02:00
%zeropage dontuse
main {
sub start () {
monogfx.text_charset(3)
test_monochrome()
monogfx.textmode()
txt.print("done!\n")
}
sub test_monochrome() {
monogfx.hires()
uword yy
uword xx
word ww
yy = 20
xx = 20
monogfx.stipple(false)
monogfx.rect(xx, yy, 250, 80, 1)
monogfx.stipple(true)
monogfx.fillrect(xx+2, yy+2, 250-4, 80-4, 1)
monogfx.stipple(false)
monogfx.fillrect(xx+20, yy+20, 200, 30, 1)
monogfx.rect(xx+21, yy+21, 200-2, 30-2, 0)
monogfx.text(xx+30, yy+32, 0, sc:"High Res Bitmap Example")
; monogfx.stipple(true)
monogfx.horizontal_line(10, 240, 620, 1)
monogfx.vertical_line(320, 10, 460, 1)
monogfx.text(320, 242, 1, sc:"0,0")
monogfx.text(322, 10, 1, sc:"Y-axis")
monogfx.text(590, 242, 1, sc:"X-axis")
for ww in -10 to 10 {
xx = (ww*30) + 320 as uword
monogfx.vertical_line(xx, 239, 3, 1)
}
for ww in -7 to 7 {
yy = (ww*30) + 240 as uword
monogfx.horizontal_line(319, yy, 3, 1)
}
monogfx.stipple(false)
float y_f
for ww in -600 to 600 {
y_f = floats.sin(ww as float / 60.0)*150
monogfx.plot(ww/2 + 320 as uword, (y_f + 240) as uword, 1)
}
monogfx.text(480, 100, 1, sc:"sin(x)")
for ww in -300 to 300 {
y_f = floats.cos(ww as float/30.0)*60 - (ww as float)/1.7
monogfx.plot(ww + 320 as uword, (y_f + 240) as uword, 1)
}
monogfx.text(80, 420, 1, sc:"cos(x)+x")
sys.wait(3*60)
monogfx.circle(320, 240, 220, 1)
monogfx.circle(320, 240, 210, 1)
monogfx.circle(320, 240, 200, 1)
monogfx.circle(320, 240, 190, 1)
monogfx.stipple(true)
monogfx.disc(320, 240, 140, 1)
monogfx.stipple(false)
monogfx.disc(320, 240, 90, 1)
monogfx.disc(320, 240, 40, 0)
sys.wait(2*60)
2020-12-28 00:08:22 +01:00
repeat 255
monogfx.line(math.rndw() % 640, math.rndw() % 480, math.rndw() % 640, math.rndw() % 480, 1)
sys.wait(1*60)
}
}