1 /**************************************************************************
2 * tkglkey.c -- handle tkgl keyboard events
4 * Written by Curtis Olson, started May 1997.
6 * Copyright (C) 1997 Curtis L. Olson - curt@infoplane.com
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License as
10 * published by the Free Software Foundation; either version 2 of the
11 * License, or (at your option) any later version.
13 * This program is distributed in the hope that it will be useful, but
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
23 * (Log is kept at end of this file)
24 **************************************************************************/
32 #include "../aircraft/aircraft.h"
34 extern double fogDensity;
36 /* Handle keyboard events */
37 void GLUTkey(unsigned char k, int x, int y) {
38 struct control_params *c;
40 c = ¤t_aircraft.controls;
42 printf("Key hit = %d\n", k);
45 case 50: /* numeric keypad 2 */
48 case 56: /* numeric keypad 8 */
51 case 49: /* numeric keypad 1 */
52 fgElevTrimMove(-0.001);
54 case 55: /* numeric keypad 7 */
55 fgElevTrimMove(0.001);
57 case 52: /* numeric keypad 4 */
60 case 54: /* numeric keypad 6 */
63 case 48: /* numeric keypad Ins */
66 case 13: /* numeric keypad Enter */
69 case 53: /* numeric keypad 5 */
74 case 57: /* numeric keypad 9 (Pg Up) */
75 fgThrottleMove(0, 0.01);
77 case 51: /* numeric keypad 3 (Pg Dn) */
78 fgThrottleMove(0, -0.01);
82 glFogf(GL_FOG_END, fogDensity);
83 printf("Fog density = %.4f\n", fogDensity);
87 glFogf(GL_FOG_END, fogDensity);
88 printf("Fog density = %.4f\n", fogDensity);
97 /* Handle "special" keyboard events */
98 void GLUTspecialkey(unsigned char k, int x, int y) {
99 struct control_params *c;
101 c = ¤t_aircraft.controls;
103 printf("Special key hit = %d\n", k);
113 fgAileronMove(-0.01);
124 /* Revision 1.7 1997/05/31 19:16:25 curt
125 /* Elevator trim added.
127 * Revision 1.6 1997/05/31 04:13:52 curt
130 * Continuing work on the LaRCsim flight model integration.
131 * Added some MSFS-like keyboard input handling.
133 * Revision 1.5 1997/05/30 23:26:19 curt
134 * Added elevator/aileron controls.
136 * Revision 1.4 1997/05/27 17:44:31 curt
137 * Renamed & rearranged variables and routines. Added some initial simple
138 * timer/alarm routines so the flight model can be updated on a regular interval.
140 * Revision 1.3 1997/05/23 15:40:25 curt
141 * Added GNU copyright headers.
144 * Revision 1.2 1997/05/23 00:35:12 curt
145 * Trying to get fog to work ...
147 * Revision 1.1 1997/05/21 15:57:50 curt
148 * Renamed due to added GLUT support.
150 * Revision 1.2 1997/05/19 18:22:41 curt
151 * Parameter tweaking ... starting to stub in fog support.
153 * Revision 1.1 1997/05/16 16:05:51 curt