view collision.c @ 1:b4c797eee72a

task dandy base
author koba <koba@cr.ie.u-ryukyu.ac.jp>
date Mon, 13 Dec 2010 04:56:23 +0900 (2010-12-12)
parents 435ac1cdb64e
children 2c85322348cf
line wrap: on
line source
#include <stdio.h>
#include <stdlib.h>
#include <SDL.h>
#include "SDL_opengl.h"
#include "object.h"
#include "Character.h"
#include "Character_state.h"
#include "tokuten.h"
#include "collision.h"
#include "bom.h"
#include "count2.h"
#include "sound.h"
#include "sgoex.h"

extern SpriteTable sptable[DEFOBJ];


CHARACTER * atari(CHARACTER *p)
{
    int i1, h, w, ex, ey, charno;
    int n;
    ex = p->x;
    ey = p->y;
    charno = p->charano;
    w = sptable[charno].w;
    h = sptable[charno].h;
    //i2 = playerno;

    //自機やられ
#ifndef INVISIBLE_MODE
    if ((ex < jiki.x + 128 / 2) && (ex + w > jiki.x + 128 / 2)
	&& (ey < jiki.y + 128 / 2) && (ey + h > jiki.y + 128 / 2)
	&& jiki.muteki == 0) {
      //se_voice[0] = SsUtKeyOn(vab[JIKIOUT], 0, 0, 65, 0, 60, 60);
	Bom(jiki.x + 16, jiki.y + 16);
	jiki.bf = FALSE;
	jiki.zanki--;
	jiki.muteki = 120;

	infg.stg = 0;
	infg_level--;
	if (infg_level < 0)
	    infg_level = 0;

	return p;
    }
#endif

    if (p->tama == TRUE)
	goto jumping;
    for (i1 = 0; i1 < tama_lv1_end + 1; i1++) {

	if ((tama_lv1[i1].x + 64 + 64 > ex)
	    && (ex + w > tama_lv1[i1].x + 16)
	    && (tama_lv1[i1].y + 128 > ey) && (tama_lv1[i1].y < ey + h)
	    && (tama_lv1[i1].r != -1)) {
	    tama_lv1[i1].r = -1;
	    p->vit -= TAMALV1P;
	    infg.stg++;
	    if (p->vit <= 0) {
		infg.stg += 4;
		Bom(p->x, p->y);
		enemycount += (p->score *
			       ((infg.stg / 128) + infg_level + 1));
		p->state = delete_chara;
		p->collision = noaction;
		p->f = FALSE;
		return p;
	    }
	}
	if ((tama_lv1[i1].x + 64 > ex) && (ex + w > tama_lv1[i1].x)
	    && (tama_lv1[i1].y + 128 > ey) && (tama_lv1[i1].y < ey + h)
	    && (tama_lv1[i1].l != -1)) {
	    tama_lv1[i1].l = -1;
	    p->vit -= TAMALV1P;
	    infg.stg++;
	    if (p->vit <= 0) {
		infg.stg += 4;
		Bom(p->x, p->y);
		enemycount += (p->score *
			       ((infg.stg / 128) + infg_level + 1));
		p->state = delete_chara;
		p->collision = noaction;
		p->f = FALSE;
		return p;
	    }
	}
    }

    for (i1 = 0; i1 < tama_lv2_end + 1; i1++) {
	if ((tama_lv2[i1].x + 128 + 64 > ex)
	    && (ex + w > tama_lv2[i1].x + 128)
	    && (tama_lv2[i1].y + 192 > ey) && (tama_lv2[i1].y < ey + h)
	    && (tama_lv2[i1].rr != -1)) {
	    tama_lv2[i1].rr = -1;
	    p->vit -= TAMALV2P;
	    infg.stg++;
	    if (p->vit <= 0) {
		infg.stg += 4;
		Bom(p->x, p->y);
		enemycount += (p->score *
			       ((infg.stg / 128) + infg_level + 1));
		p->state = delete_chara;
		p->collision = noaction;
		p->f = FALSE;
		return p;
	    }
	}

	if ((tama_lv2[i1].x + 64 + 64 > ex)
	    && (ex + w > tama_lv2[i1].x + 16)
	    && (tama_lv2[i1].y - 32 + 192 > ey)
	    && (tama_lv2[i1].y - 32 < ey + h)
	    && (tama_lv2[i1].sr != -1)) {
	    tama_lv2[i1].sr = -1;
	    p->vit -= TAMALV2P;
	    infg.stg++;
	    if (p->vit <= 0) {
		infg.stg += 4;
		Bom(p->x, p->y);
		enemycount += (p->score *
			       ((infg.stg / 128) + infg_level + 1));
		p->state = delete_chara;
		p->collision = noaction;
		p->f = FALSE;
		return p;
	    }
	}
	if ((tama_lv2[i1].x + 64 > ex) && (ex + w > tama_lv2[i1].x)
	    && (tama_lv2[i1].y - 32 + 192 > ey)
	    && (tama_lv2[i1].y - 32 < ey + h)
	    && (tama_lv2[i1].sl != -1)) {
	    tama_lv2[i1].sl = -1;
	    p->vit -= TAMALV2P;
	    infg.stg++;
	    if (p->vit <= 0) {
		infg.stg += 4;
		Bom(p->x, p->y);
		enemycount += (p->score *
			       ((infg.stg / 128) + infg_level + 1));
		p->state = delete_chara;
		p->collision = noaction;
		p->f = FALSE;
		return p;
	    }
	}
	if ((tama_lv2[i1].x - 64 + 64 > ex)
	    && (ex + w > tama_lv2[i1].x - 64)
	    && (tama_lv2[i1].y + 192 > ey) && (tama_lv2[i1].y < ey + h)
	    && (tama_lv2[i1].ll != -1)) {
	    tama_lv2[i1].ll = -1;
	    p->vit -= TAMALV2P;
	    infg.stg++;
	    if (p->vit <= 0) {
		infg.stg += 4;
		Bom(p->x, p->y);
		enemycount += (p->score *
			       ((infg.stg / 128) + infg_level + 1));
		p->state = delete_chara;
		p->collision = noaction;
		p->f = FALSE;
		return p;
	    }
	}
    }
    if ((tlv3[0].r > 0) && (jiki.x < ex + w) && (jiki.x + 128 > ex)
	&& (jiki.y > ey + h)) {
	p->vit -= TAMALV3P;
	infg.stg++;
	if (p->vit <= 0) {
	    infg.stg += 4;
	    Bom(p->x, p->y);
	    enemycount += (p->score *
			   ((infg.stg / 128) + infg_level + 1));
	    p->state = delete_chara;
	    p->collision = noaction;
	    p->f = FALSE;
	    return p;
	}
    }
  jumping:
    if ((tlv3[0].r > 0) && (jiki.x < ex + w) && (jiki.x + 128 > ex)
	&& (jiki.y + 128 > ey) && (jiki.y < ey + h)) {
	p->vit -= TAMALV3P;
	infg.stg++;
	if (p->vit <= 0) {
	    infg.stg += 4;
	    Bom(p->x, p->y);
	    enemycount += (p->score *
			   ((infg.stg / 128) + infg_level + 1));
	    p->state = delete_chara;
	    p->collision = noaction;
	    p->f = FALSE;
	    return p;
	}
    }
    /*laser lv1 */
    for (i1 = 0; i1 < laser_lv1_end + 1; i1++) {
	n = laser_lv1[i1].r * 128 / 4096;

	if ((laser_lv1[i1].x + n > ex) && (ex + w > laser_lv1[i1].x)
	    && (laser_lv1[i1].y + n > ey) && (laser_lv1[i1].y < ey + h)
	    && (laser_lv1[i1].r != -1)) {
	    laser_lv1[i1].r = -1;
	    laser_lv1[i1].y = -1;
	    p->vit -= LASERLV1P;
	    infg.stg++;
	    if (p->vit <= 0) {
		infg.stg += 4;
		Bom(p->x, p->y);
		enemycount += (p->score *
			       ((infg.stg / 128) + infg_level + 1));
		p->state = delete_chara;
		p->collision = noaction;
		p->f = FALSE;
		return p;
	    }
	}
    }
    /*shield(laser lv2) */
    if ((p->tama == TRUE) && (lg.stg > 0) &&
	(laser_lv2[0].x + 128 > ex) && (ex + w > laser_lv2[0].x - 128)
	&& (laser_lv2[0].y + 128 > ey) && (laser_lv2[0].y - 128 < ey + h)
	&& (laser_lv2[0].r != 0)) {
	p->vit -= LASERLV2P;
	lg.stg -= 26;
	infg.stg++;
	if (p->vit <= 0) {
	    infg.stg += 4;
	    Bom(p->x, p->y);
	    enemycount += (p->score *
			   ((infg.stg / 128) + infg_level + 1));
	    p->state = delete_chara;
	    p->collision = noaction;
	    p->f = FALSE;
	    return p;
	}
    }
    /*bomber(laser lv3) */
    if (laser_lv3[0].r < 62) {
	for (i1 = 1; i1 < 128; i1++) {
	    if ((laser_lv3[i1].x + 128 > ex) && (ex + w > laser_lv3[i1].x)
		&& (laser_lv3[i1].y + 128 > ey)
		&& (laser_lv3[i1].y < ey + h)
		&& (laser_lv3[i1].r > 0)) {
		tama_lv2[i1].rr = -1;
		p->vit -= LASERLV3P;
		infg.stg++;
		if (p->vit <= 0) {
		    infg.stg += 4;
		    Bom(p->x, p->y);
		    enemycount += (p->score *
				   ((infg.stg / 128) + infg_level + 1));
		    p->state = delete_chara;
		    p->collision = noaction;
		    p->f = FALSE;
		    return p;
		}
	    }
	}
    }
    return p;
}