annotate TaskDandy.cc @ 57:978097c6427a

bug fix.
author koba <koba@cr.ie.u-ryukyu.ac.jp>
date Sat, 29 Jan 2011 22:43:17 +0900
parents 2c33aa6a4a37
children e0018f39f7e1
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"
54
3acdeb3dc3e8 collision use global_alloc (not work)
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 53
diff changeset
33 #include "collision_task.h"
57
978097c6427a bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
34 #include "state_task.h"
52
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 51
diff changeset
35 #include "StateList.h"
53
b31bed246abd fix code and add log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 52
diff changeset
36 #include "Cheat.h"
51
2e123c4bf5ca print object name and id.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 49
diff changeset
37 #include "debug_db.h"
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
38
53
b31bed246abd fix code and add log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 52
diff changeset
39
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
40 static int use_keybord = 0;
49
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 45
diff changeset
41 //static int cdp[20] = { 16, 16, 16, 17, 18, 0 };
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 45
diff changeset
42 static int i;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
43
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
44 static int rswait = 0;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
45 static int cf = 0;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
46 static int cc = 0;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
47
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 extern void schedule();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
49 extern void tokuten();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 extern void Pad();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 extern void keybord();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 static int gamesyokika(int gamef);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
53 static int game_pause(int);
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
54 static void KeyAssign(int runmode, TraceBuffPtr buff, SDL_Joystick *joy, SGO_PAD *pad);
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
55
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 extern void task_init();
41
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
57
51
2e123c4bf5ca print object name and id.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 49
diff changeset
58 DebugDB dtable[DEFOBJ];
2e123c4bf5ca print object name and id.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 49
diff changeset
59
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
60 static int runmode = 0;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
61 static TraceBuffPtr t_buff;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
62 static TraceBuffPtr first;
41
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
63 static char *pad_trace_file;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
64
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 /**
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 * runmode:
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 * 0 - normal game
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
68 * 1 - capture mode
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
69 * 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
70 * dump it into a file
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
71 * 2 - trace mode
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
72 * 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
73 * by capture-mode
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
74 */
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
75
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
76 static SDL_Joystick *joy;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
77
41
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
78 #define SCMP_SIZ 8
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
79
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
80 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
81 -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
82 -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
83
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
84 static Viewer *sgroot;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
85
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
86 TaskManager *tmanager;
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 static int screen_w;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
89 static int screen_h;
23
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 19
diff changeset
90 static int gamef;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
91
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
92 MainLoopPtr
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
93 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
94 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
95 screen_w = w;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
96 screen_h = h;
23
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 19
diff changeset
97 gamef = 0;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
98 sgroot = sgroot_;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
99 tmanager = sgroot->manager;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
100 return sgroot;
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
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
103 Application *
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
104 application() {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
105 return new Dandy();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
106 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
107
41
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
108 static void print_usage();
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
109 static int get_option(int argc, char *argv[]);
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
110 static int opening(int gamef);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
111 static int dandy_closing(int gamef);
57
978097c6427a bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
112 static int dandy_main_loop(int gamef, HTaskPtr next);
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
113 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
114 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
115 extern void task_initialize();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
116 static void TMend(TaskManager *manager);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
117
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
118 bool
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
119 Dandy::app_loop(Viewer *viewer){
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
120 // don't use allExecute
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
121 return 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
122 };
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
123
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
124
23
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 19
diff changeset
125 HTaskPtr
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
126 Dandy::application_task(HTaskPtr next, Viewer* viewer){
23
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 19
diff changeset
127 // printf("gamef = %d\n",gamef);
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
128 switch (gamef) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
129 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
130 case 1: gamef= gamesyokika(gamef); break;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
131 case 2: gamef= opening(gamef); break;
57
978097c6427a bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
132 case 3: gamef= dandy_main_loop(gamef, next); break;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
133 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
134 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
135 return next;
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
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
138 int
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
139 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
140 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
141 task_init();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
142 task_initialize();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
143 manager->set_TMend(TMend);
41
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
144 if (get_option(argc, argv)) {
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
145 print_usage();
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
146 }
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
147
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
148 return init(manager,argc, argv);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
149 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
150
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
151 void
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
152 TMend(TaskManager *manager)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
153 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
154 printf("game end\n");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
155 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
156
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
157 static int light_sysswitch = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
158 static int light_num = 4;
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 static void
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
161 _LightSysSwitch(Viewer *sgroot) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
162 if (light_sysswitch == 1) {
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
163 sgroot->OffLightSysSwitch();
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
164 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
165 SceneGraphPtr light = sgroot->getLight(i);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
166 sgroot->OnLightSwitch(i);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
167 light->xyz[0] = screen_w / 2;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
168 light->xyz[1] = screen_h / 2;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
169 light->xyz[2] = -100;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
170 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
171 } else if (light_sysswitch == 0) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
172 sgroot->OffLightSysSwitch();
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 }
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
41
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
177 static void
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
178 print_usage()
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
179 {
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
180 printf("usage: exe_file [-h|-help|--help][-capture filename][-trace filename]\n");
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
181 }
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
182
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
183
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
184 static int
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
185 get_option(int argc, char *argv[])
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
186 {
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
187 int i;
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
188 if (argc < 2) {
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
189 runmode = 0;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
190 return 0;
41
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
191 }
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
192 for (i = 0; i < argc; i++) {
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
193 if (!strncmp(argv[i], "-capture", SCMP_SIZ)) {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
194 if (++i >= argc) {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
195 return 1;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
196 }
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
197 printf("Start Capture mode.\n");
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
198 t_buff = (TraceBuffPtr)malloc(sizeof(TraceBuff));
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
199 t_buff->next = NULL;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
200 pad_trace_file = argv[i];
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
201 runmode = 1;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
202 return 0;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
203 } else if (!strncmp(argv[i], "-trace", SCMP_SIZ)) {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
204 if (++i >= argc) {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
205 return 1;
41
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
206 }
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
207 printf("Start Trace mode.\n");
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
208 t_buff = (TraceBuffPtr)malloc(sizeof(TraceBuff));
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
209 t_buff->next = NULL;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
210 pad_trace_file = argv[i];
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
211 runmode = 2;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
212 return 0;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
213 } else if (!strncmp(argv[i], "--help", SCMP_SIZ) ||
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
214 !strncmp(argv[i], "-help", SCMP_SIZ) ||
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
215 !strncmp(argv[i], "-h", SCMP_SIZ)) {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
216 return 1;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
217 }
41
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
218 }
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
219
41
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
220 return 1;
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
221 }
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
222
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
223
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
224 static int
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
225 dandy_main_init(int gamef)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
226 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
227 //Timeprof timeprof_move;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
228 //timeprof_move = timeprof_new();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
229 dbg_init("/dev/stdout");
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 * timeprof があるんだけどね
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
233 */
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
234 if ((runmode == 1)||(runmode ==2)) {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
235 if (!PadfileOpen(pad_trace_file)) {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
236 runmode = 0;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
237 } else if(runmode == 2) {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
238 PadfileRead(t_buff);
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
239 }
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
240 first = t_buff;
41
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
241 }
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
242
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
243 sgroot->createFromXMLfile("xml/character.xml");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
244 sgroot->createFromXMLfile("xml/font.xml");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
245 sgroot->createFromXMLfile("xml/effect.xml");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
246 sgroot->createFromXMLfile("xml/boss.xml");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
247
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
248 _LightSysSwitch(sgroot);
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 init_sprite(0,0,0,0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
251
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
252 __debug("syokikaが呼びだされました\n");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
253 joy=SDL_JoystickOpen(0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
254 if(!joy) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
255 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
256 use_keybord = 1;
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
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
259 /**
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
260 * sound.c に移しました
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
261 * 代わりに InitSdlMixer(void); を使います。
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
262 * まあ中身一緒なんだけどね
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
263 */
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 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
266 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
267 SDL_Quit();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
268 exit(-1);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
269 }
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
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
272 // SDL_mixer とかいろいろ初期化
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
273 // もし Init に失敗したら
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
274 // 以後の Mixer 関連の関数を呼び出しても
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
275 // 中では何も行われないとかいう小細工を入れました。
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
276 InitSdlMixer();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
277
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
278 // 音楽ファイルの読み込み
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
279 LoadSdlMixer();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
280
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 InitVolume();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
283
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
284 // 音出しテスト
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
285 PlaySdlMixer(-1, BGM);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
286
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
287 if(!(init_chara_list(1024))){
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
288 __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
289 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
290
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
291 __debug("finished init_chara_list\n");
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
292
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
293 initStateList();
54
3acdeb3dc3e8 collision use global_alloc (not work)
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 53
diff changeset
294 collision_allocate();
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
295
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
296 return 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
297 }
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 SceneGraphPtr root;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
300
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
301 // 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
302
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
303 static void
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
304 flip()
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
305 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
306 CameraPtr camera = sgroot->sgroot->getCamera();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
307
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
308 sgroot->sgroot->flip();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
309 sgroot->sgroot->lightCalc();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
310
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
311 root = sgroot->createSceneGraph();
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
312 root->xyz[0] = 0;
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
313 root->xyz[1] = 0;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
314 root->xyz[2] = 30.0f;
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 /*親の回転、座標から、子の回転、座標を算出*/
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
317 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
318 /*法線用の行列。Cameraの行列を抜いている(Cameraのコンストラクタで、単位行列にしている)*/
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
319 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
320
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
321 sgroot->setSceneData(root);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
322 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
323
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
324
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
325 static int
57
978097c6427a bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
326 dandy_main_loop(int gamef, HTaskPtr next)
6
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 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
329 (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
330 gamef = gamesyokika(gamef);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
331 }
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 if (pad[0].quit != 0) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
334 gamef = 4;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
335 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
336 flip();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
337
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
338 //SDL_FillRect(screen, NULL, background);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
339
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
340 schedule();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
341 enemyfaste = count;
27
871f7d9a2f35 running.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
342
871f7d9a2f35 running.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
343 if (jiki.bf == TRUE) {
871f7d9a2f35 running.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
344 Player(0);
871f7d9a2f35 running.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
345 count++;
871f7d9a2f35 running.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
346 PutSprite(count, jiki.x, jiki.y, jiki.ch);
871f7d9a2f35 running.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
347 }
34
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 33
diff changeset
348
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 33
diff changeset
349 Putbom();
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 33
diff changeset
350 tokuten();
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 33
diff changeset
351
7aaaaf5dde40 add new task.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 33
diff changeset
352 asteroidi = 0;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
353 // timeprof_begin(timeprof_move);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
354 outofwindow();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
355 // timeprof_end(timeprof_move);
55
2c33aa6a4a37 debug global_alloc.but new bugs appear
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 54
diff changeset
356
57
978097c6427a bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
357 HTaskPtr state_next = create_next();
978097c6427a bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
358
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
359 state_update();
54
3acdeb3dc3e8 collision use global_alloc (not work)
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 53
diff changeset
360
3acdeb3dc3e8 collision use global_alloc (not work)
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 53
diff changeset
361 HTaskPtr update = collision_update();
3acdeb3dc3e8 collision use global_alloc (not work)
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 53
diff changeset
362 HTaskPtr reflect = collision_reflect();
57
978097c6427a bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
363
38
6626e451a09d fix random number.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
364 collision_detect();
57
978097c6427a bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
365
978097c6427a bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
366 next->wait_for(state_next);
978097c6427a bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
367 next->wait_for(reflect);
978097c6427a bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
368
978097c6427a bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
369 state_next->spawn();
54
3acdeb3dc3e8 collision use global_alloc (not work)
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 53
diff changeset
370 update->spawn();
3acdeb3dc3e8 collision use global_alloc (not work)
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 53
diff changeset
371 reflect->spawn();
3acdeb3dc3e8 collision use global_alloc (not work)
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 53
diff changeset
372
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
373 //charpatern();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
374 //bosguage();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
375
49
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 45
diff changeset
376 //count++;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
377 //PutSprite(count, 0, 960 - 96, 10);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
378 /*インフレゲージ */
49
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 45
diff changeset
379 //count++;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
380 //PutSprite(count, 0, 0, 48);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
381
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
382 obj_draw();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
383 gamef = game_pause(gamef);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
384
57
978097c6427a bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
385 KeyAssign(runmode, t_buff, joy, pad);
978097c6427a bug fix.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 55
diff changeset
386
49
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 45
diff changeset
387 filpcount++;
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 45
diff changeset
388 count = 0;
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 45
diff changeset
389
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
390 return gamef;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
391 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
392
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
393 static int
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
394 dandy_closing(int gamef)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
395 {
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
396 if (runmode == 1) {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
397 PadfileWrite(first);
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
398 PadfileClose(first);
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
399 } else if (runmode == 2) {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
400 PadfileClose(first);
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
401 }
49
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 45
diff changeset
402 SDL_Event usr_event;
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 45
diff changeset
403 usr_event.type = SDL_QUIT;
54
3acdeb3dc3e8 collision use global_alloc (not work)
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 53
diff changeset
404 SDL_PushEvent(&usr_event);
49
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 45
diff changeset
405
54
3acdeb3dc3e8 collision use global_alloc (not work)
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 53
diff changeset
406 collision_free();
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
407
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
408 //_______________________________________________
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
409 // SDL_mixerの後始末
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
410 Mix_CloseAudio();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
411 Mix_HaltMusic();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
412 FreeSdlMixer() ;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
413 //_______________________________________________
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
414 return 0;
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
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
417
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
418 static int
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
419 gamesyokika(int gamef)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
420 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
421 laser_lv3[0].r = 62;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
422 laser_lv3[0].r = 62;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
423 for (i = 0; i < 3; i++) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
424 tlv3[i].y = -1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
425 }
33
39e643fc4f90 moving stage1.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 30
diff changeset
426 filpcount = 0;
41
6974c3834700 all trace mode moving.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 39
diff changeset
427 stage = 0;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
428 //for (i = 0; i < 300; i++)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
429 //enemy[i].f = FALSE;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
430 jiki.zanki = 3;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
431 jiki.x = 60;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
432 jiki.y = 200;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
433 jiki.ch = 3;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
434 jiki.point = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
435 jiki.bf = FALSE;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
436 jiki.muteki = 120;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
437 enemycount = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
438 lg.stg = 4096;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
439 pg.stg = 4096;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
440 infg.stg = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
441 infg_level = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
442 //kyeenemyno = -1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
443 fastebos = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
444 jiki.ccount = 99;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
445 p_extend = 200000;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
446 pad[0].up=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
447 pad[0].down=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
448 pad[0].right=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
449 pad[0].left=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
450 pad[0].st=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
451 pad[0].se=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
452
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
453 SoundStop();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
454 SoundPlay(7);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
455 gamef = 2;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
456 flip();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
457 return gamef;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
458 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
459
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
460 static int
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
461 opening(int gamef)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
462 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
463 if(use_keybord == 1) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
464 keybord();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
465 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
466 Pad(joy);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
467 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
468
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
469 count = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
470
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
471 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
472 count++;
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
473 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
474 count++;
49
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 45
diff changeset
475 //PutSprite(count, 200, 64, 190);
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 45
diff changeset
476 //PutSpriteEx(count, 8192, 8192, 0);
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
477 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
478 count++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
479 PutSprite(count, 396, 432, 191);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
480 //PutSpriteEx(count, 8192, 8192, 0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
481 count++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
482 PutSprite(count, 640, 640, 192);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
483 //PutSpriteEx(count, 8192, 8192, 0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
484
49
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 45
diff changeset
485 if ((pad[0].st > 1)||(runmode == 2)) {
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
486 jiki.bf = TRUE;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
487
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
488 //CdPlay(1,&cdp[0],0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
489 SoundStop();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
490 SoundPlay(0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
491
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
492 gamef = 3;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
493 pad[0].st = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
494 } 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
495 gamef = 2;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
496 }
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
497 flip();
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
498 return gamef;
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
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
501 static int
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
502 game_pause(int gamef)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
503 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
504 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
505 if (pad[0].se == 1) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
506 //Mix_Pause(BGM);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
507 PauseSdlMixer(BGM);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
508 while(1){
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
509 if(use_keybord == 1) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
510 keybord();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
511 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
512 Pad(joy);
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 if(pad[0].st == 0)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
515 continue;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
516 pad[0].up=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
517 pad[0].down=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
518 pad[0].right=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
519 pad[0].left=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
520 pad[0].se=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
521 pad[0].st=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
522 //Mix_Resume(BGM);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
523 ResumeSdlMixer(BGM);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
524 break;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
525 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
526 }
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 if (jiki.zanki == 0) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
529 // RECT *recp;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
530 if ((jiki.ccount > 0) && (cf == 0)) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
531 cf = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
532 count++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
533 //cgcg(2);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
534 PutSprite(2, 480, 480, 110);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
535 count++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
536 //cgcg(1);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
537 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
538 if ((jiki.ccount > 0) && (cf == 1)) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
539 while (1) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
540 if (pad[0].st > 0) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
541 cf = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
542 jiki.ccount--;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
543 jiki.zanki = 3;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
544 enemycount++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
545 cc = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
546 for (i = 0; i < 4; i++) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
547 clear_result[i] = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
548 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
549 goto f;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
550 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
551 cc++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
552 if (29 - cc / 60 < 20) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
553 cc = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
554 cf = 3;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
555 break;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
556 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
557 SDL_Delay(100);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
558 PutSprite(1, 640, 640, 29 - cc / 60);
49
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 45
diff changeset
559 //PutSpriteEx(1, 409 * ((cc % 60) + 1), 409 * ((cc % 60) + 1), 0);
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
560
53
b31bed246abd fix code and add log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 52
diff changeset
561 if(use_keybord == 1) {
b31bed246abd fix code and add log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 52
diff changeset
562 keybord();
b31bed246abd fix code and add log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 52
diff changeset
563 } else {
b31bed246abd fix code and add log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 52
diff changeset
564 Pad(joy);
b31bed246abd fix code and add log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 52
diff changeset
565 }
b31bed246abd fix code and add log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 52
diff changeset
566
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
567 flip(); // this is not correct
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
568 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
569 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
570 if (rswait > 60 * 6) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
571 cf = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
572 rswait = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
573 gamef = gamesyokika(gamef);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
574 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
575 rswait++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
576 count++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
577 //cgcg(1);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
578 PutSprite(1, 480, 480, 19);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
579 return gamef;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
580 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
581 if (jiki.bf == FALSE) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
582 f:
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
583 if (rswait < 80) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
584 rswait++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
585 return gamef;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
586 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
587 rswait = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
588 jiki.x = 60;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
589 jiki.y = 200;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
590 jiki.bf = TRUE;
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 pad[0].st = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
593 lg.stg = 4096;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
594 pg.stg = 4096;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
595 laser_lv3[0].r = 62;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
596 tlv3[0].r = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
597 tlv3[0].y = -1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
598 return gamef;
33
39e643fc4f90 moving stage1.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 30
diff changeset
599 // sb_size = -1;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
600 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
601 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
602 return gamef;
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
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
605
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
606 SpriteTable sptable[DEFOBJ];
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
607
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 void
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
610 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
611 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
612 sptable[number].mx = middlex;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
613 sptable[number].my = middley;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
614 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
615
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
616
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
617 void
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
618 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
619 {
51
2e123c4bf5ca print object name and id.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 49
diff changeset
620 dtable[number].name = name;
2e123c4bf5ca print object name and id.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 49
diff changeset
621 dtable[number].count = 0;
2e123c4bf5ca print object name and id.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 49
diff changeset
622
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
623 SpriteTable *m = &sptable[number];
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
624 m->w = w;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
625 m->h = h;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
626 m->color = (color & 32);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
627 m->mx = w / 2;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
628 m->my = h / 2;
29
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
629 m->tex_w = power_of_two(m->w);
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
630 m->tex_h = power_of_two(m->h);
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
631
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
632 m->texture = (int *)name;
29
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
633 }
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
634
29
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
635 static float my_scale = 5;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
636
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
637 void
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
638 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
639 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
640 SpriteTable *m = &sptable[number];
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
641 char *name = (char *) m->texture;
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
642 if (!name) {
45
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 44
diff changeset
643 // printf("PutSprite %d unknown\n",number);
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
644 return;
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
645 }
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
646 SceneGraphPtr object = sgroot->createSceneGraph(name);
29
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
647 object->xyz[0] = x - object->c_xyz[0]*my_scale;
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
648 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
649 object->xyz[2] = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
650 root->addChild(object);
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
651
29
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
652 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
653 /*親の回転、座標から、子の回転、座標を算出*/
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
654 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
655 /*法線用の行列。Cameraの行列を抜いている(Cameraのコンストラクタで、単位行列にしている)*/
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
656 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
657
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
658 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
659
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
660 void
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
661 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
662 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
663 SpriteTable *m = &sptable[number];
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
664 char *name = (char *) m->texture;
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
665 if (!name) {
45
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 44
diff changeset
666 // printf("PutSpriteEx %d unknown\n",number);
19
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
667 return;
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 7
diff changeset
668 }
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
669 SceneGraphPtr object = sgroot->createSceneGraph(name);
29
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
670 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
671 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
672 object->xyz[2] = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
673 object->c_xyz[0] = m->mx;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
674 object->c_xyz[1] = m->my;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
675 object->angle[3] = angle;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
676 root->addChild(object);
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 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
679 /*親の回転、座標から、子の回転、座標を算出*/
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
680 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
681 /*法線用の行列。Cameraの行列を抜いている(Cameraのコンストラクタで、単位行列にしている)*/
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
682 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
683 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
684
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
685 struct SGO_PAD pad[2];
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 /* コントローラ状態の読み込み */
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
688 void Pad(SDL_Joystick *joy)
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
689 {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
690 Sint16 axis;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
691
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
692 SDL_JoystickUpdate();
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 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
695 pad[0].k0++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
696 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
697 pad[0].k0=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
698
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
699 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
700 pad[0].k1++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
701 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
702 pad[0].k1=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
703
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
704 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
705 pad[0].k3++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
706 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
707 pad[0].k3=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
708
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
709 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
710 pad[0].k4++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
711 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
712 pad[0].k4=0;
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(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
715 pad[0].l1++;
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].l1=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 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
720 pad[0].r1++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
721 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
722 pad[0].r1=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
723
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
724 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
725 pad[0].l2++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
726 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
727 pad[0].l2=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
728
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
729 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
730 pad[0].r2++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
731 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
732 pad[0].r2=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
733
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
734 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
735 pad[0].st++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
736 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
737 pad[0].st=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
738
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
739 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
740 pad[0].se++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
741 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
742 pad[0].se=0;
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(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
745 pad[0].l3++;
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].l3=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 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
750 pad[0].r3++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
751 else
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
752 pad[0].r3=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
753 //x
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
754 axis=SDL_JoystickGetAxis(joy,0);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
755 if(axis>=3200){
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
756 pad[0].left=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
757 pad[0].right++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
758 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
759 else if(axis<=-3200){
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
760 pad[0].right=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
761 pad[0].left++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
762 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
763 else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
764 pad[0].right=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
765 pad[0].left=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 //y
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
768 axis=SDL_JoystickGetAxis(joy,1);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
769 if(axis>=3200){
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
770 pad[0].up=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
771 pad[0].down++;
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 else if(axis<=-3200){
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
774 pad[0].down=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
775 pad[0].up++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
776 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
777 else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
778 pad[0].down=0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
779 pad[0].up=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 ((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
783 (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
784 (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
785 pad[0].quit = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
786 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
787 pad[0].quit = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
788 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
789
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
790 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
791
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
792
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
793 void keybord()
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 SDL_PumpEvents();
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
796 Uint8 *keys = SDL_GetKeyState(NULL);
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
797
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
798 if (keys[SDLK_UP]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
799 pad[0].up++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
800 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
801 pad[0].up = 0;
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 if (keys[SDLK_DOWN]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
804 pad[0].down++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
805 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
806 pad[0].down = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
807 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
808
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
809 if (keys[SDLK_RIGHT]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
810 pad[0].right++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
811 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
812 pad[0].right = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
813 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
814
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
815 if (keys[SDLK_LEFT]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
816 pad[0].left++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
817 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
818 pad[0].left = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
819 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
820
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
821 if (keys[SDLK_a]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
822 pad[0].k0++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
823 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
824 pad[0].k0 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
825 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
826
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
827 if (keys[SDLK_z]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
828 pad[0].k1++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
829 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
830 pad[0].k1 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
831 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
832
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
833 if (keys[SDLK_s]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
834 pad[0].k3++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
835 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
836 pad[0].k3 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
837 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
838
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
839 if (keys[SDLK_x]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
840 pad[0].k4++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
841 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
842 pad[0].k4 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
843 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
844
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
845 if (keys[SDLK_r]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
846 pad[0].r2++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
847 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
848 pad[0].r2 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
849 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
850
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
851 if (keys[SDLK_e]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
852 pad[0].r1++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
853 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
854 pad[0].r1 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
855 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
856
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
857 if (keys[SDLK_w]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
858 pad[0].l1++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
859 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
860 pad[0].l1 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
861 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
862
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
863 if (keys[SDLK_q]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
864 pad[0].l2++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
865 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
866 pad[0].l2 = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
867 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
868
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
869 // START ボタンは Return が似合う気がする
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
870 //if(keys[SDLK_1])
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
871 if (keys[SDLK_RETURN]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
872 pad[0].st++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
873 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
874 pad[0].st = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
875 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
876
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
877 if (keys[SDLK_2]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
878 pad[0].se++;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
879 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
880 pad[0].se = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
881 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
882
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
883 if (keys[SDLK_ESCAPE]) {
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
884 pad[0].quit = 1;
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
885 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
886
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
887 if (keys[SDLK_0]) {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
888 pad[0].quit = 1;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
889 } else {
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
890 pad[0].quit = 0;
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
891 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
892 }
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
893
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
894
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
895 static void
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
896 KeyAssign(int runmode, TraceBuffPtr buff, SDL_Joystick *joy, SGO_PAD *pad)
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
897 {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
898 switch (runmode) {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
899 case 0:
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
900 if (use_keybord) {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
901 keybord();
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
902 } else {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
903 Pad(joy);
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
904 }
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
905 break;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
906 case 1:
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
907 if (use_keybord) {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
908 keybord();
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
909 } else {
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
910 Pad(joy);
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
911 }
53
b31bed246abd fix code and add log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 52
diff changeset
912 cheat();
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
913 t_buff = CapturePad(t_buff, pad);
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
914 break;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
915 case 2:
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
916 t_buff = TracePad(t_buff, pad);
53
b31bed246abd fix code and add log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 52
diff changeset
917 cheat();
44
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
918 break;
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
919 }
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
920 }
2c85322348cf add print log.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents: 41
diff changeset
921
6
9a92435eaee6 divide SG Dandy and Task Dandy.
koba <koba@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
922 /* end */