annotate TaskDandy.cc @ 44:2c85322348cf

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