diff options
author | elias <[email protected]> | 2006-06-23 10:48:04 +0000 |
---|---|---|
committer | elias <[email protected]> | 2006-06-23 10:48:04 +0000 |
commit | 470d213d37b2cca9cb4979a076ce01a4881835d9 (patch) | |
tree | 4a680b3beb1d512b417ce5319a5885c810d7fca2 /coreAPI/src | |
parent | 0e5a7b37d92b849cc392e6bb29876553619f5538 (diff) |
Added ControllerEventTest for testing event queueing
git-svn-id: file:///home/sven/projects/JOGL/git-svn/svn-server-sync/jinput/trunk@143 e343933a-64c8-49c5-92b1-88f2ce3e89e8
Diffstat (limited to 'coreAPI/src')
-rw-r--r-- | coreAPI/src/java/net/java/games/input/test/ControllerEventTest.java | 300 | ||||
-rw-r--r-- | coreAPI/src/java/net/java/games/input/test/ControllerReadTest.java | 483 |
2 files changed, 539 insertions, 244 deletions
diff --git a/coreAPI/src/java/net/java/games/input/test/ControllerEventTest.java b/coreAPI/src/java/net/java/games/input/test/ControllerEventTest.java new file mode 100644 index 0000000..77330e7 --- /dev/null +++ b/coreAPI/src/java/net/java/games/input/test/ControllerEventTest.java @@ -0,0 +1,300 @@ +/***************************************************************************** + * Copyright (c) 2003 Sun Microsystems, Inc. All Rights Reserved. + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * + * - Redistribution of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * + * - Redistribution in binary form must reproduce the above copyright notice, + * this list of conditions and the following disclaimer in the documentation + * and/or other materails provided with the distribution. + * + * Neither the name Sun Microsystems, Inc. or the names of the contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * This software is provided "AS IS," without a warranty of any kind. + * ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING + * ANY IMPLIED WARRANT OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR + * NON-INFRINGEMEN, ARE HEREBY EXCLUDED. SUN MICROSYSTEMS, INC. ("SUN") AND + * ITS LICENSORS SHALL NOT BE LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE AS + * A RESULT OF USING, MODIFYING OR DESTRIBUTING THIS SOFTWARE OR ITS + * DERIVATIVES. IN NO EVENT WILL SUN OR ITS LICENSORS BE LIABLE FOR ANY LOST + * REVENUE, PROFIT OR DATA, OR FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL, + * INCIDENTAL OR PUNITIVE DAMAGES. HOWEVER CAUSED AND REGARDLESS OF THE THEORY + * OF LIABILITY, ARISING OUT OF THE USE OF OUR INABILITY TO USE THIS SOFTWARE, + * EVEN IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. + * + * You acknowledge that this software is not designed or intended for us in + * the design, construction, operation or maintenance of any nuclear facility + * + *****************************************************************************/ +package net.java.games.input.test; + +import java.awt.BorderLayout; +import java.awt.Color; +import java.awt.Container; +import java.awt.GridLayout; +import java.util.ArrayList; +import java.util.Iterator; +import java.util.List; +import java.util.Map; +import java.util.HashMap; + +import javax.swing.JFrame; +import javax.swing.JLabel; +import javax.swing.JPanel; +import javax.swing.JScrollPane; + +import net.java.games.input.Component; +import net.java.games.input.Controller; +import net.java.games.input.ControllerEnvironment; +import net.java.games.input.EventQueue; +import net.java.games.input.Event; + +public class ControllerEventTest extends JFrame{ + private static abstract class AxisPanel extends JPanel{ + Component axis; + float data; + + public AxisPanel(Component ax){ + axis = ax; + setLayout(new BorderLayout()); + add(new JLabel(ax.getName()+"("+ax.getIdentifier()+")"), + BorderLayout.NORTH); + } + + public void setPollData(float data){ + this.data = data; + renderData(); + } + + public Component getAxis() { + return axis; + } + + protected abstract void renderData(); + } + + private static class DigitalAxisPanel extends AxisPanel { + JLabel digitalState = new JLabel("<unread>"); + + public DigitalAxisPanel(Component ax) { + super(ax); + add(digitalState,BorderLayout.CENTER); + } + + protected void renderData(){ + if (data == 0.0f){ + digitalState.setBackground(getBackground()); + digitalState.setText("OFF"); + } else if ( data == 1.0f) { + digitalState.setBackground(Color.green); + digitalState.setText("ON"); + }else { // shoudl never happen + digitalState.setBackground(Color.red); + digitalState.setText("ERR:"+data); + } + digitalState.repaint(); + } + } + + private static class DigitalHatPanel extends AxisPanel { + JLabel digitalState = new JLabel("<unread>"); + + public DigitalHatPanel(Component ax) { + super(ax); + add(digitalState,BorderLayout.CENTER); + } + + protected void renderData(){ + if (data == Component.POV.OFF){ + digitalState.setBackground(getBackground()); + digitalState.setText("OFF"); + } else if ( data == Component.POV.UP) { + digitalState.setBackground(Color.green); + digitalState.setText("UP"); + } else if ( data == Component.POV.UP_RIGHT) { + digitalState.setBackground(Color.green); + digitalState.setText("UP+RIGHT"); + } else if ( data == Component.POV.RIGHT) { + digitalState.setBackground(Color.green); + digitalState.setText("RIGHT"); + } else if ( data == Component.POV.DOWN_RIGHT) { + digitalState.setBackground(Color.green); + digitalState.setText("DOWN+RIGHT"); + } else if ( data == Component.POV.DOWN) { + digitalState.setBackground(Color.green); + digitalState.setText("DOWN"); + } else if ( data == Component.POV.DOWN_LEFT) { + digitalState.setBackground(Color.green); + digitalState.setText("DOWN+LEFT"); + } else if ( data == Component.POV.LEFT) { + digitalState.setBackground(Color.green); + digitalState.setText("LEFT"); + } else if ( data == Component.POV.UP_LEFT) { + digitalState.setBackground(Color.green); + digitalState.setText("UP+LEFT"); + }else { // shoudl never happen + digitalState.setBackground(Color.red); + digitalState.setText("ERR:"+data); + } + digitalState.repaint(); + } + } + private static class AnalogAxisPanel extends AxisPanel { + JLabel analogState = new JLabel("<unread>"); + + public AnalogAxisPanel(Component ax) { + super(ax); + add(analogState,BorderLayout.CENTER); + } + + protected void renderData(){ + String extra = ""; + if (getAxis().getDeadZone() >= Math.abs(data)) + extra = " (DEADZONE)"; + analogState.setText(""+data+extra); + analogState.repaint(); + } + } + + + + private static class ControllerWindow extends JFrame { + Controller ca; + Map axes_to_panels = new HashMap(); + boolean disabled = false; + + public ControllerWindow(JFrame frame,Controller ca){ + super(ca.getName()); + this.setName(ca.getName()); + this.ca = ca; + Container c = this.getContentPane(); + c.setLayout(new BorderLayout()); + Component[] components = ca.getComponents(); + System.out.println("Component count = "+components.length); + if (components.length>0) { + int width = (int)Math.ceil(Math.sqrt(components.length)); + JPanel p = new JPanel(); + p.setLayout(new GridLayout(width,0)); + for(int j=0;j<components.length;j++){ + addAxis(p,components[j]); + } + c.add(new JScrollPane(p),BorderLayout.CENTER); + } + setSize(400,400); + setLocation(50,50); + setVisible(true); + } + + public boolean disabled() { + return disabled; + } + + private void setDisabled(boolean b){ + disabled = b; + if (!disabled){ + this.setTitle(ca.getName()); + System.out.println(ca.getName()+" enabled"); + } else { + this.setTitle(ca.getName()+" DISABLED!"); + System.out.println(ca.getName()+" disabled"); + } + repaint(); + } + + private void addAxis(JPanel p, Component ax){ + JPanel p2; + if (ax.isAnalog()) { + p2 = new AnalogAxisPanel(ax); + } else { + if (ax.getIdentifier() == Component.Identifier.Axis.POV) { + p2 = new DigitalHatPanel(ax); + } else { + p2 = new DigitalAxisPanel(ax); + } + } + p.add(p2); + axes_to_panels.put(ax, p2); + } + + public void poll(){ + if (!ca.poll()) { + if (!disabled()){ + setDisabled(true); + } + return; + } + if (disabled()){ + setDisabled(false); + } + EventQueue event_queue = ca.getEventQueue(); + Event event = new Event(); + while (event_queue.getNextEvent(event)) { + AxisPanel panel = (AxisPanel)axes_to_panels.get(event.getComponent()); + panel.setPollData(event.getValue()); + } + } + } + + static final long HEARTBEATMS =100; // 10th of a second + List controllers = new ArrayList(); + + public ControllerEventTest() { + super("Controller Event Test"); + ControllerEnvironment ce = ControllerEnvironment.getDefaultEnvironment(); + Controller[] ca = ce.getControllers(); + for(int i =0;i<ca.length;i++){ + makeController(ca[i]); + } + + new Thread(new Runnable() { + public void run(){ + try { + while(true){ + for(Iterator i=controllers.iterator();i.hasNext();){ + try { + ControllerWindow cw = (ControllerWindow)i.next(); + cw.poll(); + } catch (Exception e) { + e.printStackTrace(); + } + } + Thread.sleep(HEARTBEATMS); + } + } catch (Exception e) { + e.printStackTrace(); + } + } + }).start(); + pack(); + setSize(400,400); + setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + setVisible(true); + } + + private void makeController(Controller c) { + Controller[] subControllers = c.getControllers(); + if (subControllers.length == 0 ) { + createControllerWindow(c); + } else { + for(int i=0;i<subControllers.length;i++){ + makeController(subControllers[i]); + } + } + } + + private void createControllerWindow(Controller c){ + controllers.add(new ControllerWindow(this,c)); + } + + /** + * @param args the command line arguments + */ + public static void main(String[] args) { + new ControllerEventTest().setVisible(true); + } + +} diff --git a/coreAPI/src/java/net/java/games/input/test/ControllerReadTest.java b/coreAPI/src/java/net/java/games/input/test/ControllerReadTest.java index a7c0e84..ac295b1 100644 --- a/coreAPI/src/java/net/java/games/input/test/ControllerReadTest.java +++ b/coreAPI/src/java/net/java/games/input/test/ControllerReadTest.java @@ -37,11 +37,6 @@ *****************************************************************************/ package net.java.games.input.test; -/** - * - * @author administrator - */ - import java.awt.BorderLayout; import java.awt.Color; import java.awt.Container; @@ -59,251 +54,251 @@ import net.java.games.input.Component; import net.java.games.input.Controller; import net.java.games.input.ControllerEnvironment; -abstract class AxisPanel extends JPanel{ - Component axis; - float data; - - public AxisPanel(Component ax){ - axis = ax; - setLayout(new BorderLayout()); - add(new JLabel(ax.getName()+"("+ax.getIdentifier()+")"), - BorderLayout.NORTH); - } - - public void poll(){ - data = axis.getPollData(); - renderData(); - } +public class ControllerReadTest extends JFrame{ + private abstract static class AxisPanel extends JPanel{ + Component axis; + float data; + + public AxisPanel(Component ax){ + axis = ax; + setLayout(new BorderLayout()); + add(new JLabel(ax.getName()+"("+ax.getIdentifier()+")"), + BorderLayout.NORTH); + } - public Component getAxis() { - return axis; + public void poll(){ + data = axis.getPollData(); + renderData(); + } + + public Component getAxis() { + return axis; + } + + protected abstract void renderData(); } - - protected abstract void renderData(); -} -class DigitalAxisPanel extends AxisPanel { - JLabel digitalState = new JLabel("<unread>"); - - public DigitalAxisPanel(Component ax) { - super(ax); - add(digitalState,BorderLayout.CENTER); - } - - protected void renderData(){ - if (data == 0.0f){ - digitalState.setBackground(getBackground()); - digitalState.setText("OFF"); - } else if ( data == 1.0f) { - digitalState.setBackground(Color.green); - digitalState.setText("ON"); - }else { // shoudl never happen - digitalState.setBackground(Color.red); - digitalState.setText("ERR:"+data); - } - digitalState.repaint(); - } -} + private static class DigitalAxisPanel extends AxisPanel { + JLabel digitalState = new JLabel("<unread>"); -class DigitalHatPanel extends AxisPanel { - JLabel digitalState = new JLabel("<unread>"); - - public DigitalHatPanel(Component ax) { - super(ax); - add(digitalState,BorderLayout.CENTER); - } - - protected void renderData(){ - if (data == Component.POV.OFF){ - digitalState.setBackground(getBackground()); - digitalState.setText("OFF"); - } else if ( data == Component.POV.UP) { - digitalState.setBackground(Color.green); - digitalState.setText("UP"); - } else if ( data == Component.POV.UP_RIGHT) { - digitalState.setBackground(Color.green); - digitalState.setText("UP+RIGHT"); - } else if ( data == Component.POV.RIGHT) { - digitalState.setBackground(Color.green); - digitalState.setText("RIGHT"); - } else if ( data == Component.POV.DOWN_RIGHT) { - digitalState.setBackground(Color.green); - digitalState.setText("DOWN+RIGHT"); - } else if ( data == Component.POV.DOWN) { - digitalState.setBackground(Color.green); - digitalState.setText("DOWN"); - } else if ( data == Component.POV.DOWN_LEFT) { - digitalState.setBackground(Color.green); - digitalState.setText("DOWN+LEFT"); - } else if ( data == Component.POV.LEFT) { - digitalState.setBackground(Color.green); - digitalState.setText("LEFT"); - } else if ( data == Component.POV.UP_LEFT) { - digitalState.setBackground(Color.green); - digitalState.setText("UP+LEFT"); - }else { // shoudl never happen - digitalState.setBackground(Color.red); - digitalState.setText("ERR:"+data); - } - digitalState.repaint(); - } -} -class AnalogAxisPanel extends AxisPanel { - JLabel analogState = new JLabel("<unread>"); - - public AnalogAxisPanel(Component ax) { - super(ax); - add(analogState,BorderLayout.CENTER); - } - - protected void renderData(){ - String extra = ""; - if (getAxis().getDeadZone() >= Math.abs(data)) - extra = " (DEADZONE)"; - analogState.setText(""+data+extra); - analogState.repaint(); - } -} + public DigitalAxisPanel(Component ax) { + super(ax); + add(digitalState,BorderLayout.CENTER); + } + protected void renderData(){ + if (data == 0.0f){ + digitalState.setBackground(getBackground()); + digitalState.setText("OFF"); + } else if ( data == 1.0f) { + digitalState.setBackground(Color.green); + digitalState.setText("ON"); + }else { // shoudl never happen + digitalState.setBackground(Color.red); + digitalState.setText("ERR:"+data); + } + digitalState.repaint(); + } + } + private static class DigitalHatPanel extends AxisPanel { + JLabel digitalState = new JLabel("<unread>"); -class ControllerWindow extends JFrame { - Controller ca; - List axisList = new ArrayList(); - boolean disabled = false; - - public ControllerWindow(JFrame frame,Controller ca){ - super(ca.getName()); - this.setName(ca.getName()); - this.ca = ca; - Container c = this.getContentPane(); - c.setLayout(new BorderLayout()); - Component[] components = ca.getComponents(); - System.out.println("Component count = "+components.length); - if (components.length>0) { - int width = (int)Math.ceil(Math.sqrt(components.length)); - JPanel p = new JPanel(); - p.setLayout(new GridLayout(width,0)); - for(int j=0;j<components.length;j++){ - addAxis(p,components[j]); - } - c.add(new JScrollPane(p),BorderLayout.CENTER); - } - setSize(400,400); - setLocation(50,50); - setVisible(true); - } - - public boolean disabled() { - return disabled; - } - - private void setDisabled(boolean b){ - disabled = b; - if (!disabled){ - this.setTitle(ca.getName()); - System.out.println(ca.getName()+" enabled"); - } else { - this.setTitle(ca.getName()+" DISABLED!"); - System.out.println(ca.getName()+" disabled"); - } - repaint(); - } - - private void addAxis(JPanel p, Component ax){ - JPanel p2; - if (ax.isAnalog()) { - p2 = new AnalogAxisPanel(ax); - } else { - if (ax.getIdentifier() == Component.Identifier.Axis.POV) { - p2 = new DigitalHatPanel(ax); - } else { - p2 = new DigitalAxisPanel(ax); - } - } - p.add(p2); - axisList.add(p2); - //ax.setPolling(true); - } - - public void poll(){ - if (!ca.poll()) { - if (!disabled()){ - setDisabled(true); - } - return; - } - if (disabled()){ - setDisabled(false); - } - //System.out.println("Polled "+ca.getName()); - for(Iterator i =axisList.iterator();i.hasNext();){ - try { - ((AxisPanel)i.next()).poll(); - }catch (Exception e) { - e.printStackTrace(); - } - } - } -} + public DigitalHatPanel(Component ax) { + super(ax); + add(digitalState,BorderLayout.CENTER); + } + + protected void renderData(){ + if (data == Component.POV.OFF){ + digitalState.setBackground(getBackground()); + digitalState.setText("OFF"); + } else if ( data == Component.POV.UP) { + digitalState.setBackground(Color.green); + digitalState.setText("UP"); + } else if ( data == Component.POV.UP_RIGHT) { + digitalState.setBackground(Color.green); + digitalState.setText("UP+RIGHT"); + } else if ( data == Component.POV.RIGHT) { + digitalState.setBackground(Color.green); + digitalState.setText("RIGHT"); + } else if ( data == Component.POV.DOWN_RIGHT) { + digitalState.setBackground(Color.green); + digitalState.setText("DOWN+RIGHT"); + } else if ( data == Component.POV.DOWN) { + digitalState.setBackground(Color.green); + digitalState.setText("DOWN"); + } else if ( data == Component.POV.DOWN_LEFT) { + digitalState.setBackground(Color.green); + digitalState.setText("DOWN+LEFT"); + } else if ( data == Component.POV.LEFT) { + digitalState.setBackground(Color.green); + digitalState.setText("LEFT"); + } else if ( data == Component.POV.UP_LEFT) { + digitalState.setBackground(Color.green); + digitalState.setText("UP+LEFT"); + }else { // shoudl never happen + digitalState.setBackground(Color.red); + digitalState.setText("ERR:"+data); + } + digitalState.repaint(); + } + } + private static class AnalogAxisPanel extends AxisPanel { + JLabel analogState = new JLabel("<unread>"); + + public AnalogAxisPanel(Component ax) { + super(ax); + add(analogState,BorderLayout.CENTER); + } + + protected void renderData(){ + String extra = ""; + if (getAxis().getDeadZone() >= Math.abs(data)) + extra = " (DEADZONE)"; + analogState.setText(""+data+extra); + analogState.repaint(); + } + } + + + + private static class ControllerWindow extends JFrame { + Controller ca; + List axisList = new ArrayList(); + boolean disabled = false; + + public ControllerWindow(JFrame frame,Controller ca){ + super(ca.getName()); + this.setName(ca.getName()); + this.ca = ca; + Container c = this.getContentPane(); + c.setLayout(new BorderLayout()); + Component[] components = ca.getComponents(); + System.out.println("Component count = "+components.length); + if (components.length>0) { + int width = (int)Math.ceil(Math.sqrt(components.length)); + JPanel p = new JPanel(); + p.setLayout(new GridLayout(width,0)); + for(int j=0;j<components.length;j++){ + addAxis(p,components[j]); + } + c.add(new JScrollPane(p),BorderLayout.CENTER); + } + setSize(400,400); + setLocation(50,50); + setVisible(true); + } + + public boolean disabled() { + return disabled; + } + + private void setDisabled(boolean b){ + disabled = b; + if (!disabled){ + this.setTitle(ca.getName()); + System.out.println(ca.getName()+" enabled"); + } else { + this.setTitle(ca.getName()+" DISABLED!"); + System.out.println(ca.getName()+" disabled"); + } + repaint(); + } + + private void addAxis(JPanel p, Component ax){ + JPanel p2; + if (ax.isAnalog()) { + p2 = new AnalogAxisPanel(ax); + } else { + if (ax.getIdentifier() == Component.Identifier.Axis.POV) { + p2 = new DigitalHatPanel(ax); + } else { + p2 = new DigitalAxisPanel(ax); + } + } + p.add(p2); + axisList.add(p2); + //ax.setPolling(true); + } + + public void poll(){ + if (!ca.poll()) { + if (!disabled()){ + setDisabled(true); + } + return; + } + if (disabled()){ + setDisabled(false); + } + //System.out.println("Polled "+ca.getName()); + for(Iterator i =axisList.iterator();i.hasNext();){ + try { + ((AxisPanel)i.next()).poll(); + }catch (Exception e) { + e.printStackTrace(); + } + } + } + } + + static final long HEARTBEATMS =100; // 10th of a second + List controllers = new ArrayList(); + + public ControllerReadTest() { + super("Controller Read Test"); + ControllerEnvironment ce = ControllerEnvironment.getDefaultEnvironment(); + Controller[] ca = ce.getControllers(); + for(int i =0;i<ca.length;i++){ + makeController(ca[i]); + } + + new Thread(new Runnable() { + public void run(){ + try { + while(true){ + for(Iterator i=controllers.iterator();i.hasNext();){ + try { + ControllerWindow cw = (ControllerWindow)i.next(); + cw.poll(); + } catch (Exception e) { + e.printStackTrace(); + } + } + Thread.sleep(HEARTBEATMS); + } + } catch (Exception e) { + e.printStackTrace(); + } + } + }).start(); + pack(); + setSize(400,400); + setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + setVisible(true); + } + + private void makeController(Controller c) { + Controller[] subControllers = c.getControllers(); + if (subControllers.length == 0 ) { + createControllerWindow(c); + } else { + for(int i=0;i<subControllers.length;i++){ + makeController(subControllers[i]); + } + } + } + + private void createControllerWindow(Controller c){ + controllers.add(new ControllerWindow(this,c)); + } + + /** + * @param args the command line arguments + */ + public static void main(String[] args) { + new ControllerReadTest().setVisible(true); + } -public class ControllerReadTest extends JFrame{ - static final long HEARTBEATMS =100; // 10th of a second - List controllers = new ArrayList(); - /** Creates a new instance of ConrtollerReadTest */ - public ControllerReadTest() { - super("Controller Read Test"); - ControllerEnvironment ce = ControllerEnvironment.getDefaultEnvironment(); - Controller[] ca = ce.getControllers(); - for(int i =0;i<ca.length;i++){ - makeController(ca[i]); - } - - new Thread(new Runnable() { - public void run(){ - try { - while(true){ - for(Iterator i=controllers.iterator();i.hasNext();){ - try { - ControllerWindow cw = (ControllerWindow)i.next(); - cw.poll(); - } catch (Exception e) { - e.printStackTrace(); - } - } - Thread.sleep(HEARTBEATMS); - } - } catch (Exception e) { - e.printStackTrace(); - } - } - }).start(); - pack(); - setSize(400,400); - setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); - setVisible(true); - } - - private void makeController(Controller c) { - Controller[] subControllers = c.getControllers(); - if (subControllers.length == 0 ) { - createControllerWindow(c); - } else { - for(int i=0;i<subControllers.length;i++){ - makeController(subControllers[i]); - } - } - } - - private void createControllerWindow(Controller c){ - controllers.add(new ControllerWindow(this,c)); - } - - /** - * @param args the command line arguments - */ - public static void main(String[] args) { - new ControllerReadTest().setVisible(true); - } - } |