view atari.c @ 0:01387a2e419e

initial version
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Tue, 07 Dec 2010 15:39:45 +0900
parents
children
line wrap: on
line source

#include <SDL.h>
#include "atari.h"
#include "bom.h"
#include "count2.h"
#include "sound.h"
#include "Enemy.h"
//#include "libps.h"

//#include<libps.h>
#include "SDL_image.h"
//#include "libps2.h"
#include "SDL_opengl.h"
//#include "texture.h"
#include "object.h"
//#include "tree_controll.h"
#include "sgoex.h"
//#include "trace.h"
//#include "syokika.h"
//#include "LoadSprite.h"


extern SpriteTable sptable[DEFOBJ];


int atari(int playerno, int enemyno)
{
    int i1, i2, h, w, ex, ey, charno;
    int n;
    ex = enemy[enemyno].x;
    ey = enemy[enemyno].y;
    charno = enemy[enemyno].charno;
    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 (0);
    }
#endif

    if (enemy[enemyno].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;
	    enemy[enemyno].p -= TAMALV1P;
	    infg.stg++;
	    if (enemy[enemyno].p <= 0) {
		infg.stg += 4;
		return 1;
	    }
	}
	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;
	    enemy[enemyno].p -= TAMALV1P;
	    infg.stg++;
	    if (enemy[enemyno].p <= 0) {
		infg.stg += 4;
		return 1;
	    }
	}
    }

    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;
	    enemy[enemyno].p -= TAMALV2P;
	    infg.stg++;
	    if (enemy[enemyno].p <= 0) {
		infg.stg += 4;
		return 1;
	    }
	}

	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;
	    enemy[enemyno].p -= TAMALV2P;
	    infg.stg++;
	    if (enemy[enemyno].p <= 0) {
		infg.stg += 4;
		return 1;
	    }
	}
	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;
	    enemy[enemyno].p -= TAMALV2P;
	    infg.stg++;
	    if (enemy[enemyno].p <= 0) {
		infg.stg += 4;
		return 1;
	    }
	}
	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;
	    enemy[enemyno].p -= TAMALV2P;
	    infg.stg++;
	    if (enemy[enemyno].p <= 0) {
		infg.stg += 4;
		return 1;
	    }
	}
    }
    if ((tlv3[0].r > 0) && (jiki.x < ex + w) && (jiki.x + 128 > ex)
	&& (jiki.y > ey + h)) {
	enemy[enemyno].p -= TAMALV3P;
	infg.stg++;
	if (enemy[enemyno].p <= 0) {
	    infg.stg += 4;
	    return 1;
	}
    }
  jumping:
    if ((tlv3[0].r > 0) && (jiki.x < ex + w) && (jiki.x + 128 > ex)
	&& (jiki.y + 128 > ey) && (jiki.y < ey + h)) {
	enemy[enemyno].p -= TAMALV3P;
	infg.stg++;
	if (enemy[enemyno].p <= 0) {
	    infg.stg += 4;
	    return 1;
	}
    }
    /*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;
	    enemy[enemyno].p -= LASERLV1P;
	    infg.stg++;
	    if (enemy[enemyno].p <= 0) {
		infg.stg += 4;
		return 1;
	    }
	}
    }
    /*shield(laser lv2) */
    if ((enemy[enemyno].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)) {
	enemy[enemyno].p -= LASERLV2P;
	lg.stg -= 26;
	infg.stg++;
	if (enemy[enemyno].p <= 0) {
	    infg.stg += 4;
	    return 1;
	}
    }
    /*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;
		enemy[enemyno].p -= LASERLV3P;
		infg.stg++;
		if (enemy[enemyno].p <= 0) {
		    infg.stg += 4;
		    return 1;
		}
	    }
	}
    }
    return (0);
}