2020-12-12 00:17:30 +00:00
|
|
|
%target cx16
|
|
|
|
%import graphics
|
|
|
|
%import textio
|
|
|
|
%import diskio
|
|
|
|
|
|
|
|
main {
|
|
|
|
sub start() {
|
|
|
|
graphics.enable_bitmap_mode()
|
|
|
|
|
2020-12-12 02:32:15 +00:00
|
|
|
if strlen(diskio.status(8)) ; trick to check if we're running on sdcard or host system shared folder
|
|
|
|
show_pics_sdcard()
|
|
|
|
else {
|
|
|
|
txt.print("only works with files on\nsdcard image!\n")
|
|
|
|
}
|
2020-12-12 00:17:30 +00:00
|
|
|
|
|
|
|
repeat {
|
|
|
|
;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub show_pics_sdcard() {
|
|
|
|
|
|
|
|
; load and show all *.pcx pictures on the disk.
|
|
|
|
; this only works in the emulator V38 with an sd-card image with the files on it.
|
|
|
|
|
|
|
|
str[20] filename_ptrs
|
|
|
|
ubyte num_files = diskio.list_files(8, ".pcx", true, &filename_ptrs, len(filename_ptrs))
|
|
|
|
if num_files {
|
|
|
|
while num_files {
|
|
|
|
num_files--
|
|
|
|
show_pcx_image(filename_ptrs[num_files])
|
2020-12-12 02:32:15 +00:00
|
|
|
cx16.wait(120)
|
2020-12-12 00:17:30 +00:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
txt.print("no *.pcx files found\n")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub show_pcx_image(uword filenameptr) {
|
|
|
|
ubyte load_ok = false
|
|
|
|
txt.print(filenameptr)
|
|
|
|
txt.chrout('\n')
|
|
|
|
|
|
|
|
if diskio.f_open(8, filenameptr) {
|
|
|
|
ubyte[128] header
|
|
|
|
uword size = diskio.f_read(header, 128)
|
|
|
|
if size==128 {
|
|
|
|
if header[0] == $0a and header[2] == 1 {
|
|
|
|
ubyte bits_per_pixel = header[3]
|
|
|
|
if bits_per_pixel==1 or bits_per_pixel==4 or bits_per_pixel==8 {
|
|
|
|
uword width = mkword(header[$09], header[$08]) - mkword(header[$05], header[$04]) + 1
|
|
|
|
uword height = mkword(header[$0b], header[$0a]) - mkword(header[$07], header[$06]) + 1
|
|
|
|
ubyte number_of_planes = header[$41]
|
|
|
|
uword palette_format = mkword(header[$45], header[$44])
|
|
|
|
uword num_colors = 2**bits_per_pixel
|
|
|
|
if number_of_planes == 1 {
|
|
|
|
if (width & 7) == 0 {
|
2020-12-14 01:12:26 +00:00
|
|
|
txt.clear_screen()
|
|
|
|
graphics.clear_screen(1, 0)
|
2020-12-12 00:17:30 +00:00
|
|
|
if palette_format==2
|
|
|
|
set_grayscale_palette()
|
|
|
|
else if num_colors == 16
|
2020-12-14 01:12:26 +00:00
|
|
|
set_palette_8rgb(&header + $10, 16)
|
2020-12-12 00:17:30 +00:00
|
|
|
else if num_colors == 2
|
|
|
|
set_monochrome_palette()
|
|
|
|
when bits_per_pixel {
|
|
|
|
8 -> load_ok = bitmap.do8bpp(width, height)
|
|
|
|
4 -> load_ok = bitmap.do4bpp(width, height)
|
|
|
|
1 -> load_ok = bitmap.do1bpp(width, height)
|
|
|
|
}
|
|
|
|
if load_ok {
|
|
|
|
load_ok = c64.CHRIN()
|
|
|
|
if load_ok == 12 {
|
|
|
|
; there is 256 colors of palette data at the end
|
|
|
|
uword palette_mem = progend()
|
|
|
|
load_ok = false
|
|
|
|
size = diskio.f_read(palette_mem, 3*256)
|
|
|
|
if size==3*256 {
|
|
|
|
load_ok = true
|
2020-12-14 01:12:26 +00:00
|
|
|
set_palette_8rgb(palette_mem, num_colors)
|
2020-12-12 00:17:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else
|
|
|
|
txt.print("width not multiple of 8!\n")
|
|
|
|
} else
|
|
|
|
txt.print("has >256 colors!\n")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
diskio.f_close()
|
|
|
|
}
|
|
|
|
|
|
|
|
if not load_ok {
|
|
|
|
txt.print("load error!\n")
|
|
|
|
txt.print(diskio.status(8))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub set_monochrome_palette() {
|
|
|
|
uword vera_palette_ptr = $fa00
|
|
|
|
cx16.vpoke(1, vera_palette_ptr, 0)
|
|
|
|
vera_palette_ptr++
|
|
|
|
cx16.vpoke(1, vera_palette_ptr, 0)
|
|
|
|
vera_palette_ptr++
|
|
|
|
repeat 255 {
|
|
|
|
cx16.vpoke(1, vera_palette_ptr, 255)
|
|
|
|
vera_palette_ptr++
|
|
|
|
cx16.vpoke(1, vera_palette_ptr, 255)
|
|
|
|
vera_palette_ptr++
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub set_grayscale_palette() {
|
|
|
|
ubyte c = 0
|
|
|
|
uword vera_palette_ptr = $fa00
|
|
|
|
repeat 16 {
|
|
|
|
repeat 16 {
|
|
|
|
cx16.vpoke(1, vera_palette_ptr, c)
|
|
|
|
vera_palette_ptr++
|
|
|
|
cx16.vpoke(1, vera_palette_ptr, c)
|
|
|
|
vera_palette_ptr++
|
|
|
|
}
|
|
|
|
c += $11
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-12-14 01:12:26 +00:00
|
|
|
sub set_palette_8rgb(uword palletteptr, uword num_colors) {
|
2020-12-12 00:17:30 +00:00
|
|
|
uword vera_palette_ptr = $fa00
|
|
|
|
ubyte red
|
|
|
|
ubyte greenblue
|
|
|
|
|
|
|
|
; 3 bytes per color entry, adjust color depth from 8 to 4 bits per channel.
|
|
|
|
repeat num_colors {
|
|
|
|
red = @(palletteptr) >> 4
|
|
|
|
palletteptr++
|
|
|
|
greenblue = @(palletteptr) & %11110000
|
|
|
|
palletteptr++
|
|
|
|
greenblue |= @(palletteptr) >> 4 ; add Blue
|
|
|
|
palletteptr++
|
|
|
|
cx16.vpoke(1, vera_palette_ptr, greenblue)
|
|
|
|
vera_palette_ptr++
|
|
|
|
cx16.vpoke(1, vera_palette_ptr, red)
|
|
|
|
vera_palette_ptr++
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
bitmap {
|
|
|
|
|
|
|
|
uword offsetx
|
|
|
|
uword offsety
|
|
|
|
uword py
|
|
|
|
uword px
|
2020-12-12 02:32:15 +00:00
|
|
|
ubyte y_ok
|
2020-12-12 00:17:30 +00:00
|
|
|
ubyte status
|
|
|
|
|
2020-12-12 02:32:15 +00:00
|
|
|
sub start_plot(uword width, uword height) {
|
2020-12-12 00:17:30 +00:00
|
|
|
offsetx = 0
|
|
|
|
offsety = 0
|
2020-12-12 02:32:15 +00:00
|
|
|
y_ok = true
|
2020-12-12 00:17:30 +00:00
|
|
|
py = 0
|
|
|
|
px = 0
|
|
|
|
if width < graphics.WIDTH
|
2020-12-12 02:32:15 +00:00
|
|
|
offsetx = (graphics.WIDTH - width - 1) / 2
|
2020-12-12 00:17:30 +00:00
|
|
|
if height < graphics.HEIGHT
|
2020-12-12 02:32:15 +00:00
|
|
|
offsety = (graphics.HEIGHT - height - 1) / 2
|
2020-12-12 00:17:30 +00:00
|
|
|
status = (not c64.READST()) or c64.READST()==64
|
|
|
|
}
|
|
|
|
|
|
|
|
sub set_cursor(uword x, uword y) {
|
|
|
|
cx16.r0=offsetx+x
|
|
|
|
cx16.r1=offsety+y
|
|
|
|
cx16.FB_cursor_position()
|
|
|
|
}
|
|
|
|
|
2020-12-12 02:32:15 +00:00
|
|
|
sub next_scanline() {
|
|
|
|
px = 0
|
|
|
|
py++
|
|
|
|
y_ok = py < graphics.HEIGHT-1
|
|
|
|
set_cursor(0, py)
|
|
|
|
status = (not c64.READST()) or c64.READST()==64
|
|
|
|
}
|
|
|
|
|
2020-12-12 00:17:30 +00:00
|
|
|
sub do1bpp(uword width, uword height) -> ubyte {
|
2020-12-12 02:32:15 +00:00
|
|
|
start_plot(width, height)
|
2020-12-12 00:17:30 +00:00
|
|
|
set_cursor(0, 0)
|
|
|
|
while py < height and status {
|
|
|
|
ubyte b = c64.CHRIN()
|
|
|
|
if b>>6==3 {
|
2020-12-12 02:32:15 +00:00
|
|
|
b &= %00111111
|
|
|
|
ubyte dat = c64.CHRIN()
|
|
|
|
repeat b {
|
|
|
|
if y_ok {
|
|
|
|
cx16.r0 = dat
|
|
|
|
cx16.FB_set_8_pixels_opaque(255, 255, 0)
|
2020-12-12 00:17:30 +00:00
|
|
|
}
|
2020-12-12 02:32:15 +00:00
|
|
|
px += 8
|
2020-12-12 00:17:30 +00:00
|
|
|
}
|
|
|
|
} else {
|
2020-12-12 02:32:15 +00:00
|
|
|
if y_ok {
|
|
|
|
cx16.r0 = b
|
|
|
|
cx16.FB_set_8_pixels_opaque(255, 255, 0)
|
|
|
|
}
|
|
|
|
px += 8
|
2020-12-12 00:17:30 +00:00
|
|
|
}
|
2020-12-12 02:32:15 +00:00
|
|
|
if px==width
|
|
|
|
next_scanline()
|
2020-12-12 00:17:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return status
|
|
|
|
}
|
|
|
|
|
|
|
|
sub do4bpp(uword width, uword height) -> ubyte {
|
2020-12-12 02:32:15 +00:00
|
|
|
start_plot(width, height)
|
2020-12-12 00:17:30 +00:00
|
|
|
set_cursor(0, 0)
|
|
|
|
while py < height and status {
|
|
|
|
ubyte b = c64.CHRIN()
|
|
|
|
if b>>6==3 {
|
2020-12-12 02:32:15 +00:00
|
|
|
b &= %00111111
|
|
|
|
ubyte dat = c64.CHRIN()
|
2020-12-12 00:17:30 +00:00
|
|
|
if y_ok
|
2020-12-12 02:32:15 +00:00
|
|
|
repeat b {
|
|
|
|
cx16.FB_set_pixel(dat>>4)
|
|
|
|
cx16.FB_set_pixel(dat & 15)
|
2020-12-12 00:17:30 +00:00
|
|
|
}
|
2020-12-12 02:32:15 +00:00
|
|
|
px += b*2
|
2020-12-12 00:17:30 +00:00
|
|
|
} else {
|
|
|
|
if y_ok {
|
2020-12-12 02:32:15 +00:00
|
|
|
cx16.FB_set_pixel(b>>4)
|
2020-12-12 00:17:30 +00:00
|
|
|
cx16.FB_set_pixel(b & 15)
|
|
|
|
}
|
2020-12-12 02:32:15 +00:00
|
|
|
px += 2
|
2020-12-12 00:17:30 +00:00
|
|
|
}
|
2020-12-12 02:32:15 +00:00
|
|
|
if px==width
|
|
|
|
next_scanline()
|
2020-12-12 00:17:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return status
|
|
|
|
}
|
|
|
|
|
|
|
|
sub do8bpp(uword width, uword height) -> ubyte {
|
2020-12-12 02:32:15 +00:00
|
|
|
start_plot(width, height)
|
2020-12-12 00:17:30 +00:00
|
|
|
set_cursor(0, 0)
|
|
|
|
while py < height and status {
|
|
|
|
ubyte b = c64.CHRIN()
|
|
|
|
if b>>6==3 {
|
2020-12-12 02:32:15 +00:00
|
|
|
b &= %00111111
|
|
|
|
ubyte dat = c64.CHRIN()
|
2020-12-12 00:17:30 +00:00
|
|
|
if y_ok
|
2020-12-12 02:32:15 +00:00
|
|
|
repeat b
|
|
|
|
cx16.FB_set_pixel(dat)
|
|
|
|
px += b
|
2020-12-12 00:17:30 +00:00
|
|
|
} else {
|
|
|
|
if y_ok
|
|
|
|
cx16.FB_set_pixel(b)
|
|
|
|
px++
|
|
|
|
}
|
2020-12-12 02:32:15 +00:00
|
|
|
if px==width
|
|
|
|
next_scanline()
|
2020-12-12 00:17:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return status
|
|
|
|
}
|
|
|
|
}
|