1 /* $Id: centers.c,v 1.8 2005-07-03 13:12:47 chris Exp $ */
3 THE COMPUTER CODE CONTAINED HEREIN IS THE SOLE PROPERTY OF PARALLAX
4 SOFTWARE CORPORATION ("PARALLAX"). PARALLAX, IN DISTRIBUTING THE CODE TO
5 END-USERS, AND SUBJECT TO ALL OF THE TERMS AND CONDITIONS HEREIN, GRANTS A
6 ROYALTY-FREE, PERPETUAL LICENSE TO SUCH END-USERS FOR USE BY SUCH END-USERS
7 IN USING, DISPLAYING, AND CREATING DERIVATIVE WORKS THEREOF, SO LONG AS
8 SUCH USE, DISPLAY OR CREATION IS FOR NON-COMMERCIAL, ROYALTY OR REVENUE
9 FREE PURPOSES. IN NO EVENT SHALL THE END-USER USE THE COMPUTER CODE
10 CONTAINED HEREIN FOR REVENUE-BEARING PURPOSES. THE END-USER UNDERSTANDS
11 AND AGREES TO THE TERMS HEREIN AND ACCEPTS THE SAME BY USE OF THIS FILE.
12 COPYRIGHT 1993-1998 PARALLAX SOFTWARE CORPORATION. ALL RIGHTS RESERVED.
17 * Dialog box stuff for control centers, material centers, etc.
22 static char rcsid[] = "$Id: centers.c,v 1.8 2005-07-03 13:12:47 chris Exp $";
61 //-------------------------------------------------------------------------
62 // Variables for this module...
63 //-------------------------------------------------------------------------
64 static UI_WINDOW *MainWindow = NULL;
65 static UI_GADGET_BUTTON *QuitButton;
66 static UI_GADGET_RADIO *CenterFlag[MAX_CENTER_TYPES];
67 static UI_GADGET_CHECKBOX *RobotMatFlag[64]; // 2 ints = 64 bits
69 static int old_seg_num;
71 char center_names[MAX_CENTER_TYPES][CENTER_STRING_LENGTH] = {
79 //-------------------------------------------------------------------------
80 // Called from the editor... does one instance of the centers dialog box
81 //-------------------------------------------------------------------------
82 int do_centers_dialog()
86 // Only open 1 instance of this window...
87 if ( MainWindow != NULL ) return 0;
89 // Close other windows.
90 close_trigger_window();
91 hostage_close_window();
95 // Open a window with a quit button
96 MainWindow = ui_open_window( TMAPBOX_X+20, TMAPBOX_Y+20, 765-TMAPBOX_X, 545-TMAPBOX_Y, WIN_DIALOG );
97 QuitButton = ui_add_gadget_button( MainWindow, 20, 252, 48, 40, "Done", NULL );
99 // These are the checkboxes for each door flag.
101 CenterFlag[0] = ui_add_gadget_radio( MainWindow, 18, i, 16, 16, 0, "NONE" ); i += 24;
102 CenterFlag[1] = ui_add_gadget_radio( MainWindow, 18, i, 16, 16, 0, "FuelCen" ); i += 24;
103 CenterFlag[2] = ui_add_gadget_radio( MainWindow, 18, i, 16, 16, 0, "RepairCen" ); i += 24;
104 CenterFlag[3] = ui_add_gadget_radio( MainWindow, 18, i, 16, 16, 0, "ControlCen" ); i += 24;
105 CenterFlag[4] = ui_add_gadget_radio( MainWindow, 18, i, 16, 16, 0, "RobotCen" ); i += 24;
107 // These are the checkboxes for each robot flag.
108 for (i=0; i < 64; i++)
109 RobotMatFlag[i] = ui_add_gadget_checkbox( MainWindow, 128 + (i%2)*92, 20+(i/2)*24, 16, 16, 0, Robot_names[i]);
111 old_seg_num = -2; // Set to some dummy value so everything works ok on the first frame.
116 void close_centers_window()
118 if ( MainWindow!=NULL ) {
119 ui_close_window( MainWindow );
124 void do_centers_window()
131 if ( MainWindow == NULL ) return;
133 //------------------------------------------------------------
134 // Call the ui code..
135 //------------------------------------------------------------
136 ui_button_any_drawn = 0;
137 ui_window_do_gadgets(MainWindow);
139 //------------------------------------------------------------
140 // If we change walls, we need to reset the ui code for all
141 // of the checkboxes that control the wall flags.
142 //------------------------------------------------------------
143 if (old_seg_num != Cursegp-Segments) {
144 Assert(Curseg2p->special < MAX_CENTER_TYPES);
145 ui_radio_set_value(CenterFlag[Curseg2p->special], 1);
147 mprintf((0, "Curseg2p->matcen_num = %i\n", Curseg2p->matcen_num));
149 // Read materialization center robot bit flags
150 for (i = 0; i < 2; i++)
152 robot_index = i * 32;
153 robot_flags = RobotCenters[Curseg2p->matcen_num].robot_flags[i];
156 ui_checkbox_check(RobotMatFlag[i], robot_flags & 1);
164 //------------------------------------------------------------
165 // If any of the radio buttons that control the mode are set, then
166 // update the corresponding center.
167 //------------------------------------------------------------
170 for ( i=0; i < MAX_CENTER_TYPES; i++ ) {
171 if ( CenterFlag[i]->flag == 1 )
174 fuelcen_delete(Cursegp);
175 else if (Curseg2p->special != i)
177 fuelcen_delete(Cursegp);
179 fuelcen_activate( Cursegp, i );
184 for (i = 0; i < 2; i++)
186 robot_flags = RobotCenters[Curseg2p->matcen_num].robot_flags[i];
188 for (robot_index = 0; robot_index < 32; robot_index++)
190 if (RobotMatFlag[robot_index + i * 32]->flag == 1)
192 if (!(robot_flags & (1 << robot_index)))
194 robot_flags |= (1 << robot_index);
195 mprintf((0, "Segment %i, matcen = %i, robot_flags[%d] = %d\n", Cursegp - Segments, Curseg2p->matcen_num, i, robot_flags));
198 else if (robot_flags & 1 << robot_index)
200 robot_flags &= ~(1 << robot_index);
201 mprintf((0, "Segment %i, matcen = %i, robot_flags[%d] = %d\n", Cursegp - Segments, Curseg2p->matcen_num, i, robot_flags));
205 RobotCenters[Curseg2p->matcen_num].robot_flags[i] = robot_flags;
208 //------------------------------------------------------------
209 // If anything changes in the ui system, redraw all the text that
210 // identifies this wall.
211 //------------------------------------------------------------
212 if (redraw_window || (old_seg_num != Cursegp-Segments ) ) {
214 // char temp_text[CENTER_STRING_LENGTH];
216 ui_wprintf_at( MainWindow, 12, 6, "Seg: %3d", Cursegp-Segments );
218 // for (i=0; i<CENTER_STRING_LENGTH; i++)
219 // temp_text[i] = ' ';
222 // Assert(Curseg2p->special < MAX_CENTER_TYPES);
223 // strncpy(temp_text, Center_names[Curseg2p->special], strlen(Center_names[Curseg2p->special]));
224 // ui_wprintf_at( MainWindow, 12, 23, " Type: %s", temp_text );
225 Update_flags |= UF_WORLD_CHANGED;
228 if ( QuitButton->pressed || (last_keypress==KEY_ESC) ) {
229 close_centers_window();
233 old_seg_num = Cursegp-Segments;