git-svn-id: https://svn.eduke32.com/eduke32@520 1a8010ca-5511-0410-912e-c29ae57300e0

This commit is contained in:
terminx 2007-03-08 21:07:10 +00:00
parent 3081c87724
commit cb77e41236
6 changed files with 40 additions and 5 deletions

View file

@ -468,9 +468,7 @@ int movesprite(int spritenum, long xchange, long ychange, long zchange, unsigned
{ {
long daz,h, oldx, oldy; long daz,h, oldx, oldy;
short retval, dasectnum, cd; short retval, dasectnum, cd;
char bg; int bg = badguy(&sprite[spritenum]);
bg = badguy(&sprite[spritenum]);
if (sprite[spritenum].statnum == 5 || (bg && sprite[spritenum].xrepeat < 4)) if (sprite[spritenum].statnum == 5 || (bg && sprite[spritenum].xrepeat < 4))
{ {

View file

@ -1730,9 +1730,9 @@ static void Keys3d(void)
} }
if (tabgraphic == 1) if (tabgraphic == 1)
rotatesprite((44+(tilesizx[temppicnum]>>2))<<16,(114)<<16,32768,0,temppicnum,tempshade,temppal,2,0L,0L,xdim-1L,ydim-1L); rotatesprite((44+(tilesizx[temppicnum]>>3))<<16,(114)<<16,32768,0,temppicnum,tempshade,temppal,2,0L,0L,xdim-1L,ydim-1L);
else if (tabgraphic == 2) else if (tabgraphic == 2)
rotatesprite((44+(tilesizx[temppicnum]>>2))<<16,(114)<<16,16384,0,temppicnum,tempshade,temppal,2,0L,0L,xdim-1L,ydim-1L); rotatesprite((44+(tilesizx[temppicnum]>>3))<<16,(114)<<16,16384,0,temppicnum,tempshade,temppal,2,0L,0L,xdim-1L,ydim-1L);
begindrawing(); begindrawing();
j = xdimgame>640?0:1; j = xdimgame>640?0:1;

View file

@ -498,6 +498,15 @@ struct weaponhit {
extern struct weaponhit hittype[MAXSPRITES]; extern struct weaponhit hittype[MAXSPRITES];
struct spriteinterpolate {
long x;
long y;
long z;
int ang;
};
extern struct spriteinterpolate sprpos[MAXSPRITES];
extern input loc; extern input loc;
extern input recsync[RECSYNCBUFSIZ]; extern input recsync[RECSYNCBUFSIZ];
extern long avgfvel, avgsvel, avgavel, avghorz, avgbits, avgextbits; extern long avgfvel, avgsvel, avgavel, avghorz, avgbits, avgextbits;

View file

@ -4247,6 +4247,11 @@ int EGS(int whatsect,long s_x,long s_y,long s_z,int s_pn,int s_s,int s_xr,int s_
actorspriteflags[i] = 0; actorspriteflags[i] = 0;
sprpos[i].x = sprite[i].x;
sprpos[i].y = sprite[i].y;
sprpos[i].z = sprite[i].z;
sprpos[i].ang = sprite[i].ang;
if (actorscrptr[s_pn]) if (actorscrptr[s_pn])
{ {
s->extra = *actorscrptr[s_pn]; s->extra = *actorscrptr[s_pn];
@ -4376,6 +4381,11 @@ int spawn(int j, int pn)
actorspriteflags[i] = 0; actorspriteflags[i] = 0;
sprpos[i].x = sprite[i].x;
sprpos[i].y = sprite[i].y;
sprpos[i].z = sprite[i].z;
sprpos[i].ang = sprite[i].ang;
if (PN != SPEAKER && PN != LETTER && PN != DUCK && PN != TARGET && PN != TRIPBOMB && PN != VIEWSCREEN && PN != VIEWSCREEN2 && (CS&48)) if (PN != SPEAKER && PN != LETTER && PN != DUCK && PN != TARGET && PN != TRIPBOMB && PN != VIEWSCREEN && PN != VIEWSCREEN2 && (CS&48))
if (!(PN >= CRACK1 && PN <= CRACK4)) if (!(PN >= CRACK1 && PN <= CRACK4))
{ {
@ -6221,6 +6231,16 @@ void animatesprites(long x,long y,int a,long smoothratio)
t = &tsprite[j]; t = &tsprite[j];
i = t->owner; i = t->owner;
s = &sprite[t->owner]; s = &sprite[t->owner];
/*
t->x = sprpos[i].x+mulscale16((long)(s->x-sprpos[i].x),smoothratio);
t->y = sprpos[i].y+mulscale16((long)(s->y-sprpos[i].y),smoothratio);
t->z = sprpos[i].z+mulscale16((long)(s->z-sprpos[i].z),smoothratio);
sprpos[i].x = s->x;
sprpos[i].y = s->y;
sprpos[i].z = s->z;
*/
//greenslime can't be handled through the dynamictostatic system due to addition on constant //greenslime can't be handled through the dynamictostatic system due to addition on constant
if ((t->picnum >= GREENSLIME)&&(t->picnum <= GREENSLIME+7)) if ((t->picnum >= GREENSLIME)&&(t->picnum <= GREENSLIME+7))
{} {}

View file

@ -3256,6 +3256,8 @@ static void move(void)
goalang = getangle(ps[g_p].oposx-g_sp->x,ps[g_p].oposy-g_sp->y); goalang = getangle(ps[g_p].oposx-g_sp->x,ps[g_p].oposy-g_sp->y);
else goalang = getangle(ps[g_p].posx-g_sp->x,ps[g_p].posy-g_sp->y); else goalang = getangle(ps[g_p].posx-g_sp->x,ps[g_p].posy-g_sp->y);
angdif = getincangle(g_sp->ang,goalang)>>2; angdif = getincangle(g_sp->ang,goalang)>>2;
if ((angdif > -8 && angdif < 0) || (angdif < 8 && angdif > 0))
angdif *= 2;
g_sp->ang += angdif; g_sp->ang += angdif;
} }
@ -3268,6 +3270,8 @@ static void move(void)
goalang = getangle(ps[g_p].oposx-g_sp->x,ps[g_p].oposy-g_sp->y); goalang = getangle(ps[g_p].oposx-g_sp->x,ps[g_p].oposy-g_sp->y);
else goalang = getangle(ps[g_p].posx-g_sp->x,ps[g_p].posy-g_sp->y); else goalang = getangle(ps[g_p].posx-g_sp->x,ps[g_p].posy-g_sp->y);
angdif = getincangle(g_sp->ang,goalang)>>4; angdif = getincangle(g_sp->ang,goalang)>>4;
if ((angdif > -8 && angdif < 0) || (angdif < 8 && angdif > 0))
angdif *= 2;
g_sp->ang += angdif; g_sp->ang += angdif;
} }
@ -3284,6 +3288,8 @@ static void move(void)
goalang = getangle(newx-g_sp->x,newy-g_sp->y); goalang = getangle(newx-g_sp->x,newy-g_sp->y);
angdif = getincangle(g_sp->ang,goalang)>>2; angdif = getincangle(g_sp->ang,goalang)>>2;
if ((angdif > -8 && angdif < 0) || (angdif < 8 && angdif > 0))
angdif *= 2;
g_sp->ang += angdif; g_sp->ang += angdif;
} }

View file

@ -34,6 +34,8 @@ long gc=176;
// long temp_data[MAXSPRITES][6]; // long temp_data[MAXSPRITES][6];
struct weaponhit hittype[MAXSPRITES]; struct weaponhit hittype[MAXSPRITES];
struct spriteinterpolate sprpos[MAXSPRITES];
short spriteq[1024],spriteqloc,spriteqamount=64; short spriteq[1024],spriteqloc,spriteqamount=64;
struct animwalltype animwall[MAXANIMWALLS]; struct animwalltype animwall[MAXANIMWALLS];
short numanimwalls; short numanimwalls;