Add driver modularity
This commit is contained in:
parent
91430fcc06
commit
6500028632
5 changed files with 256 additions and 200 deletions
|
@ -1,4 +1,4 @@
|
|||
package org.manzerbredes.client;
|
||||
package org.manzerbredes.open_klm.client;
|
||||
|
||||
import java.awt.EventQueue;
|
||||
import java.awt.GridLayout;
|
||||
|
@ -12,10 +12,9 @@ import javax.swing.JComboBox;
|
|||
import javax.swing.JFrame;
|
||||
import javax.swing.JPanel;
|
||||
|
||||
import org.manzerbredes.open_klm.device.Driver.Color;
|
||||
import org.manzerbredes.open_klm.device.Driver.Intensity;
|
||||
import org.manzerbredes.open_klm.device.Driver.Region;
|
||||
import org.manzerbredes.open_klm.device.Keyboard;
|
||||
import org.manzerbredes.open_klm.drivers.BasicDriver;
|
||||
import org.manzerbredes.open_klm.drivers.BasicDriver.*;
|
||||
import org.manzerbredes.open_klm.drivers.Device_1770_ff00;
|
||||
|
||||
public class MainWindow extends JFrame {
|
||||
|
||||
|
@ -25,11 +24,11 @@ public class MainWindow extends JFrame {
|
|||
private JComboBox<Color> right;
|
||||
private JButton apply=new JButton("Apply");
|
||||
|
||||
private Keyboard keyboard;
|
||||
private BasicDriver keyboard;
|
||||
|
||||
public MainWindow() throws InstantiationException{
|
||||
this.initUI();
|
||||
this.keyboard=new Keyboard();
|
||||
this.keyboard=new Device_1770_ff00();
|
||||
this.left=new JComboBox<>(Color.values());
|
||||
this.middle=new JComboBox<>(Color.values());
|
||||
this.right=new JComboBox<>(Color.values());
|
||||
|
|
|
@ -1,184 +0,0 @@
|
|||
package org.manzerbredes.open_klm.device;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
import com.codeminders.hidapi.HIDDevice;
|
||||
import com.codeminders.hidapi.HIDManager;
|
||||
|
||||
/**
|
||||
*
|
||||
* Driver to communicate with the keyboard device
|
||||
* using HIDAPI.
|
||||
*
|
||||
* @author Manzerbredes
|
||||
*
|
||||
*/
|
||||
public class Driver{
|
||||
|
||||
/**
|
||||
* Defined Region Helper
|
||||
*
|
||||
* @author Manzerbredes
|
||||
*
|
||||
*/
|
||||
public enum Region{
|
||||
LEFT(1), MIDDLE(2), RIGHT(3);
|
||||
|
||||
private int current;
|
||||
|
||||
Region(int current){
|
||||
this.current=current;
|
||||
}
|
||||
|
||||
public int intValue(){
|
||||
return this.current;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Defined Color Helper
|
||||
*
|
||||
* @author Manzerbredes
|
||||
*
|
||||
*/
|
||||
public enum Color{
|
||||
OFF(0),RED(1),ORANGE(2),YELLOW(3),GREEN(4),SKY(5), BLUE(6),PURPLE(7),WHITE(8);
|
||||
|
||||
private int current;
|
||||
|
||||
Color(int current){
|
||||
this.current=current;
|
||||
}
|
||||
|
||||
public int intValue(){
|
||||
return this.current;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Defined Level Helper
|
||||
*
|
||||
* @author Manzerbredes
|
||||
*
|
||||
*/
|
||||
public enum Intensity{
|
||||
HIGH(0), MEDIUM(1), LOW(2), LIGHT(3);
|
||||
|
||||
private int current;
|
||||
|
||||
Intensity(int current){
|
||||
this.current=current;
|
||||
}
|
||||
|
||||
public int intValue(){
|
||||
return this.current;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Defined Mode Helper
|
||||
*
|
||||
* @author Manzerbredes
|
||||
*
|
||||
*/
|
||||
public enum Mode{
|
||||
NORMAL(1), GAMING(2), BREATHE(3), DEMO(4), WAVE(5);
|
||||
|
||||
private int current;
|
||||
|
||||
Mode(int current){
|
||||
this.current=current;
|
||||
}
|
||||
|
||||
public int intValue(){
|
||||
return this.current;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Device entry
|
||||
*/
|
||||
HIDDevice device;
|
||||
|
||||
|
||||
/**
|
||||
* Init driver and HIDAPI library
|
||||
*
|
||||
* @throws InstantiationException
|
||||
*/
|
||||
public Driver() throws InstantiationException{
|
||||
// Init HIDAPI Library
|
||||
com.codeminders.hidapi.ClassPathLibraryLoader.loadNativeHIDLibrary();
|
||||
|
||||
// Try not bind the device
|
||||
try {
|
||||
HIDManager man=HIDManager.getInstance();
|
||||
this.device=man.openById(0x1770, 0xff00, null);
|
||||
if(this.device==null)
|
||||
throw new Exception();
|
||||
}
|
||||
catch(Exception e){
|
||||
throw new InstantiationException("Failed to instanciate driver. Device not found or permission denied (try as root)");
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Build a byte[] report
|
||||
*
|
||||
* @param a
|
||||
* @param b
|
||||
* @param c
|
||||
* @param d
|
||||
* @param e
|
||||
* @param f
|
||||
* @param g
|
||||
* @param h
|
||||
* @return
|
||||
*/
|
||||
private byte[] getReport(int a, int b, int c, int d, int e, int f, int g, int h){
|
||||
byte[] message = new byte[8];
|
||||
message[0] = (byte) a;
|
||||
message[1] = (byte) b;
|
||||
message[2] = (byte) c;
|
||||
message[3] = (byte) d;
|
||||
message[4] = (byte) e;
|
||||
message[5] = (byte) f;
|
||||
message[6] = (byte) g;
|
||||
message[7] = (byte) h;
|
||||
return message;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Set Color of region
|
||||
*
|
||||
* @param region Region to apply
|
||||
* @param color Color to apply
|
||||
* @param intensity Intensity wanted
|
||||
*/
|
||||
public void setColor(Region region, Color color, Intensity intensity){
|
||||
try {
|
||||
this.device.sendFeatureReport(this.getReport(1,2,66,region.intValue(),color.intValue(),intensity.intValue(),0,236));
|
||||
} catch (IOException e) {
|
||||
// TODO Auto-generated catch block
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Commit change
|
||||
*
|
||||
* @param mode Mode wanted
|
||||
*/
|
||||
public void commit(Mode mode){
|
||||
try {
|
||||
this.device.sendFeatureReport(this.getReport(1,2,65,mode.intValue(),0,0,0,236));
|
||||
} catch (IOException e) {
|
||||
// TODO Auto-generated catch block
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -10,15 +10,7 @@ import org.manzerbredes.open_klm.device.Driver.Region;
|
|||
|
||||
public class KeyboardState {
|
||||
|
||||
/**
|
||||
* Define Keyboard color state
|
||||
*/
|
||||
private HashMap<Region, Pair<Color,Intensity>> KeyboardColor=new HashMap<>();
|
||||
|
||||
/**
|
||||
* Define Keyboard mode state
|
||||
*/
|
||||
private Mode mode;
|
||||
|
||||
|
||||
|
||||
public KeyboardState() {
|
||||
|
|
110
src/drivers/BasicDriver.java
Normal file
110
src/drivers/BasicDriver.java
Normal file
|
@ -0,0 +1,110 @@
|
|||
package org.manzerbredes.open_klm.drivers;
|
||||
|
||||
|
||||
public interface BasicDriver{
|
||||
|
||||
|
||||
/**
|
||||
* Defined Region Helper
|
||||
*
|
||||
* @author Manzerbredes
|
||||
*
|
||||
*/
|
||||
public enum Region{
|
||||
LEFT(1), MIDDLE(2), RIGHT(3);
|
||||
|
||||
private int current;
|
||||
|
||||
Region(int current){
|
||||
this.current=current;
|
||||
}
|
||||
|
||||
public int intValue(){
|
||||
return this.current;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Defined Color Helper
|
||||
*
|
||||
* @author Manzerbredes
|
||||
*
|
||||
*/
|
||||
public enum Color{
|
||||
OFF(0),RED(1),ORANGE(2),YELLOW(3),GREEN(4),SKY(5), BLUE(6),PURPLE(7),WHITE(8);
|
||||
|
||||
private int current;
|
||||
|
||||
Color(int current){
|
||||
this.current=current;
|
||||
}
|
||||
|
||||
public int intValue(){
|
||||
return this.current;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Defined Level Helper
|
||||
*
|
||||
* @author Manzerbredes
|
||||
*
|
||||
*/
|
||||
public enum Intensity{
|
||||
HIGH(0), MEDIUM(1), LOW(2), LIGHT(3);
|
||||
|
||||
private int current;
|
||||
|
||||
Intensity(int current){
|
||||
this.current=current;
|
||||
}
|
||||
|
||||
public int intValue(){
|
||||
return this.current;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Defined Mode Helper
|
||||
*
|
||||
* @author Manzerbredes
|
||||
*
|
||||
*/
|
||||
public enum Mode{
|
||||
NORMAL(1), GAMING(2), BREATHE(3), DEMO(4), WAVE(5);
|
||||
|
||||
private int current;
|
||||
|
||||
Mode(int current){
|
||||
this.current=current;
|
||||
}
|
||||
|
||||
public int intValue(){
|
||||
return this.current;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Set color of the region
|
||||
* @param region
|
||||
* @param color
|
||||
* @param intensity
|
||||
*/
|
||||
public void setRegionColor(Region region, Color color, Intensity intensity);
|
||||
|
||||
/**
|
||||
* Set global keyboard color
|
||||
* @param color
|
||||
* @param intensity
|
||||
*/
|
||||
public void setColor(Color color, Intensity intensity);
|
||||
|
||||
/**
|
||||
* Set keyboard mode
|
||||
* @param mode
|
||||
*/
|
||||
public void setMode(Mode mode);
|
||||
|
||||
}
|
139
src/drivers/Device_1770_ff00.java
Normal file
139
src/drivers/Device_1770_ff00.java
Normal file
|
@ -0,0 +1,139 @@
|
|||
package org.manzerbredes.open_klm.drivers;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.HashMap;
|
||||
import org.javatuples.Pair;
|
||||
import com.codeminders.hidapi.*;
|
||||
|
||||
|
||||
/**
|
||||
*
|
||||
* Driver to communicate with the keyboard device
|
||||
* using HIDAPI.
|
||||
*
|
||||
* @author Manzerbredes
|
||||
*
|
||||
*/
|
||||
public class Device_1770_ff00 implements BasicDriver{
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Device entry
|
||||
*/
|
||||
HIDDevice device;
|
||||
|
||||
/**
|
||||
* Define Keyboard color state
|
||||
*/
|
||||
private HashMap<Region, Pair<Color,Intensity>> KeyboardColor=new HashMap<>();
|
||||
|
||||
/**
|
||||
* Define Keyboard mode state
|
||||
*/
|
||||
private Mode mode=Mode.NORMAL;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Init driver and HIDAPI library
|
||||
*
|
||||
* @throws InstantiationException
|
||||
*/
|
||||
public Device_1770_ff00() throws InstantiationException{
|
||||
// Init HIDAPI Library
|
||||
com.codeminders.hidapi.ClassPathLibraryLoader.loadNativeHIDLibrary();
|
||||
|
||||
// Try not bind the device
|
||||
try {
|
||||
HIDManager man=HIDManager.getInstance();
|
||||
this.device=man.openById(0x1770, 0xff00, null);
|
||||
if(this.device==null)
|
||||
throw new Exception();
|
||||
}
|
||||
catch(Exception e){
|
||||
throw new InstantiationException("Failed to instanciate driver. Device not found or permission denied (try as root)");
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Build a byte[] report
|
||||
*
|
||||
* @param a
|
||||
* @param b
|
||||
* @param c
|
||||
* @param d
|
||||
* @param e
|
||||
* @param f
|
||||
* @param g
|
||||
* @param h
|
||||
* @return
|
||||
*/
|
||||
private byte[] getReport(int a, int b, int c, int d, int e, int f, int g, int h){
|
||||
byte[] message = new byte[8];
|
||||
message[0] = (byte) a;
|
||||
message[1] = (byte) b;
|
||||
message[2] = (byte) c;
|
||||
message[3] = (byte) d;
|
||||
message[4] = (byte) e;
|
||||
message[5] = (byte) f;
|
||||
message[6] = (byte) g;
|
||||
message[7] = (byte) h;
|
||||
return message;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
private void commit(){
|
||||
try {
|
||||
this.device.sendFeatureReport(this.getReport(1,2,65,this.mode.intValue(),0,0,0,236));
|
||||
} catch (IOException e) {
|
||||
// TODO Auto-generated catch block
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void setRegionColor(Region region, Color color, Intensity intensity) {
|
||||
try {
|
||||
this.device.sendFeatureReport(this.getReport(1,2,66,region.intValue(),color.intValue(),intensity.intValue(),0,236));
|
||||
this.commit();
|
||||
} catch (IOException e) {
|
||||
// TODO Auto-generated catch block
|
||||
e.printStackTrace();
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void setColor(Color color, Intensity intensity) {
|
||||
try {
|
||||
this.device.sendFeatureReport(this.getReport(1,2,66,Region.LEFT.intValue(),color.intValue(),intensity.intValue(),0,236));
|
||||
this.device.sendFeatureReport(this.getReport(1,2,66,Region.MIDDLE.intValue(),color.intValue(),intensity.intValue(),0,236));
|
||||
this.device.sendFeatureReport(this.getReport(1,2,66,Region.RIGHT.intValue(),color.intValue(),intensity.intValue(),0,236));
|
||||
this.commit();
|
||||
} catch (IOException e) {
|
||||
// TODO Auto-generated catch block
|
||||
e.printStackTrace();
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void setMode(Mode mode) {
|
||||
this.mode=mode;
|
||||
this.commit();
|
||||
}
|
||||
|
||||
}
|
Loading…
Add table
Reference in a new issue