annotate TaskDandy.cc @ 70:cee55c8365e9 default tip

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