annotate TaskDandy.cc @ 30:427e1aac0bd7

not run.
author koba <koba@cr.ie.u-ryukyu.ac.jp>
date Fri, 31 Dec 2010 15:50:44 +0900
parents d2e627af7f61
children 39e643fc4f90
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 #include "Dandy.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 #include <stdio.h>
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 #include <stdlib.h>
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 #include <string.h>
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 #include <ctype.h>
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 #include <math.h>
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 #include <time.h>
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 #include <SDL.h>
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 #include "SDL_opengl.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 #include "object.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 #include "tree_controll.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 #include "xml.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
13 #include "profile.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 #include "syokika.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 #include "sankaku.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 #include "sgoex.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
17 #include "sound.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 #include "bool.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
19 #include "bom.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
20 #include "count2.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 #include "tokuten.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
22 #include "schedule.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
23 #include "tama.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 #include "debug.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
25 #include "trace.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 #include "LoadSprite.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
27 #include <SDL_mixer.h>
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
28 #include "error.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
29 #include "matrix_calc.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
30 #include "Character.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 #include "Character_state.h"
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 #include "property.h"
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
33 #include "state_task.h"
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
34
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 int use_keybord = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 int cdp[20] = { 16, 16, 16, 17, 18, 0 };
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 int d, i;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
38
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 int rswait = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 int cf = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 int cc = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
42
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 //static SDL_Surface *screen;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 // static Uint32 background;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 // static char *pad_trace_file;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
46
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 extern void schedule();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 extern void tokuten();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
49 extern void Pad();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 extern void keybord();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 static int gamesyokika(int gamef);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 static int game_pause(int);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
53
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 extern void task_init();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
55 //static char *pad_trace_file;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
56
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 /**
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
58 * runmode:
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 * 0 - normal game
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
60 * 1 - capture mode
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 * program will capture all pad traces on a play and
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 * dump it into a file
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 * 2 - trace mode
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
64 * program will run with a trace file which is generated
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 * by capture-mode
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 */
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 int runmode;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
68
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
69 SDL_Joystick *joy;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
70
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
71
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
72
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
73 const char *usr_help_str = "Usage: ./twice [-length data_length] [-count task_num]\n\
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
74 -length Number of data (default DATA_NUM (Func.h))\n\
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
75 -count Number of task (default 1)\n";
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
76
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
77 static Viewer *sgroot;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
78
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
79 TaskManager *tmanager;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
80
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
81 static int screen_w;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
82 static int screen_h;
23
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 19
diff changeset
83 static int gamef;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
84
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
85 MainLoopPtr
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
86 Dandy::init(Viewer *sgroot_, int w, int h)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
87 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
88 screen_w = w;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
89 screen_h = h;
23
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 19
diff changeset
90 gamef = 0;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
91 sgroot = sgroot_;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
92 tmanager = sgroot->manager;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
93 return sgroot;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
94 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
95
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
96 Application *
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
97 application() {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
98 return new Dandy();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
99 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
100
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
101
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
102 static int opening(int gamef);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
103 static int dandy_closing(int gamef);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
104 static int dandy_main_loop(int gamef);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
105 static int dandy_main_init(int gamef);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
106 extern int init(TaskManager *manager, int argc, char *argv[]);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
107 extern void task_initialize();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
108 static void TMend(TaskManager *manager);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
109
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
110 bool
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
111 Dandy::app_loop(Viewer *viewer){
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
112 // don't use allExecute
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
113 return 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
114 };
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
115
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
116
23
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 19
diff changeset
117 HTaskPtr
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
118 Dandy::application_task(HTaskPtr next, Viewer* viewer){
23
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 19
diff changeset
119 // printf("gamef = %d\n",gamef);
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
120 switch (gamef) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
121 case 0: gamef= dandy_main_init(gamef); break;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
122 case 1: gamef= gamesyokika(gamef); break;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
123 case 2: gamef= opening(gamef); break;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
124 case 3: gamef= dandy_main_loop(gamef); break;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
125 case 4: gamef= dandy_closing(gamef); break;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
126 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
127 return next;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
128 };
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
129
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
130 int
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
131 TMmain(TaskManager *manager,int argc, char *argv[])
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
132 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
133 task_init();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
134 task_initialize();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
135 manager->set_TMend(TMend);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
136
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
137 return init(manager,argc, argv);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
138 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
139
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
140 void
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
141 TMend(TaskManager *manager)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
142 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
143 printf("game end\n");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
144 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
145
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
146 static int light_sysswitch = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
147 static int light_num = 4;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
148
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
149 static void
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
150 _LightSysSwitch(Viewer *sgroot) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
151 if (light_sysswitch == 1) {
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
152 sgroot->OffLightSysSwitch();
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
153 for (int i = 0; i < light_num; i++) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
154 SceneGraphPtr light = sgroot->getLight(i);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
155 sgroot->OnLightSwitch(i);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
156 light->xyz[0] = screen_w / 2;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
157 light->xyz[1] = screen_h / 2;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
158 light->xyz[2] = -100;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
159 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
160 } else if (light_sysswitch == 0) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
161 sgroot->OffLightSysSwitch();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
162 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
163 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
164
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
165
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
166 static int
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
167 dandy_main_init(int gamef)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
168 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
169 //Timeprof timeprof_move;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
170 //timeprof_move = timeprof_new();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
171 dbg_init("/dev/stdout");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
172
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
173 /**
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
174 * timeprof があるんだけどね
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
175 */
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
176
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
177 sgroot->createFromXMLfile("xml/character.xml");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
178 sgroot->createFromXMLfile("xml/font.xml");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
179 sgroot->createFromXMLfile("xml/effect.xml");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
180 sgroot->createFromXMLfile("xml/boss.xml");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
181
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
182 _LightSysSwitch(sgroot);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
183
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
184 init_sprite(0,0,0,0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
185
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
186 __debug("syokikaが呼びだされました\n");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
187 joy=SDL_JoystickOpen(0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
188 if(!joy) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
189 fprintf(stderr,"failed to open joystick 0\n");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
190 use_keybord = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
191 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
192
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
193 /**
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
194 * sound.c に移しました
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
195 * 代わりに InitSdlMixer(void); を使います。
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
196 * まあ中身一緒なんだけどね
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
197 */
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
198 /**
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
199 if (Mix_OpenAudio(MIX_DEFAULT_FREQUENCY,MIX_DEFAULT_FORMAT,2,1024) < 0) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
200 fprintf(stderr,"failed to initialize SDL_mixer.\n");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
201 SDL_Quit();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
202 exit(-1);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
203 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
204 */
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
205
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
206 // SDL_mixer とかいろいろ初期化
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
207 // もし Init に失敗したら
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
208 // 以後の Mixer 関連の関数を呼び出しても
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
209 // 中では何も行われないとかいう小細工を入れました。
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
210 InitSdlMixer();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
211
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
212 // 音楽ファイルの読み込み
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
213 LoadSdlMixer();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
214
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
215 // ボリューム調整
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
216 InitVolume();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
217
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
218 // 音出しテスト
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
219 PlaySdlMixer(-1, BGM);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
220
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
221 if(!(init_chara_list(1024))){
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
222 __debug("failed to init_chara_list\n");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
223 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
224
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
225 __debug("finished init_chara_list\n");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
226
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
227 initStateList();
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
228
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
229 return 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
230 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
231
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
232 SceneGraphPtr root;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
233
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
234 // extern void get_matrix(float *matrix, float *rxyz, float *txyz, float *scale, float *stack);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
235
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
236 static void
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
237 flip()
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
238 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
239 CameraPtr camera = sgroot->sgroot->getCamera();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
240
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
241 sgroot->sgroot->flip();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
242 sgroot->sgroot->lightCalc();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
243
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
244 root = sgroot->createSceneGraph();
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
245 root->xyz[0] = 0;
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
246 root->xyz[1] = 0;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
247 root->xyz[2] = 30.0f;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
248
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
249 /*親の回転、座標から、子の回転、座標を算出*/
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
250 get_matrix(root->matrix, root->angle, root->xyz, root->scale, camera->matrix);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
251 /*法線用の行列。Cameraの行列を抜いている(Cameraのコンストラクタで、単位行列にしている)*/
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
252 get_matrix(root->real_matrix, root->angle, root->xyz, root->scale, camera->real_matrix);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
253
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
254 sgroot->setSceneData(root);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
255 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
256
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
257
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
258 static int
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
259 dandy_main_loop(int gamef)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
260 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
261 if ((pad[0].l1 != 0) && (pad[0].r1 != 0) &&
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
262 (pad[0].l2 != 0) && (pad[0].r2 != 0)) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
263 gamef = gamesyokika(gamef);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
264 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
265
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
266 if (pad[0].quit != 0) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
267 gamef = 4;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
268 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
269 flip();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
270
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
271 //SDL_FillRect(screen, NULL, background);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
272
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
273 schedule();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
274 enemyfaste = count;
27
871f7d9a2f35 running.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
275
871f7d9a2f35 running.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
276 if (jiki.bf == TRUE) {
871f7d9a2f35 running.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
277 Player(0);
871f7d9a2f35 running.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
278 count++;
871f7d9a2f35 running.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
279 PutSprite(count, jiki.x, jiki.y, jiki.ch);
871f7d9a2f35 running.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
280 }
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
281
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
282 // timeprof_begin(timeprof_move);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
283 //Move(); //enemy move
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
284 collision_detect();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
285 outofwindow();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
286 // timeprof_end(timeprof_move);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
287 state_update();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
288 asteroidi = 0;
26
c4210c1053e8 add state7.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 23
diff changeset
289 printf("frame = %d\n", filpcount);
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
290 //charpatern();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
291 //bosguage();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
292
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
293 count++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
294 //PutSprite(count, 0, 960 - 96, 10);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
295 /*インフレゲージ */
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
296 count++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
297 //PutSprite(count, 0, 0, 48);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
298
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
299 obj_draw();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
300 gamef = game_pause(gamef);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
301
28
813f5461daab collision bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 27
diff changeset
302
813f5461daab collision bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 27
diff changeset
303 Putbom();
813f5461daab collision bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 27
diff changeset
304 tokuten();
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
305 if (use_keybord) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
306 keybord();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
307 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
308 Pad(joy);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
309 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
310 filpcount++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
311 count = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
312
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
313 return gamef;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
314 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
315
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
316 static int
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
317 dandy_closing(int gamef)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
318 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
319
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
320 //_______________________________________________
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
321 // SDL_mixerの後始末
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
322 Mix_CloseAudio();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
323 Mix_HaltMusic();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
324 FreeSdlMixer() ;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
325 //_______________________________________________
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
326 return 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
327 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
328
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
329
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
330 static int
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
331 gamesyokika(int gamef)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
332 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
333 laser_lv3[0].r = 62;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
334 laser_lv3[0].r = 62;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
335 for (i = 0; i < 3; i++) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
336 tlv3[i].y = -1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
337 }
30
427e1aac0bd7 not run.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 29
diff changeset
338 filpcount = 32*45;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
339 stage = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
340 //for (i = 0; i < 300; i++)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
341 //enemy[i].f = FALSE;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
342 jiki.zanki = 3;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
343 jiki.x = 60;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
344 jiki.y = 200;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
345 jiki.ch = 3;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
346 jiki.point = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
347 jiki.bf = FALSE;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
348 jiki.muteki = 120;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
349 enemycount = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
350 lg.stg = 4096;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
351 pg.stg = 4096;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
352 infg.stg = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
353 infg_level = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
354 //kyeenemyno = -1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
355 fastebos = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
356 jiki.ccount = 99;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
357 p_extend = 200000;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
358 pad[0].up=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
359 pad[0].down=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
360 pad[0].right=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
361 pad[0].left=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
362 pad[0].st=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
363 pad[0].se=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
364
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
365 SoundStop();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
366 SoundPlay(7);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
367 gamef = 2;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
368 flip();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
369 return gamef;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
370 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
371
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
372 static int
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
373 opening(int gamef)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
374 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
375 if(use_keybord == 1) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
376 keybord();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
377 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
378 Pad(joy);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
379 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
380
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
381 count = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
382
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
383 PutSprite(count, 700, 480, 53); // put `push start' string on screen.
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
384 count++;
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
385 PutSprite(count, 224, 776, 119); // put `super dandy'
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
386 count++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
387 // PutSprite(count, 200, 64, 190);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
388 // PutSpriteEx(count, 8192, 8192, 0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
389 PutSpriteEx(190, 800, 264, 2, 2, 5);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
390 count++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
391 PutSprite(count, 396, 432, 191);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
392 //PutSpriteEx(count, 8192, 8192, 0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
393 count++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
394 PutSprite(count, 640, 640, 192);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
395 //PutSpriteEx(count, 8192, 8192, 0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
396
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
397 if (pad[0].st > 1) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
398 jiki.bf = TRUE;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
399
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
400 //CdPlay(1,&cdp[0],0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
401 SoundStop();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
402 SoundPlay(0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
403
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
404 gamef = 3;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
405 pad[0].st = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
406 } else if ((pad[0].se > 0) && (pad[0].st > 0)) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
407 gamef = 2;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
408 }
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
409 flip();
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
410 return gamef;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
411 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
412
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
413 static int
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
414 game_pause(int gamef)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
415 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
416 gamef = 3;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
417 if (jiki.zanki != 0 && jiki.bf != FALSE) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
418 if (pad[0].se == 1) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
419 //Mix_Pause(BGM);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
420 PauseSdlMixer(BGM);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
421 while(1){
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
422 if(use_keybord == 1) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
423 keybord();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
424 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
425 Pad(joy);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
426 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
427 if(pad[0].st == 0)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
428 continue;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
429 pad[0].up=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
430 pad[0].down=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
431 pad[0].right=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
432 pad[0].left=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
433 pad[0].se=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
434 pad[0].st=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
435 //Mix_Resume(BGM);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
436 ResumeSdlMixer(BGM);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
437 break;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
438 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
439 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
440 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
441 if (jiki.zanki == 0) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
442 // RECT *recp;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
443 if ((jiki.ccount > 0) && (cf == 0)) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
444 cf = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
445 count++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
446 //cgcg(2);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
447 PutSprite(2, 480, 480, 110);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
448 count++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
449 //cgcg(1);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
450 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
451 if ((jiki.ccount > 0) && (cf == 1)) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
452 while (1) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
453 if (pad[0].st > 0) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
454 cf = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
455 jiki.ccount--;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
456 jiki.zanki = 3;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
457 enemycount++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
458 cc = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
459 for (i = 0; i < 4; i++) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
460 clear_result[i] = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
461 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
462 goto f;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
463 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
464 cc++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
465 if (29 - cc / 60 < 20) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
466 cc = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
467 cf = 3;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
468 break;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
469 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
470 SDL_Delay(100);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
471 PutSprite(1, 640, 640, 29 - cc / 60);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
472 // PutSpriteEx(1, 409 * ((cc % 60) + 1), 409 * ((cc % 60) + 1), 0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
473
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
474 Pad(joy);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
475 flip(); // this is not correct
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
476 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
477 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
478 if (rswait > 60 * 6) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
479 cf = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
480 rswait = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
481 gamef = gamesyokika(gamef);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
482 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
483 rswait++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
484 count++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
485 //cgcg(1);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
486 PutSprite(1, 480, 480, 19);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
487 return gamef;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
488 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
489 if (jiki.bf == FALSE) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
490 f:
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
491 if (rswait < 80) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
492 rswait++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
493 return gamef;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
494 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
495 rswait = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
496 jiki.x = 60;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
497 jiki.y = 200;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
498 jiki.bf = TRUE;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
499
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
500 pad[0].st = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
501 lg.stg = 4096;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
502 pg.stg = 4096;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
503 laser_lv3[0].r = 62;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
504 tlv3[0].r = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
505 tlv3[0].y = -1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
506 return gamef;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
507 // sb_size = -1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
508 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
509 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
510 return gamef;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
511 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
512
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
513
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
514 SpriteTable sptable[DEFOBJ];
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
515
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
516
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
517 void
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
518 DefSpriteEx(int number, short middlex, short middley)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
519 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
520 sptable[number].mx = middlex;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
521 sptable[number].my = middley;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
522 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
523
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
524
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
525 void
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
526 DefSprite(int number, const char *name, float w, float h, int color, OBJECT *obj)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
527 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
528 SpriteTable *m = &sptable[number];
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
529 m->w = w;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
530 m->h = h;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
531 m->color = (color & 32);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
532 m->mx = w / 2;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
533 m->my = h / 2;
29
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
534 m->tex_w = power_of_two(m->w);
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
535 m->tex_h = power_of_two(m->h);
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
536
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
537 m->texture = (int *)name;
29
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
538 }
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
539
29
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
540 static float my_scale = 5;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
541
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
542 void
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
543 PutSprite(int zorder, short x, short y, int number)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
544 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
545 SpriteTable *m = &sptable[number];
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
546 char *name = (char *) m->texture;
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
547 if (!name) {
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
548 printf("PutSprite %d unknown\n",number);
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
549 return;
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
550 }
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
551 SceneGraphPtr object = sgroot->createSceneGraph(name);
29
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
552 object->xyz[0] = x - object->c_xyz[0]*my_scale;
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
553 object->xyz[1] = y - object->c_xyz[1]*my_scale;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
554 object->xyz[2] = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
555 root->addChild(object);
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
556
29
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
557 float scale[] = {my_scale,my_scale,1};
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
558 /*親の回転、座標から、子の回転、座標を算出*/
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
559 get_matrix(object->matrix, object->angle, object->xyz, scale, root->matrix);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
560 /*法線用の行列。Cameraの行列を抜いている(Cameraのコンストラクタで、単位行列にしている)*/
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
561 get_matrix(object->real_matrix, object->angle, object->xyz, scale, root->real_matrix);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
562
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
563 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
564
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
565 void
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
566 PutSpriteEx(int number, int x, int y, float scalex, float scaley, float angle)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
567 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
568 SpriteTable *m = &sptable[number];
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
569 char *name = (char *) m->texture;
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
570 if (!name) {
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
571 printf("PutSpriteEx %d unknown\n",number);
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
572 return;
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
573 }
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
574 SceneGraphPtr object = sgroot->createSceneGraph(name);
29
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
575 object->xyz[0] = x - object->c_xyz[0]*my_scale - m->w*my_scale;
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
576 object->xyz[1] = y - object->c_xyz[0]*my_scale - m->w*my_scale;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
577 object->xyz[2] = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
578 object->c_xyz[0] = m->mx;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
579 object->c_xyz[1] = m->my;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
580 object->angle[3] = angle;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
581 root->addChild(object);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
582
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
583 float scale[] = {5*scalex,5*scaley,1};
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
584 /*親の回転、座標から、子の回転、座標を算出*/
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
585 get_matrix(object->matrix, object->angle, object->xyz, scale, root->matrix);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
586 /*法線用の行列。Cameraの行列を抜いている(Cameraのコンストラクタで、単位行列にしている)*/
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
587 get_matrix(object->real_matrix, object->angle, object->xyz, scale, root->real_matrix);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
588 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
589
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
590 struct SGO_PAD pad[2];
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
591
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
592 /* コントローラ状態の読み込み */
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
593 void Pad(SDL_Joystick *joy)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
594 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
595 Sint16 axis;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
596
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
597 SDL_JoystickUpdate();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
598
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
599 if(SDL_JoystickGetButton(joy,PS2_CROSS)==SDL_PRESSED)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
600 pad[0].k0++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
601 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
602 pad[0].k0=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
603
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
604 if(SDL_JoystickGetButton(joy,PS2_CIRCLE)==SDL_PRESSED)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
605 pad[0].k1++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
606 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
607 pad[0].k1=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
608
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
609 if(SDL_JoystickGetButton(joy,PS2_SQUARE)==SDL_PRESSED)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
610 pad[0].k3++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
611 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
612 pad[0].k3=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
613
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
614 if(SDL_JoystickGetButton(joy,PS2_TRIANGLE)==SDL_PRESSED)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
615 pad[0].k4++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
616 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
617 pad[0].k4=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
618
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
619 if(SDL_JoystickGetButton(joy,PS2_L1)==SDL_PRESSED)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
620 pad[0].l1++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
621 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
622 pad[0].l1=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
623
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
624 if(SDL_JoystickGetButton(joy,PS2_R1)==SDL_PRESSED)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
625 pad[0].r1++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
626 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
627 pad[0].r1=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
628
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
629 if(SDL_JoystickGetButton(joy,PS2_L2)==SDL_PRESSED)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
630 pad[0].l2++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
631 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
632 pad[0].l2=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
633
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
634 if(SDL_JoystickGetButton(joy,PS2_R2)==SDL_PRESSED)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
635 pad[0].r2++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
636 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
637 pad[0].r2=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
638
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
639 if(SDL_JoystickGetButton(joy,PS2_START)==SDL_PRESSED)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
640 pad[0].st++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
641 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
642 pad[0].st=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
643
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
644 if(SDL_JoystickGetButton(joy,PS2_SELECT)==SDL_PRESSED)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
645 pad[0].se++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
646 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
647 pad[0].se=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
648
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
649 if(SDL_JoystickGetButton(joy,PS2_L3)==SDL_PRESSED)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
650 pad[0].l3++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
651 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
652 pad[0].l3=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
653
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
654 if(SDL_JoystickGetButton(joy,PS2_R3)==SDL_PRESSED)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
655 pad[0].r3++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
656 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
657 pad[0].r3=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
658 //x
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
659 axis=SDL_JoystickGetAxis(joy,0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
660 if(axis>=3200){
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
661 pad[0].left=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
662 pad[0].right++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
663 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
664 else if(axis<=-3200){
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
665 pad[0].right=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
666 pad[0].left++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
667 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
668 else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
669 pad[0].right=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
670 pad[0].left=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
671 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
672 //y
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
673 axis=SDL_JoystickGetAxis(joy,1);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
674 if(axis>=3200){
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
675 pad[0].up=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
676 pad[0].down++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
677 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
678 else if(axis<=-3200){
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
679 pad[0].down=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
680 pad[0].up++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
681 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
682 else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
683 pad[0].down=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
684 pad[0].up=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
685 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
686
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
687 if ((pad[0].l1 != 0) && (pad[0].r1 != 0) &&
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
688 (pad[0].l2 != 0) && (pad[0].r2 != 0) &&
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
689 (pad[0].st != 0) && (pad[0].se != 0)) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
690 pad[0].quit = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
691 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
692 pad[0].quit = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
693 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
694
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
695 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
696
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
697
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
698 void keybord()
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
699 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
700 SDL_PumpEvents();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
701 Uint8 *keys = SDL_GetKeyState(NULL);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
702
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
703 if (keys[SDLK_UP]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
704 pad[0].up++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
705 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
706 pad[0].up = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
707 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
708 if (keys[SDLK_DOWN]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
709 pad[0].down++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
710 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
711 pad[0].down = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
712 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
713
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
714 if (keys[SDLK_RIGHT]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
715 pad[0].right++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
716 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
717 pad[0].right = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
718 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
719
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
720 if (keys[SDLK_LEFT]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
721 pad[0].left++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
722 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
723 pad[0].left = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
724 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
725
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
726 if (keys[SDLK_a]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
727 pad[0].k0++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
728 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
729 pad[0].k0 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
730 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
731
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
732 if (keys[SDLK_z]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
733 pad[0].k1++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
734 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
735 pad[0].k1 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
736 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
737
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
738 if (keys[SDLK_s]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
739 pad[0].k3++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
740 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
741 pad[0].k3 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
742 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
743
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
744 if (keys[SDLK_x]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
745 pad[0].k4++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
746 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
747 pad[0].k4 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
748 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
749
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
750 if (keys[SDLK_r]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
751 pad[0].r2++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
752 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
753 pad[0].r2 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
754 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
755
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
756 if (keys[SDLK_e]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
757 pad[0].r1++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
758 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
759 pad[0].r1 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
760 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
761
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
762 if (keys[SDLK_w]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
763 pad[0].l1++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
764 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
765 pad[0].l1 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
766 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
767
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
768 if (keys[SDLK_q]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
769 pad[0].l2++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
770 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
771 pad[0].l2 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
772 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
773
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
774 // START ボタンは Return が似合う気がする
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
775 //if(keys[SDLK_1])
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
776 if (keys[SDLK_RETURN]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
777 pad[0].st++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
778 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
779 pad[0].st = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
780 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
781
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
782 if (keys[SDLK_2]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
783 pad[0].se++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
784 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
785 pad[0].se = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
786 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
787
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
788 if (keys[SDLK_ESCAPE]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
789 SDL_Quit();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
790 exit(1);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
791 //pad[0].st = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
792 //pad[0].se = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
793 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
794
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
795 if (keys[SDLK_0]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
796 pad[0].quit = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
797 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
798 pad[0].quit = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
799 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
800 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
801
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
802
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
803 /* end */