diff --git a/src/app/App.java b/src/app/App.java index c509962..8de6d69 100644 --- a/src/app/App.java +++ b/src/app/App.java @@ -24,7 +24,8 @@ public class App public void parseArguments(){ if(this.leftColor!=null || this.rightColor!=null || this.middleColor!=null){ try { - DriverTypeA device=new Device_1770_ff00(); + DriverTypeA device=new Driver_1770_ff00(); + if(this.leftColor==null) this.leftColor="OFF"; if(this.middleColor==null) @@ -35,7 +36,7 @@ public class App device.setRegionColor(Region.MIDDLE, Color.valueOf(middleColor), Intensity.HIGH); device.setRegionColor(Region.RIGHT, Color.valueOf(rightColor), Intensity.HIGH); - } catch (InstantiationException e) { + } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } @@ -51,6 +52,6 @@ public class App parser.parseArgument(args); app.parseArguments(); new MainWindow(); - + } } diff --git a/src/client/MainWindow.java b/src/client/MainWindow.java index b60b9ec..1f24f64 100644 --- a/src/client/MainWindow.java +++ b/src/client/MainWindow.java @@ -23,16 +23,26 @@ public class MainWindow extends JFrame { private JComboBox right; private JButton apply=new JButton("Apply"); - private DriverTypeA keyboard; + private DriverTypeA keyboardTypeA; + private Class driverType; + private DriverManager drvMan=new DriverManager(); public MainWindow() throws InstantiationException{ this.initUI(); - this.keyboard=new Device_1770_ff00(); + Driver drv=drvMan.getDevice(); + if(drv==null){ + System.err.println("No driver avalaible (try as root)"); + System.exit(1); + } + else{ + this.driverType=drv.getType(); + this.keyboardTypeA=(DriverTypeA) drv; + } + this.left=new JComboBox<>(Color.values()); this.middle=new JComboBox<>(Color.values()); this.right=new JComboBox<>(Color.values()); - this.apply.addActionListener(new ActionListener() { @Override @@ -41,9 +51,9 @@ public class MainWindow extends JFrame { Color middleRegion=(Color) middle.getSelectedItem(); Color rightRegion=(Color) right.getSelectedItem(); - keyboard.setRegionColor(Region.LEFT, leftRegion, Intensity.HIGH); - keyboard.setRegionColor(Region.MIDDLE, middleRegion, Intensity.HIGH); - keyboard.setRegionColor(Region.RIGHT, rightRegion, Intensity.HIGH); + keyboardTypeA.setRegionColor(Region.LEFT, leftRegion, Intensity.HIGH); + keyboardTypeA.setRegionColor(Region.MIDDLE, middleRegion, Intensity.HIGH); + keyboardTypeA.setRegionColor(Region.RIGHT, rightRegion, Intensity.HIGH); } diff --git a/src/drivers/Driver.java b/src/drivers/Driver.java new file mode 100644 index 0000000..d362d19 --- /dev/null +++ b/src/drivers/Driver.java @@ -0,0 +1,25 @@ +package org.manzerbredes.open_klm.drivers; + + +/** + * Driver must implement this interface + * + * @author Manzerbredes + * + */ +public interface Driver{ + + /** + * Get the type of the driver + * + * @return class that represent the type of the driver (DriverTypeA.class for example) + */ + public Class getType(); + + /** + * Initialise the driver (do not initialise anything in the constructor). + * + * @return true if success (device is present and accessible) false else. + */ + public boolean initDriver(); +} \ No newline at end of file diff --git a/src/drivers/DriverManager.java b/src/drivers/DriverManager.java new file mode 100644 index 0000000..9a3c37c --- /dev/null +++ b/src/drivers/DriverManager.java @@ -0,0 +1,48 @@ +package org.manzerbredes.open_klm.drivers; + + +/** + * Driver Manager + * + * @author Manzerbredes + * + */ +public class DriverManager{ + + /** + * List of avalaible drivers + */ + private Class[] drivers={ + Driver_1770_ff00.class + }; + + + + /** + * Get a successfully loaded driver + * + * @return Driver the loaded driver. + */ + public Driver getDevice(){ + // Walk on driver list + for(int i=0;i getType() { + return DriverTypeA.class; + } + + + + + } \ No newline at end of file