annotate TaskDandy.cc @ 49:f4140672ef9f

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