Thread aangemaakt voor het updaten van features en pollen van events. Misschien moet het hele Device een Thread worden?

This commit is contained in:
Bram Veenboer
2011-02-05 22:10:39 +00:00
parent 792c430ad0
commit 9048c76afe
4 changed files with 49 additions and 31 deletions

View File

@@ -50,7 +50,7 @@ public class Main extends Target {
}
public void start() throws Exception {
addDevice(new ExampleDevice());
//addDevice(new ExampleDevice());
addDevice(new RumblepadDevice());
Application application = new VoorbeeldApplication();
@@ -67,6 +67,7 @@ public class Main extends Target {
public void run() throws ActionException, EventException {
run = true;
while (run) {
//System.out.println("Print!");
if (actionQueue.isEmpty()) {
try {
Thread.sleep(SLEEP);

View File

@@ -3,12 +3,15 @@ package pm.application.voorbeeld;
import pm.application.Application;
public class VoorbeeldApplication extends Application {
public void start() throws Exception {
System.out.println("jeheee!");
//throw new Exception("GEK");
public void start() {
System.out.println("start");
}
public void stop() {
System.out.println("stop");
}
public void test() {
System.out.println("neheee!");
System.out.println("test");
}
}

View File

@@ -13,6 +13,8 @@ import de.hardcode.jxinput.event.JXInputButtonEvent;
import de.hardcode.jxinput.event.JXInputDirectionalEvent;
import de.hardcode.jxinput.event.JXInputEventManager;
import pm.action.Action;
import pm.event.Target;
import pm.exception.ServiceJavaInputDeviceNotFoundException;
import pm.exception.ServiceJavaInputException;
@@ -56,38 +58,50 @@ public abstract class JavaInputDevice extends Device {
public void start() {
startListeners();
while (run) {
boolean sleep = true;
if (!axisEventQueue.isEmpty()) {
processEvent(axisEventQueue.poll());
sleep = false;
startUpdateThread();
}
protected void startUpdateThread() {
new Thread() {
public void run() {
while (run) {
JXInputManager.updateFeatures();
boolean sleep = true;
if (!axisEventQueue.isEmpty()) {
processEvent(axisEventQueue.poll());
sleep = false;
}
if (!buttonEventQueue.isEmpty()) {
processEvent(buttonEventQueue.poll());
sleep = false;
}
if (!directionalEventQueue.isEmpty()) {
processEvent(directionalEventQueue.poll());
sleep = false;
}
if (sleep) {
try {
Thread.sleep(SLEEP);
} catch (InterruptedException e) {}
}
}
}
if (!buttonEventQueue.isEmpty()) {
processEvent(buttonEventQueue.poll());
sleep = false;
}
if (!directionalEventQueue.isEmpty()) {
processEvent(directionalEventQueue.poll());
sleep = false;
}
if (sleep) {
try {
Thread.sleep(SLEEP);
} catch (InterruptedException e) {}
}
}
}.start();
}
protected void processEvent(JXInputAxisEvent event) {
addAction(Action.START, Target.APPLICATION);
//System.out.println(event);
}
protected void processEvent(JXInputButtonEvent event) {
System.out.println(event);
addAction(Action.TEST, Target.APPLICATION);
//System.out.println(event);
}
protected void processEvent(JXInputDirectionalEvent event) {
addAction(Action.EXIT, Target.APPLICATION);
//System.out.println(event);
}
protected void startListeners() {

View File

@@ -6,10 +6,10 @@ import pm.event.Target;
public class ExampleDevice extends Device {
public void start() {
System.out.println("Ik hoef niets te starten");
addAction(Action.START, Target.APPLICATION);
addAction(Action.TEST, Target.APPLICATION);
addAction(Action.EXIT, Target.MAIN);
//System.out.println("Ik hoef niets te starten");
//addAction(Action.START, Target.APPLICATION);
//addAction(Action.TEST, Target.APPLICATION);
//addAction(Action.EXIT, Target.MAIN);
}
public void exit() {