aboutsummaryrefslogtreecommitdiffstats
path: root/src/jake2/sys/IN.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/jake2/sys/IN.java')
-rw-r--r--src/jake2/sys/IN.java386
1 files changed, 207 insertions, 179 deletions
diff --git a/src/jake2/sys/IN.java b/src/jake2/sys/IN.java
index 6f74ab4..2c70d53 100644
--- a/src/jake2/sys/IN.java
+++ b/src/jake2/sys/IN.java
@@ -2,27 +2,27 @@
* IN.java
* Copyright (C) 2003
*
- * $Id: IN.java,v 1.4 2004-09-08 09:37:39 hzi Exp $
+ * $Id: IN.java,v 1.5 2004-09-22 19:22:14 salomo Exp $
*/
/*
-Copyright (C) 1997-2001 Id Software, Inc.
+ Copyright (C) 1997-2001 Id Software, Inc.
-This program is free software; you can redistribute it and/or
-modify it under the terms of the GNU General Public License
-as published by the Free Software Foundation; either version 2
-of the License, or (at your option) any later version.
+ This program is free software; you can redistribute it and/or
+ modify it under the terms of the GNU General Public License
+ as published by the Free Software Foundation; either version 2
+ of the License, or (at your option) any later version.
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
-See the GNU General Public License for more details.
+ See the GNU General Public License for more details.
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-*/
+ */
package jake2.sys;
import jake2.Globals;
@@ -32,8 +32,11 @@ import jake2.game.Cmd;
import jake2.game.usercmd_t;
import jake2.qcommon.Cvar;
import jake2.qcommon.xcommand_t;
+import jake2.util.Math3D;
-import java.awt.*;
+import java.awt.Component;
+import java.awt.Cursor;
+import java.awt.Point;
import javax.swing.ImageIcon;
@@ -42,167 +45,192 @@ import javax.swing.ImageIcon;
*/
public final class IN extends Globals {
- static Component c = null;
- static Cursor emptyCursor = null;
-
- static boolean mouse_avail = true;
- static boolean mouse_active = false;
- static boolean ignorefirst = false;
-
- static int mouse_buttonstate;
- static int mouse_oldbuttonstate;
-
- static int old_mouse_x;
- static int old_mouse_y;
-
- static boolean mlooking;
-
- public static void ActivateMouse() {
- if (!mouse_avail || c == null) return;
- if (!mouse_active) {
- KBD.mx = KBD.my = 0; // don't spazz
- install_grabs();
- mouse_active = true;
- }
- }
-
- public static void DeactivateMouse() {
- // if (!mouse_avail || c == null) return;
- if (mouse_active) {
- uninstall_grabs();
- mouse_active = false;
- }
- }
-
- private static void install_grabs() {
- if (emptyCursor == null) {
- ImageIcon emptyIcon = new ImageIcon(new byte[0]);
- emptyCursor = c.getToolkit().createCustomCursor(emptyIcon.getImage(), new Point(0, 0), "emptyCursor");
- }
- c.setCursor(emptyCursor);
- KBD.centerMouse();
-
- ignorefirst = true;
- }
-
- private static void uninstall_grabs() {
- c.setCursor(Cursor.getPredefinedCursor(Cursor.DEFAULT_CURSOR));
- }
-
- public static void toggleMouse() {
- if (mouse_avail) {
- mouse_avail=false;
- DeactivateMouse();
- } else {
- mouse_avail=true;
- ActivateMouse();
- }
- }
-
- public static void Init() {
- in_mouse = Cvar.Get("in_mouse", "1", CVAR_ARCHIVE);
- in_joystick = Cvar.Get("in_joystick", "0", CVAR_ARCHIVE);
- }
-
- public static void Shutdown() {
- mouse_avail = false;
- }
-
- public static void Real_IN_Init() {
- // mouse variables
- Globals.m_filter = Cvar.Get("m_filter", "0", 0);
- Globals.in_mouse = Cvar.Get("in_mouse", "1", CVAR_ARCHIVE);
- Globals.freelook = Cvar.Get("freelook", "1", 0 );
- Globals.lookstrafe = Cvar.Get("lookstrafe", "0", 0);
- Globals.sensitivity = Cvar.Get("sensitivity", "3", 0);
- Globals.m_pitch = Cvar.Get("m_pitch", "0.022", 0);
- Globals.m_yaw = Cvar.Get("m_yaw", "0.022", 0);
- Globals.m_forward = Cvar.Get("m_forward", "1", 0);
- Globals.m_side = Cvar.Get("m_side", "0.8", 0);
-
- Cmd.AddCommand("+mlook", new xcommand_t() {
- public void execute() {MLookDown();}});
- Cmd.AddCommand("-mlook", new xcommand_t() {
- public void execute() {MLookUp();}});
-
- Cmd.AddCommand ("force_centerview", new xcommand_t() {
- public void execute() {Force_CenterView_f();}});
-
- Cmd.AddCommand ("togglemouse", new xcommand_t() {
- public void execute() {toggleMouse();}});
-
- IN.mouse_avail = true;
- }
-
- public static void Commands() {
- int i;
-
- if (!IN.mouse_avail)
- return;
-
- for (i=0 ; i<3 ; i++) {
- if ( (IN.mouse_buttonstate & (1<<i)) != 0 && (IN.mouse_oldbuttonstate & (1<<i)) == 0 )
- KBD.Do_Key_Event(Key.K_MOUSE1 + i, true);
-
- if ( (IN.mouse_buttonstate & (1<<i)) == 0 && (IN.mouse_oldbuttonstate & (1<<i)) != 0 )
- KBD.Do_Key_Event(Key.K_MOUSE1 + i, false);
- }
- IN.mouse_oldbuttonstate = IN.mouse_buttonstate;
- }
-
- public static void Frame() {
-
- if ( !cl.refresh_prepped || cls.key_dest == key_console || cls.key_dest == key_menu)
- DeactivateMouse();
- else
- ActivateMouse();
- }
-
- public static void CenterView() {
- cl.viewangles[PITCH] = -SHORT2ANGLE(cl.frame.playerstate.pmove.delta_angles[PITCH]);
- }
-
- public static void Move(usercmd_t cmd) {
- if (!IN.mouse_avail)
- return;
-
- if (Globals.m_filter.value != 0.0f) {
- KBD.mx = (KBD.mx + IN.old_mouse_x) / 2;
- KBD.my = (KBD.my + IN.old_mouse_y) / 2;
- }
-
- IN.old_mouse_x = KBD.mx;
- IN.old_mouse_y = KBD.my;
-
- KBD.mx = (int)(KBD.mx * Globals.sensitivity.value);
- KBD.my = (int)(KBD.my * Globals.sensitivity.value);
-
- // add mouse X/Y movement to cmd
- if ( (CL_input.in_strafe.state & 1) != 0 || ((Globals.lookstrafe.value != 0) && IN.mlooking )) {
- cmd.sidemove += Globals.m_side.value * KBD.mx;
- } else {
- Globals.cl.viewangles[YAW] -= Globals.m_yaw.value * KBD.mx;
- }
-
- if ( (IN.mlooking || Globals.freelook.value != 0.0f) && (CL_input.in_strafe.state & 1) == 0) {
- Globals.cl.viewangles[PITCH] += Globals.m_pitch.value * KBD.my;
- } else {
- cmd.forwardmove -= Globals.m_forward.value * KBD.my;
- }
- KBD.mx = KBD.my = 0;
- }
-
- static void MLookDown() {
- mlooking = true;
- }
-
- static void MLookUp() {
- mlooking = false;
- CenterView();
- }
-
- static void Force_CenterView_f() {
- Globals.cl.viewangles[PITCH] = 0;
- }
-
-}
+ static Component c = null;
+
+ static Cursor emptyCursor = null;
+
+ static boolean mouse_avail = true;
+
+ static boolean mouse_active = false;
+
+ static boolean ignorefirst = false;
+
+ static int mouse_buttonstate;
+
+ static int mouse_oldbuttonstate;
+
+ static int old_mouse_x;
+
+ static int old_mouse_y;
+
+ static boolean mlooking;
+
+ public static void ActivateMouse() {
+ if (!mouse_avail || c == null)
+ return;
+ if (!mouse_active) {
+ KBD.mx = KBD.my = 0; // don't spazz
+ install_grabs();
+ mouse_active = true;
+ }
+ }
+
+ public static void DeactivateMouse() {
+ // if (!mouse_avail || c == null) return;
+ if (mouse_active) {
+ uninstall_grabs();
+ mouse_active = false;
+ }
+ }
+
+ private static void install_grabs() {
+ if (emptyCursor == null) {
+ ImageIcon emptyIcon = new ImageIcon(new byte[0]);
+ emptyCursor = c.getToolkit().createCustomCursor(
+ emptyIcon.getImage(), new Point(0, 0), "emptyCursor");
+ }
+ c.setCursor(emptyCursor);
+ KBD.centerMouse();
+
+ ignorefirst = true;
+ }
+
+ private static void uninstall_grabs() {
+ c.setCursor(Cursor.getPredefinedCursor(Cursor.DEFAULT_CURSOR));
+ }
+
+ public static void toggleMouse() {
+ if (mouse_avail) {
+ mouse_avail = false;
+ DeactivateMouse();
+ } else {
+ mouse_avail = true;
+ ActivateMouse();
+ }
+ }
+
+ public static void Init() {
+ in_mouse = Cvar.Get("in_mouse", "1", CVAR_ARCHIVE);
+ in_joystick = Cvar.Get("in_joystick", "0", CVAR_ARCHIVE);
+ }
+
+ public static void Shutdown() {
+ mouse_avail = false;
+ }
+
+ public static void Real_IN_Init() {
+ // mouse variables
+ Globals.m_filter = Cvar.Get("m_filter", "0", 0);
+ Globals.in_mouse = Cvar.Get("in_mouse", "1", CVAR_ARCHIVE);
+ Globals.freelook = Cvar.Get("freelook", "1", 0);
+ Globals.lookstrafe = Cvar.Get("lookstrafe", "0", 0);
+ Globals.sensitivity = Cvar.Get("sensitivity", "3", 0);
+ Globals.m_pitch = Cvar.Get("m_pitch", "0.022", 0);
+ Globals.m_yaw = Cvar.Get("m_yaw", "0.022", 0);
+ Globals.m_forward = Cvar.Get("m_forward", "1", 0);
+ Globals.m_side = Cvar.Get("m_side", "0.8", 0);
+
+ Cmd.AddCommand("+mlook", new xcommand_t() {
+ public void execute() {
+ MLookDown();
+ }
+ });
+ Cmd.AddCommand("-mlook", new xcommand_t() {
+ public void execute() {
+ MLookUp();
+ }
+ });
+
+ Cmd.AddCommand("force_centerview", new xcommand_t() {
+ public void execute() {
+ Force_CenterView_f();
+ }
+ });
+
+ Cmd.AddCommand("togglemouse", new xcommand_t() {
+ public void execute() {
+ toggleMouse();
+ }
+ });
+
+ IN.mouse_avail = true;
+ }
+
+ public static void Commands() {
+ int i;
+
+ if (!IN.mouse_avail)
+ return;
+
+ for (i = 0; i < 3; i++) {
+ if ((IN.mouse_buttonstate & (1 << i)) != 0
+ && (IN.mouse_oldbuttonstate & (1 << i)) == 0)
+ KBD.Do_Key_Event(Key.K_MOUSE1 + i, true);
+
+ if ((IN.mouse_buttonstate & (1 << i)) == 0
+ && (IN.mouse_oldbuttonstate & (1 << i)) != 0)
+ KBD.Do_Key_Event(Key.K_MOUSE1 + i, false);
+ }
+ IN.mouse_oldbuttonstate = IN.mouse_buttonstate;
+ }
+
+ public static void Frame() {
+
+ if (!cl.refresh_prepped || cls.key_dest == key_console
+ || cls.key_dest == key_menu)
+ DeactivateMouse();
+ else
+ ActivateMouse();
+ }
+
+ public static void CenterView() {
+ cl.viewangles[PITCH] = -Math3D
+ .SHORT2ANGLE(cl.frame.playerstate.pmove.delta_angles[PITCH]);
+ }
+
+ public static void Move(usercmd_t cmd) {
+ if (!IN.mouse_avail)
+ return;
+
+ if (Globals.m_filter.value != 0.0f) {
+ KBD.mx = (KBD.mx + IN.old_mouse_x) / 2;
+ KBD.my = (KBD.my + IN.old_mouse_y) / 2;
+ }
+
+ IN.old_mouse_x = KBD.mx;
+ IN.old_mouse_y = KBD.my;
+
+ KBD.mx = (int) (KBD.mx * Globals.sensitivity.value);
+ KBD.my = (int) (KBD.my * Globals.sensitivity.value);
+
+ // add mouse X/Y movement to cmd
+ if ((CL_input.in_strafe.state & 1) != 0
+ || ((Globals.lookstrafe.value != 0) && IN.mlooking)) {
+ cmd.sidemove += Globals.m_side.value * KBD.mx;
+ } else {
+ Globals.cl.viewangles[YAW] -= Globals.m_yaw.value * KBD.mx;
+ }
+
+ if ((IN.mlooking || Globals.freelook.value != 0.0f)
+ && (CL_input.in_strafe.state & 1) == 0) {
+ Globals.cl.viewangles[PITCH] += Globals.m_pitch.value * KBD.my;
+ } else {
+ cmd.forwardmove -= Globals.m_forward.value * KBD.my;
+ }
+ KBD.mx = KBD.my = 0;
+ }
+
+ static void MLookDown() {
+ mlooking = true;
+ }
+
+ static void MLookUp() {
+ mlooking = false;
+ CenterView();
+ }
+
+ static void Force_CenterView_f() {
+ Globals.cl.viewangles[PITCH] = 0;
+ }
+
+} \ No newline at end of file