Space.c is uploaded. Compiles in release version, but not in latest kickc version; Assembly fails.
262
src/main/fragment/cache/fragment-cache-wdc65c02.asm
vendored
@ -3812,3 +3812,265 @@ inc {z1}+2
|
|||||||
bne !+
|
bne !+
|
||||||
inc {z1}+3
|
inc {z1}+3
|
||||||
!:
|
!:
|
||||||
|
//FRAGMENT isr_rom_sys_cx16_entry
|
||||||
|
|
||||||
|
//FRAGMENT vbuz1=_dec_vbuz1
|
||||||
|
dec {z1}
|
||||||
|
//FRAGMENT vwuz1_lt_vbuc1_then_la1
|
||||||
|
lda {z1}+1
|
||||||
|
bne !+
|
||||||
|
lda {z1}
|
||||||
|
cmp #{c1}
|
||||||
|
bcc {la1}
|
||||||
|
!:
|
||||||
|
//FRAGMENT 0_eq_vwuz1_then_la1
|
||||||
|
lda {z1}
|
||||||
|
ora {z1}+1
|
||||||
|
beq {la1}
|
||||||
|
//FRAGMENT _deref_(_deref_qbuc1)=vbuz1
|
||||||
|
lda {z1}
|
||||||
|
ldy {c1}
|
||||||
|
sty $fe
|
||||||
|
ldy {c1}+1
|
||||||
|
sty $ff
|
||||||
|
ldy #0
|
||||||
|
sta ($fe),y
|
||||||
|
//FRAGMENT isr_rom_sys_cx16_exit
|
||||||
|
jmp $e034
|
||||||
|
//FRAGMENT vwuz1=vwuz2_plus_vbuz3
|
||||||
|
lda {z3}
|
||||||
|
clc
|
||||||
|
adc {z2}
|
||||||
|
sta {z1}
|
||||||
|
lda #0
|
||||||
|
adc {z2}+1
|
||||||
|
sta {z1}+1
|
||||||
|
//FRAGMENT vwuz1=vwuz1_minus_vbuc1
|
||||||
|
sec
|
||||||
|
lda {z1}
|
||||||
|
sbc #{c1}
|
||||||
|
sta {z1}
|
||||||
|
lda {z1}+1
|
||||||
|
sbc #0
|
||||||
|
sta {z1}+1
|
||||||
|
//FRAGMENT _deref_pwuc1=_deref_pwuz1
|
||||||
|
ldy #0
|
||||||
|
lda ({z1}),y
|
||||||
|
sta {c1}
|
||||||
|
iny
|
||||||
|
lda ({z1}),y
|
||||||
|
sta {c1}+1
|
||||||
|
//FRAGMENT vwuz1=vwuc1_plus_vwuz2
|
||||||
|
clc
|
||||||
|
lda {z2}
|
||||||
|
adc #<{c1}
|
||||||
|
sta {z1}
|
||||||
|
lda {z2}+1
|
||||||
|
adc #>{c1}
|
||||||
|
sta {z1}+1
|
||||||
|
//FRAGMENT _deref_pwuc1=vwuz1
|
||||||
|
lda {z1}
|
||||||
|
sta {c1}
|
||||||
|
lda {z1}+1
|
||||||
|
sta {c1}+1
|
||||||
|
//FRAGMENT pbuz1=pbuz1_plus_vbuc1
|
||||||
|
lda #{c1}
|
||||||
|
clc
|
||||||
|
adc {z1}
|
||||||
|
sta {z1}
|
||||||
|
bcc !+
|
||||||
|
inc {z1}+1
|
||||||
|
!:
|
||||||
|
//FRAGMENT _deref_qprc1=pprc2
|
||||||
|
lda #<{c2}
|
||||||
|
sta {c1}
|
||||||
|
lda #>{c2}
|
||||||
|
sta {c1}+1
|
||||||
|
//FRAGMENT vbuz1=vbuc1_plus_vbuz2
|
||||||
|
lda #{c1}
|
||||||
|
clc
|
||||||
|
adc {z2}
|
||||||
|
sta {z1}
|
||||||
|
//FRAGMENT vwuz1_lt_vwuc1_then_la1
|
||||||
|
lda {z1}+1
|
||||||
|
cmp #>{c1}
|
||||||
|
bcc {la1}
|
||||||
|
bne !+
|
||||||
|
lda {z1}
|
||||||
|
cmp #<{c1}
|
||||||
|
bcc {la1}
|
||||||
|
!:
|
||||||
|
//FRAGMENT _deref_(_deref_qbuc1)=vbuaa
|
||||||
|
ldy {c1}
|
||||||
|
sty $fe
|
||||||
|
ldy {c1}+1
|
||||||
|
sty $ff
|
||||||
|
ldy #0
|
||||||
|
sta ($fe),y
|
||||||
|
//FRAGMENT _deref_(_deref_qbuc1)=vbuxx
|
||||||
|
txa
|
||||||
|
ldy {c1}
|
||||||
|
sty $fe
|
||||||
|
ldy {c1}+1
|
||||||
|
sty $ff
|
||||||
|
ldy #0
|
||||||
|
sta ($fe),y
|
||||||
|
//FRAGMENT _deref_(_deref_qbuc1)=vbuyy
|
||||||
|
tya
|
||||||
|
ldy {c1}
|
||||||
|
sty $fe
|
||||||
|
ldy {c1}+1
|
||||||
|
sty $ff
|
||||||
|
ldy #0
|
||||||
|
sta ($fe),y
|
||||||
|
//FRAGMENT vbuz1=vbuc1_plus_vbuaa
|
||||||
|
clc
|
||||||
|
adc #{c1}
|
||||||
|
sta {z1}
|
||||||
|
//FRAGMENT vbuz1=vbuc1_plus_vbuxx
|
||||||
|
txa
|
||||||
|
clc
|
||||||
|
adc #{c1}
|
||||||
|
sta {z1}
|
||||||
|
//FRAGMENT vbuz1=vbuc1_plus_vbuyy
|
||||||
|
tya
|
||||||
|
clc
|
||||||
|
adc #{c1}
|
||||||
|
sta {z1}
|
||||||
|
//FRAGMENT vbuaa=vbuc1_plus_vbuz1
|
||||||
|
lda #{c1}
|
||||||
|
clc
|
||||||
|
adc {z1}
|
||||||
|
//FRAGMENT vbuaa=vbuc1_plus_vbuaa
|
||||||
|
clc
|
||||||
|
adc #{c1}
|
||||||
|
//FRAGMENT vbuaa=vbuc1_plus_vbuxx
|
||||||
|
txa
|
||||||
|
clc
|
||||||
|
adc #{c1}
|
||||||
|
//FRAGMENT vbuaa=vbuc1_plus_vbuyy
|
||||||
|
tya
|
||||||
|
clc
|
||||||
|
adc #{c1}
|
||||||
|
//FRAGMENT vbuxx=vbuc1_plus_vbuz1
|
||||||
|
lda #{c1}
|
||||||
|
clc
|
||||||
|
adc {z1}
|
||||||
|
tax
|
||||||
|
//FRAGMENT vbuxx=vbuc1_plus_vbuaa
|
||||||
|
clc
|
||||||
|
adc #{c1}
|
||||||
|
tax
|
||||||
|
//FRAGMENT vbuxx=vbuc1_plus_vbuxx
|
||||||
|
txa
|
||||||
|
clc
|
||||||
|
adc #{c1}
|
||||||
|
tax
|
||||||
|
//FRAGMENT vbuxx=vbuc1_plus_vbuyy
|
||||||
|
tya
|
||||||
|
clc
|
||||||
|
adc #{c1}
|
||||||
|
tax
|
||||||
|
//FRAGMENT vbuyy=vbuc1_plus_vbuz1
|
||||||
|
lda #{c1}
|
||||||
|
clc
|
||||||
|
adc {z1}
|
||||||
|
tay
|
||||||
|
//FRAGMENT vbuyy=vbuc1_plus_vbuaa
|
||||||
|
clc
|
||||||
|
adc #{c1}
|
||||||
|
tay
|
||||||
|
//FRAGMENT vbuyy=vbuc1_plus_vbuxx
|
||||||
|
txa
|
||||||
|
clc
|
||||||
|
adc #{c1}
|
||||||
|
tay
|
||||||
|
//FRAGMENT vbuyy=vbuc1_plus_vbuyy
|
||||||
|
tya
|
||||||
|
clc
|
||||||
|
adc #{c1}
|
||||||
|
tay
|
||||||
|
//FRAGMENT vbuaa=vbuaa_plus_2
|
||||||
|
clc
|
||||||
|
adc #2
|
||||||
|
//FRAGMENT vbuz1=vbuz2_plus_vbuaa
|
||||||
|
clc
|
||||||
|
adc {z2}
|
||||||
|
sta {z1}
|
||||||
|
//FRAGMENT vbuaa=vbuz1_plus_vbuaa
|
||||||
|
clc
|
||||||
|
adc {z1}
|
||||||
|
//FRAGMENT vbuxx=vbuz1_plus_vbuaa
|
||||||
|
clc
|
||||||
|
adc {z1}
|
||||||
|
tax
|
||||||
|
//FRAGMENT vbuyy=vbuz1_plus_vbuaa
|
||||||
|
clc
|
||||||
|
adc {z1}
|
||||||
|
tay
|
||||||
|
//FRAGMENT vbuz1=vbuaa_plus_vbuaa
|
||||||
|
asl
|
||||||
|
sta {z1}
|
||||||
|
//FRAGMENT vbuaa=vbuaa_plus_vbuaa
|
||||||
|
asl
|
||||||
|
//FRAGMENT vbuxx=vbuaa_plus_vbuaa
|
||||||
|
asl
|
||||||
|
tax
|
||||||
|
//FRAGMENT vbuyy=vbuaa_plus_vbuaa
|
||||||
|
asl
|
||||||
|
tay
|
||||||
|
//FRAGMENT vbuz1=vbuxx_plus_vbuaa
|
||||||
|
stx $ff
|
||||||
|
clc
|
||||||
|
adc $ff
|
||||||
|
sta {z1}
|
||||||
|
//FRAGMENT vbuaa=vbuxx_plus_vbuaa
|
||||||
|
stx $ff
|
||||||
|
clc
|
||||||
|
adc $ff
|
||||||
|
//FRAGMENT vbuxx=vbuxx_plus_vbuaa
|
||||||
|
stx $ff
|
||||||
|
clc
|
||||||
|
adc $ff
|
||||||
|
tax
|
||||||
|
//FRAGMENT vbuyy=vbuxx_plus_vbuaa
|
||||||
|
stx $ff
|
||||||
|
clc
|
||||||
|
adc $ff
|
||||||
|
tay
|
||||||
|
//FRAGMENT vbuz1=vbuyy_plus_vbuaa
|
||||||
|
sty $ff
|
||||||
|
clc
|
||||||
|
adc $ff
|
||||||
|
sta {z1}
|
||||||
|
//FRAGMENT vbuaa=vbuyy_plus_vbuaa
|
||||||
|
sty $ff
|
||||||
|
clc
|
||||||
|
adc $ff
|
||||||
|
//FRAGMENT vbuxx=vbuyy_plus_vbuaa
|
||||||
|
sty $ff
|
||||||
|
clc
|
||||||
|
adc $ff
|
||||||
|
tax
|
||||||
|
//FRAGMENT vbuyy=vbuyy_plus_vbuaa
|
||||||
|
sty $ff
|
||||||
|
clc
|
||||||
|
adc $ff
|
||||||
|
tay
|
||||||
|
//FRAGMENT vwuz1=vwuz1_rol_7
|
||||||
|
lda {z1}+1
|
||||||
|
lsr
|
||||||
|
lda {z1}
|
||||||
|
ror
|
||||||
|
sta {z1}+1
|
||||||
|
lda #0
|
||||||
|
ror
|
||||||
|
sta {z1}
|
||||||
|
//FRAGMENT vwuz1=vwuc1_plus_vwuz1
|
||||||
|
clc
|
||||||
|
lda {z1}
|
||||||
|
adc #<{c1}
|
||||||
|
sta {z1}
|
||||||
|
lda {z1}+1
|
||||||
|
adc #>{c1}
|
||||||
|
sta {z1}+1
|
||||||
|
BIN
src/test/kc/examples/cx16/SpaceDemo/Metal_1/frame_1.png
Normal file
After Width: | Height: | Size: 556 B |
BIN
src/test/kc/examples/cx16/SpaceDemo/Metal_1/frame_2.png
Normal file
After Width: | Height: | Size: 609 B |
BIN
src/test/kc/examples/cx16/SpaceDemo/Metal_1/frame_3.png
Normal file
After Width: | Height: | Size: 574 B |
BIN
src/test/kc/examples/cx16/SpaceDemo/Metal_1/frame_4.png
Normal file
After Width: | Height: | Size: 590 B |
BIN
src/test/kc/examples/cx16/SpaceDemo/Metal_1/metal_1.png
Normal file
After Width: | Height: | Size: 1.5 KiB |
BIN
src/test/kc/examples/cx16/SpaceDemo/Metal_1/metal_2.png
Normal file
After Width: | Height: | Size: 1.4 KiB |
BIN
src/test/kc/examples/cx16/SpaceDemo/Metal_1/metal_3.png
Normal file
After Width: | Height: | Size: 1.4 KiB |
BIN
src/test/kc/examples/cx16/SpaceDemo/Metal_1/metal_4.png
Normal file
After Width: | Height: | Size: 1.4 KiB |
BIN
src/test/kc/examples/cx16/SpaceDemo/Ship_1/ship_1_360_1.png
Normal file
After Width: | Height: | Size: 1.1 KiB |
BIN
src/test/kc/examples/cx16/SpaceDemo/Ship_1/ship_1_360_10.png
Normal file
After Width: | Height: | Size: 502 B |
BIN
src/test/kc/examples/cx16/SpaceDemo/Ship_1/ship_1_360_11.png
Normal file
After Width: | Height: | Size: 831 B |
BIN
src/test/kc/examples/cx16/SpaceDemo/Ship_1/ship_1_360_12.png
Normal file
After Width: | Height: | Size: 1.1 KiB |
BIN
src/test/kc/examples/cx16/SpaceDemo/Ship_1/ship_1_360_2.png
Normal file
After Width: | Height: | Size: 1.1 KiB |
BIN
src/test/kc/examples/cx16/SpaceDemo/Ship_1/ship_1_360_3.png
Normal file
After Width: | Height: | Size: 844 B |
BIN
src/test/kc/examples/cx16/SpaceDemo/Ship_1/ship_1_360_4.png
Normal file
After Width: | Height: | Size: 517 B |
BIN
src/test/kc/examples/cx16/SpaceDemo/Ship_1/ship_1_360_5.png
Normal file
After Width: | Height: | Size: 730 B |
BIN
src/test/kc/examples/cx16/SpaceDemo/Ship_1/ship_1_360_6.png
Normal file
After Width: | Height: | Size: 1.1 KiB |
BIN
src/test/kc/examples/cx16/SpaceDemo/Ship_1/ship_1_360_7.png
Normal file
After Width: | Height: | Size: 1.1 KiB |
BIN
src/test/kc/examples/cx16/SpaceDemo/Ship_1/ship_1_360_8.png
Normal file
After Width: | Height: | Size: 1.0 KiB |
BIN
src/test/kc/examples/cx16/SpaceDemo/Ship_1/ship_1_360_9.png
Normal file
After Width: | Height: | Size: 748 B |
384
src/test/kc/examples/cx16/SpaceDemo/Space.c
Normal file
@ -0,0 +1,384 @@
|
|||||||
|
// Example program for the Commander X16
|
||||||
|
|
||||||
|
#pragma link("space.ld")
|
||||||
|
|
||||||
|
#pragma data_seg(Data)
|
||||||
|
|
||||||
|
#include <cx16.h>
|
||||||
|
#include <cx16-kernal.h>
|
||||||
|
#include <6502.h>
|
||||||
|
#include <veralib.h>
|
||||||
|
#include <conio.h>
|
||||||
|
#include <printf.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
const byte NUM_SPRITES = 12;
|
||||||
|
const byte NUM_TILES_SMALL = 4;
|
||||||
|
const byte NUM_TILES_LARGE = 4;
|
||||||
|
|
||||||
|
#pragma data_seg(Palettes)
|
||||||
|
export char* PALETTES;
|
||||||
|
|
||||||
|
#pragma data_seg(Sprites)
|
||||||
|
export char SPRITE_PIXELS[] = kickasm(resource "Ship_1/ship_1_360_1.png") {{
|
||||||
|
.var pic = LoadPicture("Ship_1/ship_1_360_1.png")
|
||||||
|
// palette: rgb->idx
|
||||||
|
.var palette = Hashtable()
|
||||||
|
// RGB value for each palette index
|
||||||
|
.var palList = List()
|
||||||
|
// Next palette index
|
||||||
|
.var nxt_idx = 0;
|
||||||
|
// Extract palette while outputting pixels as palete index values
|
||||||
|
.for (var y=0; y<64; y++) {
|
||||||
|
.for (var x=0;x<64; x++) {
|
||||||
|
// Find palette index (add if not known)
|
||||||
|
.var rgb = pic.getPixel(x,y);
|
||||||
|
.var idx = palette.get(rgb)
|
||||||
|
.if(idx==null) {
|
||||||
|
.eval idx = nxt_idx++;
|
||||||
|
.eval palette.put(rgb,idx);
|
||||||
|
.eval palList.add(rgb)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.if(nxt_idx>16) .error "Image has too many colours "+nxt_idx
|
||||||
|
|
||||||
|
.segment Palettes
|
||||||
|
.for(var i=0;i<16;i++) {
|
||||||
|
.var rgb = palList.get(i)
|
||||||
|
.var red = floor(rgb / [256*256])
|
||||||
|
.var green = floor(rgb/256) & 255
|
||||||
|
.var blue = rgb & 255
|
||||||
|
// bits 4-8: green, bits 0-3 blue
|
||||||
|
.byte green&$f0 | blue/16
|
||||||
|
// bits bits 0-3 red
|
||||||
|
.byte red/16
|
||||||
|
}
|
||||||
|
|
||||||
|
.segment Sprites
|
||||||
|
.for(var p=1;p<=NUM_SPRITES;p++) {
|
||||||
|
.var pic = LoadPicture("Ship_1/ship_1_360_" + p + ".png")
|
||||||
|
.for (var y=0; y<64; y++) {
|
||||||
|
.for (var x=0;x<64; x+=2) {
|
||||||
|
// Find palette index (add if not known)
|
||||||
|
.var rgb = pic.getPixel(x,y);
|
||||||
|
.var idx1 = palette.get(rgb)
|
||||||
|
.if(idx1==null) {
|
||||||
|
.printnow "unknown rgb value!"
|
||||||
|
}
|
||||||
|
// Find palette index (add if not known)
|
||||||
|
.eval rgb = pic.getPixel(x+1,y);
|
||||||
|
.var idx2 = palette.get(rgb)
|
||||||
|
.if(idx2==null) {
|
||||||
|
.printnow "unknown rgb value!"
|
||||||
|
}
|
||||||
|
.byte idx1*16+idx2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}};
|
||||||
|
|
||||||
|
#pragma data_seg(TileS)
|
||||||
|
export char TILE_PIXELS_SMALL[] = kickasm(resource "Metal_1/frame_1.png") {{
|
||||||
|
// palette: rgb->idx
|
||||||
|
.var palette2 = Hashtable()
|
||||||
|
// RGB value for each palette index
|
||||||
|
.var palList2 = List()
|
||||||
|
// Next palette index
|
||||||
|
// Extract palette while outputting pixels as palete index values
|
||||||
|
.var nxt_idx2 = 0;
|
||||||
|
.for(var p=1;p<=NUM_TILES_SMALL;p++) {
|
||||||
|
.var pic = LoadPicture("Metal_1/frame_" + p + ".png")
|
||||||
|
.for (var y=0; y<32; y++) {
|
||||||
|
.for (var x=0;x<32; x++) {
|
||||||
|
// Find palette index (add if not known)
|
||||||
|
.var rgb = pic.getPixel(x,y);
|
||||||
|
.var idx = palette2.get(rgb)
|
||||||
|
.if(idx==null) {
|
||||||
|
.eval idx = nxt_idx2++;
|
||||||
|
.eval palette2.put(rgb,idx);
|
||||||
|
.eval palList2.add(rgb)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.if(nxt_idx2>16) .error "Image has too many colours "+nxt_idx2
|
||||||
|
|
||||||
|
.segment Palettes
|
||||||
|
.for(var i=0;i<16;i++) {
|
||||||
|
.var rgb = 16*256*256+16*256+16
|
||||||
|
.if(i<palList2.size())
|
||||||
|
.eval rgb = palList2.get(i)
|
||||||
|
.var red = floor(rgb / [256*256])
|
||||||
|
.var green = floor(rgb/256) & 255
|
||||||
|
.var blue = rgb & 255
|
||||||
|
// bits 4-8: green, bits 0-3 blue
|
||||||
|
.byte green&$f0 | blue/16
|
||||||
|
// bits bits 0-3 red
|
||||||
|
.byte red/16
|
||||||
|
.printnow "tile small: rgb = " + rgb + ", i = " + i
|
||||||
|
}
|
||||||
|
|
||||||
|
.segment TileS
|
||||||
|
.var count = 0
|
||||||
|
.for(var p=1;p<=NUM_TILES_SMALL;p++) {
|
||||||
|
.var pic = LoadPicture("Metal_1/frame_" + p + ".png")
|
||||||
|
.for(var j=0; j<32; j+=16) {
|
||||||
|
.for(var i=0; i<32; i+=16) {
|
||||||
|
.for (var y=j; y<j+16; y++) {
|
||||||
|
.for (var x=i; x<i+16; x+=2) {
|
||||||
|
// .printnow "j="+j+",y="+y+",i="+i+",x="+x
|
||||||
|
// Find palette index (add if not known)
|
||||||
|
.var rgb = pic.getPixel(x,y);
|
||||||
|
.var idx1 = palette2.get(rgb)
|
||||||
|
.if(idx1==null) {
|
||||||
|
.error "unknown rgb value!"
|
||||||
|
}
|
||||||
|
// Find palette index (add if not known)
|
||||||
|
.eval rgb = pic.getPixel(x+1,y);
|
||||||
|
.var idx2 = palette2.get(rgb)
|
||||||
|
.if(idx2==null) {
|
||||||
|
.error "unknown rgb value!"
|
||||||
|
}
|
||||||
|
.byte idx1*16+idx2;
|
||||||
|
.eval count++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.printnow "small count = " + count
|
||||||
|
}};
|
||||||
|
|
||||||
|
#pragma data_seg(TileB)
|
||||||
|
export char TILE_PIXELS_LARGE[] = kickasm(resource "Metal_1/metal_1.png") {{
|
||||||
|
.var pic3 = LoadPicture("Metal_1/metal_1.png")
|
||||||
|
// palette: rgb->idx
|
||||||
|
.var palette3 = Hashtable()
|
||||||
|
// RGB value for each palette index
|
||||||
|
.var palList3 = List()
|
||||||
|
// Next palette index
|
||||||
|
.var nxt_idx3 = 0;
|
||||||
|
// Extract palette while outputting pixels as palete index values
|
||||||
|
.for (var y=0; y<64; y++) {
|
||||||
|
.for (var x=0;x<64; x++) {
|
||||||
|
// Find palette index (add if not known)
|
||||||
|
.var rgb = pic3.getPixel(x,y);
|
||||||
|
.var idx = palette3.get(rgb)
|
||||||
|
.if(idx==null) {
|
||||||
|
.eval idx = nxt_idx3++;
|
||||||
|
.eval palette3.put(rgb,idx);
|
||||||
|
.eval palList3.add(rgb)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.if(nxt_idx3>16) .error "Image has too many colours "+nxt_idx3
|
||||||
|
|
||||||
|
.segment Palettes
|
||||||
|
.for(var i=0;i<16;i++) {
|
||||||
|
.var rgb = 0
|
||||||
|
.if(i<palList3.size())
|
||||||
|
.eval rgb = palList3.get(i)
|
||||||
|
.var red = floor(rgb / [256*256])
|
||||||
|
.var green = floor(rgb/256) & 255
|
||||||
|
.var blue = rgb & 255
|
||||||
|
// bits 4-8: green, bits 0-3 blue
|
||||||
|
.byte green&$f0 | blue/16
|
||||||
|
// bits bits 0-3 red
|
||||||
|
.byte red/16
|
||||||
|
// .printnow "tile large: rgb = " + rgb + ", i = " + i
|
||||||
|
}
|
||||||
|
|
||||||
|
.segment TileB
|
||||||
|
.eval count = 0
|
||||||
|
.for(var p=1;p<=NUM_TILES_LARGE;p++) {
|
||||||
|
.var pic = LoadPicture("Metal_1/metal_" + p + ".png")
|
||||||
|
.for(var j=0; j<64; j+=16) {
|
||||||
|
.for(var i=0; i<64; i+=16) {
|
||||||
|
.for (var y=j; y<j+16; y++) {
|
||||||
|
.for (var x=i; x<i+16; x+=2) {
|
||||||
|
// Find palette index (add if not known)
|
||||||
|
.var rgb = pic.getPixel(x,y);
|
||||||
|
.var idx1 = palette3.get(rgb)
|
||||||
|
.if(idx1==null) {
|
||||||
|
.error "unknown rgb value!"
|
||||||
|
}
|
||||||
|
// Find palette index (add if not known)
|
||||||
|
.eval rgb = pic.getPixel(x+1,y);
|
||||||
|
.var idx2 = palette3.get(rgb)
|
||||||
|
.if(idx2==null) {
|
||||||
|
.error "unknown rgb value!"
|
||||||
|
}
|
||||||
|
.byte idx1*16+idx2;
|
||||||
|
.eval count++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.printnow "count = " + count
|
||||||
|
}};
|
||||||
|
|
||||||
|
|
||||||
|
#pragma data_seg(Data)
|
||||||
|
|
||||||
|
word sprites[NUM_SPRITES];
|
||||||
|
|
||||||
|
// Addressed used for graphics in main banked memory.
|
||||||
|
const dword BANK_SPRITES = 0x02000;
|
||||||
|
const dword BANK_TILES_SMALL = 0x14000;
|
||||||
|
const dword BANK_TILES_LARGE = 0x16000;
|
||||||
|
const dword BANK_PALETTE = 0x18000;
|
||||||
|
|
||||||
|
// Addresses used to store graphics in VERA VRAM.
|
||||||
|
const dword VRAM_SPRITES = 0x00000;
|
||||||
|
const dword VRAM_TILES_SMALL = 0x14000;
|
||||||
|
const dword VRAM_TILES_LARGE = 0x14800;
|
||||||
|
const dword VRAM_PALETTE = 0x18000;
|
||||||
|
|
||||||
|
word sprite_offset = <(VRAM_SPRITES/32)|VERA_SPRITE_4BPP;
|
||||||
|
// Sprite attributes: 8bpp, in front, 64x64, address SPRITE_PIXELS_VRAM
|
||||||
|
struct VERA_SPRITE SPRITE_ATTR = { <(VRAM_SPRITES/32)|VERA_SPRITE_8BPP, 320-32, 240-32, 0x0c, 0xf1 };
|
||||||
|
|
||||||
|
void main() {
|
||||||
|
|
||||||
|
memcpy_in_vram(1, 0xF000, VERA_INC_1, 0, 0xF800, VERA_INC_1, 256*8); // We copy the 128 character set of 8 bytes each.
|
||||||
|
vera_layer_mode_tile(1, (dword)0x1A000, (dword)0x1F000, 128, 64, 8, 8, 1);
|
||||||
|
screenlayer(1);
|
||||||
|
textcolor(WHITE);
|
||||||
|
bgcolor(BLACK);
|
||||||
|
clrscr();
|
||||||
|
|
||||||
|
// Loading the graphics in main banked memory.
|
||||||
|
char status = LoadFileBanked(8, "SPRITES", BANK_SPRITES);
|
||||||
|
status = LoadFileBanked(8, "TILES", BANK_TILES_SMALL);
|
||||||
|
status = LoadFileBanked(8, "TILEB", BANK_TILES_LARGE);
|
||||||
|
|
||||||
|
// Load the palette in main banked memory.
|
||||||
|
status = LoadFileBanked(8, "PALETTES", BANK_PALETTE);
|
||||||
|
|
||||||
|
// Copy graphics to the VERA VRAM.
|
||||||
|
bnkcpy_vram_address(VRAM_SPRITES, BANK_SPRITES-2, (dword)64*64*NUM_SPRITES/2);
|
||||||
|
bnkcpy_vram_address(VRAM_TILES_SMALL, BANK_TILES_SMALL-2, (dword)32*32*(NUM_TILES_SMALL)/2);
|
||||||
|
bnkcpy_vram_address(VRAM_TILES_LARGE, BANK_TILES_LARGE-2, (dword)64*64*(NUM_TILES_LARGE)/2);
|
||||||
|
|
||||||
|
// Load the palette in VERA palette registers, but keep the first 16 colors untouched.
|
||||||
|
bnkcpy_vram_address(VERA_PALETTE+32, BANK_PALETTE-2, (dword)32*3);
|
||||||
|
|
||||||
|
// Now we activate the tile mode.
|
||||||
|
vera_layer_mode_tile(0, (dword)0x10000, VRAM_TILES_SMALL, 128, 64, 16, 16, 4);
|
||||||
|
|
||||||
|
POKE(0x9f61, 0); // let's put back bank 0.
|
||||||
|
vera_vram_address0(0x10000,VERA_INC_1);
|
||||||
|
for(byte r=0;r<42;r+=12) {
|
||||||
|
for(byte j=0;j<16;j+=8) {
|
||||||
|
for(byte i=0;i<4;i+=2) {
|
||||||
|
for(byte c=0;c<128;c+=4) {
|
||||||
|
*VERA_DATA0 = 0+i+j;
|
||||||
|
*VERA_DATA0 = 0x20;
|
||||||
|
*VERA_DATA0 = 1+i+j;
|
||||||
|
*VERA_DATA0 = 0x20;
|
||||||
|
*VERA_DATA0 = 4+i+j;
|
||||||
|
*VERA_DATA0 = 0x20;
|
||||||
|
*VERA_DATA0 = 5+i+j;
|
||||||
|
*VERA_DATA0 = 0x20;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for(byte j=0;j<64;j+=32) {
|
||||||
|
for(byte i=0;i<16;i+=4) {
|
||||||
|
for(byte c=0;c<128;c+=8) {
|
||||||
|
*VERA_DATA0 = 16+i+j;
|
||||||
|
*VERA_DATA0 = 0x30;
|
||||||
|
*VERA_DATA0 = 17+i+j;
|
||||||
|
*VERA_DATA0 = 0x30;
|
||||||
|
*VERA_DATA0 = 18+i+j;
|
||||||
|
*VERA_DATA0 = 0x30;
|
||||||
|
*VERA_DATA0 = 19+i+j;
|
||||||
|
*VERA_DATA0 = 0x30;
|
||||||
|
*VERA_DATA0 = 32+i+j;
|
||||||
|
*VERA_DATA0 = 0x30;
|
||||||
|
*VERA_DATA0 = 33+i+j;
|
||||||
|
*VERA_DATA0 = 0x30;
|
||||||
|
*VERA_DATA0 = 34+i+j;
|
||||||
|
*VERA_DATA0 = 0x30;
|
||||||
|
*VERA_DATA0 = 35+i+j;
|
||||||
|
*VERA_DATA0 = 0x30;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
vera_layer_show(0);
|
||||||
|
|
||||||
|
|
||||||
|
// Copy sprite palette to VRAM
|
||||||
|
// Copy 8* sprite attributes to VRAM
|
||||||
|
char* vram_sprite_attr = <VERA_SPRITE_ATTR;
|
||||||
|
for(char s=0;s<NUM_SPRITES;s++) {
|
||||||
|
sprites[s] = sprite_offset;
|
||||||
|
SPRITE_ATTR.ADDR = sprite_offset;
|
||||||
|
SPRITE_ATTR.X += 68;
|
||||||
|
SPRITE_ATTR.Y = 100;
|
||||||
|
memcpy_to_vram((char)>VERA_SPRITE_ATTR, vram_sprite_attr, &SPRITE_ATTR, sizeof(SPRITE_ATTR));
|
||||||
|
vram_sprite_attr += sizeof(SPRITE_ATTR);
|
||||||
|
sprite_offset += 64;
|
||||||
|
}
|
||||||
|
// Enable sprites
|
||||||
|
*VERA_CTRL &= ~VERA_DCSEL;
|
||||||
|
*VERA_DC_VIDEO |= VERA_SPRITES_ENABLE;
|
||||||
|
// Enable VSYNC IRQ (also set line bit 8 to 0)
|
||||||
|
SEI();
|
||||||
|
*KERNEL_IRQ = &irq_vsync;
|
||||||
|
*VERA_IEN = VERA_VSYNC;
|
||||||
|
CLI();
|
||||||
|
|
||||||
|
while(!fgetc());
|
||||||
|
}
|
||||||
|
|
||||||
|
volatile byte i = 0;
|
||||||
|
volatile byte a = 4;
|
||||||
|
volatile word vscroll = 0;
|
||||||
|
volatile word scroll_action = 2;
|
||||||
|
|
||||||
|
// VSYNC Interrupt Routine
|
||||||
|
__interrupt(rom_sys_cx16) void irq_vsync() {
|
||||||
|
// Move the sprite around
|
||||||
|
|
||||||
|
a--;
|
||||||
|
if(a==0) {
|
||||||
|
a=4;
|
||||||
|
const char vram_sprite_attr_bank = (char)>VERA_SPRITE_ATTR;
|
||||||
|
char *vram_sprite_attr = <VERA_SPRITE_ATTR;
|
||||||
|
unsigned int i_x = 0;
|
||||||
|
unsigned int i_y = 0;
|
||||||
|
for(word s=0;s<NUM_SPRITES;s++) {
|
||||||
|
word x = s+i;
|
||||||
|
if(x>=NUM_SPRITES) {
|
||||||
|
x-=NUM_SPRITES;
|
||||||
|
}
|
||||||
|
SPRITE_ATTR.ADDR = sprites[x];
|
||||||
|
SPRITE_ATTR.X = (word)40+((word)(s&03)<<7);
|
||||||
|
SPRITE_ATTR.Y = (word)100+((word)(s>>2)<<7);
|
||||||
|
// Copy sprite positions to VRAM (the 4 relevant bytes in VERA_SPRITE_ATTR)
|
||||||
|
memcpy_to_vram(vram_sprite_attr_bank, vram_sprite_attr, &SPRITE_ATTR, 6);
|
||||||
|
vram_sprite_attr += sizeof(SPRITE_ATTR);
|
||||||
|
}
|
||||||
|
|
||||||
|
i++;
|
||||||
|
if(i>=NUM_SPRITES) i=0;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if(scroll_action--) {
|
||||||
|
scroll_action = 2;
|
||||||
|
vscroll++;
|
||||||
|
if(vscroll>(32+64)*2-1) vscroll=0;
|
||||||
|
vera_layer_set_vertical_scroll(0,vscroll);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Reset the VSYNC interrupt
|
||||||
|
*VERA_ISR = VERA_VSYNC;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
16
src/test/kc/examples/cx16/SpaceDemo/space.ld
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
// Create a D64 disk containing the program and a sprite file
|
||||||
|
.file [name="%O", type="prg", segments="Program"]
|
||||||
|
.file [name="SPRITES", type="bin", segments="Sprites"]
|
||||||
|
.file [name="TILES", type="bin", segments="TileS"]
|
||||||
|
.file [name="TILEB", type="bin", segments="TileB"]
|
||||||
|
.file [name="PALETTES", type="bin", segments="Palettes"]
|
||||||
|
.segmentdef Program [segments="Basic, Code, Data"]
|
||||||
|
.segmentdef Basic [start=$0801]
|
||||||
|
.segmentdef Code [start=%P]
|
||||||
|
.segmentdef Data [startAfter="Code"]
|
||||||
|
.segment Basic
|
||||||
|
:BasicUpstart(%E)
|
||||||
|
.segmentdef Sprites
|
||||||
|
.segmentdef TileS
|
||||||
|
.segmentdef TileB
|
||||||
|
.segmentdef Palettes
|