tfv: closer

This commit is contained in:
Vince Weaver 2017-09-10 23:42:47 -04:00
parent 15a6a85edc
commit 0486ef4bbd
2 changed files with 81 additions and 20 deletions

View File

@ -39,32 +39,46 @@ static unsigned char water_map[32]={
#define LOWRES_W 40 #define LOWRES_W 40
#define LOWRES_H 40 #define LOWRES_H 40
static int displayed=0;
static int lookup_map(int xx, int yy) {
static int lookup_map(int x, int y) { int color,offset;
int color;
color=2; color=2;
x=x&MASK_X; xx=xx&MASK_X;
y=y&MASK_Y; yy=yy&MASK_Y;
if (!displayed) {
printf("XX,YY! %x,%x\n",xx,yy);
}
// if ( ((y&0x3)==1) && ((x&7)==0) ) color=14; // if ( ((y&0x3)==1) && ((x&7)==0) ) color=14;
// if ( ((y&0x3)==3) && ((x&7)==4) ) color=14; // if ( ((y&0x3)==3) && ((x&7)==4) ) color=14;
color=water_map[((y*8)+x)&0x1f]; offset=yy<<3;
offset+=xx;
// color=water_map[((yy*8)+xx)&0x1f];
color=water_map[offset&0x1f];
/* 2 2 2 2 2 2 2 2 */ /* 2 2 2 2 2 2 2 2 */
/* e 2 2 2 2 2 2 2 */ /* e 2 2 2 2 2 2 2 */
/* 2 2 2 2 2 2 2 2 */ /* 2 2 2 2 2 2 2 2 */
/* 2 2 2 2 e 2 2 2 */ /* 2 2 2 2 e 2 2 2 */
if ((y<8) && (x<8)) { if ((yy<8) && (xx<8)) {
color=flying_map[(y*8)+x]; color=flying_map[offset];
} }
if (!displayed) {
printf("COLOR! %x\n",color);
}
return color; return color;
} }
@ -205,7 +219,7 @@ static void fixed_add(struct fixed_type *x, struct fixed_type *y, struct fixed_t
// //
// //
static int displayed=0;
void draw_background_mode7(void) { void draw_background_mode7(void) {
@ -231,9 +245,8 @@ void draw_background_mode7(void) {
fixed_mul(&space_z,&BETA,&factor,0); fixed_mul(&space_z,&BETA,&factor,0);
if (!displayed) { if (!displayed) {
printf("%x %x * %x %x = %x %x\n", printf("SPACEZ/BETA/FACTOR %x %x * %x %x = %x %x\n",
space_z.i,space_z.f,BETA.i,BETA.f,factor.i,factor.f); space_z.i,space_z.f,BETA.i,BETA.f,factor.i,factor.f);
displayed=1;
} }
// printf("spacez=%lf beta=%lf factor=%lf\n", // printf("spacez=%lf beta=%lf factor=%lf\n",
@ -251,6 +264,11 @@ void draw_background_mode7(void) {
horizontal_scale.f= horizontal_scale.f=
horizontal_lookup[space_z.i&0xf][(screen_y-8)/2]; horizontal_lookup[space_z.i&0xf][(screen_y-8)/2];
if (!displayed) {
printf("HORIZ_SCALE %x %x\n",
horizontal_scale.i,horizontal_scale.f);
}
// calculate the distance of the line we are drawing // calculate the distance of the line we are drawing
fixed_mul(&horizontal_scale,&scale,&distance,0); fixed_mul(&horizontal_scale,&scale,&distance,0);
//fixed_to_double(&distance,&double_distance); //fixed_to_double(&distance,&double_distance);
@ -258,16 +276,33 @@ void draw_background_mode7(void) {
// printf("Distance=%lf, horizontal-scale=%lf\n", // printf("Distance=%lf, horizontal-scale=%lf\n",
// distance,horizontal_scale); // distance,horizontal_scale);
if (!displayed) {
printf("DISTANCE %x:%x\n",
distance.i,distance.f);
}
// calculate the dx and dy of points in space when we step // calculate the dx and dy of points in space when we step
// through all points on this line // through all points on this line
dx.i=fixed_sin[(angle+8)&0xf].i; // -sin() dx.i=fixed_sin[(angle+8)&0xf].i; // -sin()
dx.f=fixed_sin[(angle+8)&0xf].f; // -sin() dx.f=fixed_sin[(angle+8)&0xf].f; // -sin()
fixed_mul(&dx,&horizontal_scale,&dx,0); fixed_mul(&dx,&horizontal_scale,&dx,0);
if (!displayed) {
printf("DX %x:%x\n",
dx.i,dx.f);
}
dy.i=fixed_sin[(angle+4)&0xf].i; // cos() dy.i=fixed_sin[(angle+4)&0xf].i; // cos()
dy.f=fixed_sin[(angle+4)&0xf].f; // cos() dy.f=fixed_sin[(angle+4)&0xf].f; // cos()
fixed_mul(&dy,&horizontal_scale,&dy,0); fixed_mul(&dy,&horizontal_scale,&dy,0);
if (!displayed) {
printf("DY %x:%x\n",
dy.i,dy.f);
}
// calculate the starting position // calculate the starting position
//double_space_x =(double_distance+double_factor); //double_space_x =(double_distance+double_factor);
fixed_add(&distance,&factor,&space_x); fixed_add(&distance,&factor,&space_x);
@ -281,6 +316,11 @@ void draw_background_mode7(void) {
fixed_mul(&fixed_temp,&dx,&fixed_temp,0); fixed_mul(&fixed_temp,&dx,&fixed_temp,0);
fixed_add(&space_x,&fixed_temp,&space_x); fixed_add(&space_x,&fixed_temp,&space_x);
if (!displayed) {
printf("SPACEX! %x:%x\n",
space_x.i,space_x.f);
}
fixed_add(&distance,&factor,&space_y); fixed_add(&distance,&factor,&space_y);
// double_space_y =(double_distance+double_factor); // double_space_y =(double_distance+double_factor);
// double_to_fixed(double_space_y,&space_y); // double_to_fixed(double_space_y,&space_y);
@ -293,6 +333,11 @@ void draw_background_mode7(void) {
fixed_mul(&fixed_temp,&dy,&fixed_temp,0); fixed_mul(&fixed_temp,&dy,&fixed_temp,0);
fixed_add(&space_y,&fixed_temp,&space_y); fixed_add(&space_y,&fixed_temp,&space_y);
if (!displayed) {
printf("SPACEY! %x:%x\n",
space_y.i,space_y.f);
}
// go through all points in this screen line // go through all points in this screen line
for (screen_x = 0; screen_x < LOWRES_W-1; screen_x++) { for (screen_x = 0; screen_x < LOWRES_W-1; screen_x++) {
// get a pixel from the tile and put it on the screen // get a pixel from the tile and put it on the screen
@ -315,6 +360,7 @@ void draw_background_mode7(void) {
fixed_add(&space_y,&dy,&space_y); fixed_add(&space_y,&dy,&space_y);
} }
} }
displayed=1;
} }
#define SHIPX 15 #define SHIPX 15

View File

@ -55,6 +55,12 @@ flying_start:
sta ANGLE sta ANGLE
sta SPACEX_I sta SPACEX_I
sta SPACEY_I sta SPACEY_I
sta CX_I
sta CX_F
sta CY_I
sta CY_F
lda #4 lda #4
sta SPACEZ_I sta SPACEZ_I
@ -96,13 +102,13 @@ check_left:
cmp #('J') cmp #('J')
bne check_right bne check_right
inc TURNING inc TURNING
inc ANGLE dec ANGLE
check_right: check_right:
cmp #('K') cmp #('K')
bne check_done bne check_done
dec TURNING dec TURNING
dec ANGLE inc ANGLE
check_done: check_done:
@ -242,7 +248,8 @@ sky_loop: ; draw line across screen
screeny_loop: screeny_loop:
ldy #0 ldy #0
jsr hlin_setup jsr hlin_setup ; y-coord in a, x-coord in y
; sets up GBASL/GBASH
lda #0 ; horizontal_scale.i = 0 lda #0 ; horizontal_scale.i = 0
sta HORIZ_SCALE_I sta HORIZ_SCALE_I
@ -303,9 +310,6 @@ screeny_loop:
lda fixed_sin,Y lda fixed_sin,Y
sta DX_F sta DX_F
;; ANGLE
;; brk ASM, dx = 00:00
; fixed_mul(&dx,&horizontal_scale,&dx); ; fixed_mul(&dx,&horizontal_scale,&dx);
lda HORIZ_SCALE_I lda HORIZ_SCALE_I
sta NUM1H sta NUM1H
@ -321,6 +325,8 @@ screeny_loop:
lda RESULT+1 lda RESULT+1
sta DX_F sta DX_F
;; ANGLE
;; brk ASM, dx = 00:00
lda ANGLE ; dy.i=fixed_sin[(angle+4)&0xf].i; // cos() lda ANGLE ; dy.i=fixed_sin[(angle+4)&0xf].i; // cos()
clc clc
@ -349,6 +355,8 @@ screeny_loop:
lda RESULT+1 lda RESULT+1
sta DY_F sta DY_F
;; brk ASM, dy = 00:73
; calculate the starting position ; calculate the starting position
; fixed_add(&distance,&factor,&space_x); ; fixed_add(&distance,&factor,&space_x);
@ -429,6 +437,8 @@ screeny_loop:
adc TEMP_I adc TEMP_I
sta SPACEX_I sta SPACEX_I
;; brk space_x = 06:bc
lda ANGLE ; fixed_temp.i=fixed_sin[angle&0xf].i; lda ANGLE ; fixed_temp.i=fixed_sin[angle&0xf].i;
and #$f and #$f
asl asl
@ -493,6 +503,7 @@ screeny_loop:
adc TEMP_I adc TEMP_I
sta SPACEY_I sta SPACEY_I
;; brk space_y = f7:04
lda #0 lda #0
sta SCREEN_X sta SCREEN_X
@ -551,7 +562,9 @@ lookup_map:
sta TEMPY sta TEMPY
lda SPACEY_I lda SPACEY_I
and #MAP_MASK and #MAP_MASK ; wrap to 64x64 grid
asl asl
asl asl
asl ; multiply by 8 asl ; multiply by 8
@ -561,10 +574,12 @@ lookup_map:
ldy SPACEX_I ldy SPACEX_I
cpy #$8 cpy #$8
bcc ocean_color ; bgt beq ocean_color ; bgt
bcs ocean_color
ldy SPACEY_I ldy SPACEY_I
cpy #$8 cpy #$8
bcc ocean_color ; bgt beq ocean_color ; bgt
bcs ocean_color
tay tay
lda flying_map,Y ; load from array lda flying_map,Y ; load from array