Do some cleanup

This commit is contained in:
Juergen Jung 2012-03-04 10:50:50 +01:00
parent e786db9406
commit 27741a5330
24 changed files with 287 additions and 251 deletions

View file

@ -18,16 +18,16 @@ public class DeviceChangedEvent extends ApplicationEvent {
this.options = options;
}
public BuntiDevice getDevice() {
public final BuntiDevice getDevice() {
return device;
}
public Map<String, Object> getOptions() {
public final Map<String, Object> getOptions() {
return options;
}
@Override
public String toString() {
public final String toString() {
return "DeviceChangedEvent " + getDevice().getDeviceName();
}

View file

@ -17,7 +17,7 @@ import de.ctdo.bunti.artnet.packets.ArtNetPacket;
public class ArtNetSocketImpl implements ArtNetSocket {
private final Logger logger = LoggerFactory.getLogger(getClass());
public static final int DEFAULT_PORT = 0x1936;
protected DatagramSocket socket;
private DatagramSocket socket;
public ArtNetSocketImpl() {
try {
@ -33,12 +33,12 @@ public class ArtNetSocketImpl implements ArtNetSocket {
}
@Override
public boolean unicastPacket(ArtNetPacket pack, String address) {
public final boolean unicastPacket(ArtNetPacket pack, String address) {
InetAddress targetAdress;
try {
targetAdress = InetAddress.getByName(address);
DatagramPacket packet = new DatagramPacket(pack.getData(), pack.getLength(), targetAdress, DEFAULT_PORT);
DatagramPacket packet = new DatagramPacket(pack.getRawData(), pack.getLength(), targetAdress, DEFAULT_PORT);
socket.send(packet);
//socket.send(packet, targetAdress);

View file

@ -20,8 +20,8 @@
package de.ctdo.bunti.artnet;
public class ByteUtils {
protected final byte[] data;
public final int length;
private final byte[] data;
private final int length;
public ByteUtils(byte[] data) {
this.data = data;
@ -44,7 +44,7 @@ public class ByteUtils {
return stuff;
}
public boolean compareBytes(byte[] other, int offset, int length) {
public final boolean compareBytes(byte[] other, int offset, int length) {
boolean isEqual = (offset + length) < data.length;
for (int i = 0; i < length && isEqual; i++) {
isEqual = data[offset++] == other[i];
@ -60,7 +60,7 @@ public class ByteUtils {
return buffer;
}
public byte[] getBytes() {
public final byte[] getBytes() {
return data;
}

View file

@ -15,13 +15,13 @@ public class SimpleArtNetSenderImpl implements SimpleArtNetSender {
private int sequence = 0;
@Autowired
public void setSocket(ArtNetSocket socket) {
public final void setSocket(ArtNetSocket socket) {
this.socket = socket;
}
@Override
public void sendDMXData(Map<Integer,Integer> dmxdata, String adr) {
public final void sendDMXData(Map<Integer,Integer> dmxdata, String adr) {
ArtDmxPacket packet = new ArtDmxPacket();

View file

@ -31,92 +31,92 @@ public class ArtDmxPacket extends ArtNetPacket {
setData(new byte[530]);
setHeader();
setProtocol();
data.setInt8(0x02, 13);
getData().setInt8(0x02, 13);
}
/**
* @return the actual packet size used. If an odd number DMX channels is
* used, the packet size is made even automatically.
*
* @see artnet4j.packets.ArtNetPacket#getLength()
* @see ArtNetPacket#getLength()
*/
@Override
public int getLength() {
public final int getLength() {
return 18 + (1 == numChannels % 2 ? numChannels + 1 : numChannels);
}
/**
* @return the number of DMX channels
*/
public int getNumChannels() {
public final int getNumChannels() {
return numChannels;
}
/**
* @return the sequenceID
*/
public int getSequenceID() {
public final int getSequenceID() {
return sequenceID;
}
/**
* @return the subnetID
*/
public int getSubnetID() {
public final int getSubnetID() {
return subnetID;
}
/**
* @return the universeID
*/
public int getUniverseID() {
public final int getUniverseID() {
return universeID;
}
@Override
public boolean parse(byte[] raw) {
public final boolean parse(byte[] raw) {
return false;
}
public void setDMX(byte[] dmxData, int numChannels) {
public final void setDMX(byte[] dmxData, int numChannels) {
this.numChannels = numChannels;
data.setByteChunk(dmxData, 18, numChannels);
data.setInt16((1 == numChannels % 2 ? numChannels + 1 : numChannels),
16);
getData().setByteChunk(dmxData, 18, numChannels);
getData().setInt16((1 == numChannels % 2 ? numChannels + 1 : numChannels),
16);
}
/**
* @param numChannels
* the number of DMX channels to set
*/
public void setNumChannels(int numChannels) {
public final void setNumChannels(int numChannels) {
this.numChannels = numChannels > 512 ? 512 : numChannels;
}
public void setSequenceID(int id) {
public final void setSequenceID(int id) {
sequenceID = id % 0xff;
data.setInt8(id, 12);
getData().setInt8(id, 12);
}
/**
* @param subnetID
* the subnetID to set
*/
public void setSubnetID(int subnetID) {
public final void setSubnetID(int subnetID) {
this.subnetID = subnetID & 0x0f;
}
public void setUniverse(int subnetID, int universeID) {
public final void setUniverse(int subnetID, int universeID) {
this.subnetID = subnetID & 0x0f;
this.universeID = universeID & 0x0f;
data.setInt16LE(subnetID << 4 | universeID, 14);
getData().setInt16LE(subnetID << 4 | universeID, 14);
}
/**
* @param universeID
* the universeID to set
*/
public void setUniverseID(int universeID) {
public final void setUniverseID(int universeID) {
this.universeID = universeID & 0x0f;
}
}

View file

@ -3,25 +3,30 @@ package de.ctdo.bunti.artnet.packets;
import de.ctdo.bunti.artnet.ByteUtils;
public abstract class ArtNetPacket {
public static final byte[] HEADER = "Art-Net\0".getBytes();
static final byte[] HEADER = "Art-Net\0".getBytes();
public static final int PROTOCOL_VERSION = 14;
protected ByteUtils data;
protected final PacketType type;
private ByteUtils data;
private final PacketType type;
public final ByteUtils getData() {
return data;
}
public ArtNetPacket(PacketType type) {
this.type = type;
}
public byte[] getData() {
public final byte[] getRawData() {
return data.getBytes();
}
public int getLength() {
return data.length;
return getData().getLength();
}
public PacketType getType() {
public final PacketType getType() {
return type;
}
@ -40,11 +45,11 @@ public abstract class ArtNetPacket {
* @param data
* the data to set
*/
public void setData(byte[] data) {
public final void setData(byte[] data) {
this.data = new ByteUtils(data);
}
public void setData(byte[] raw, int maxLength) {
public final void setRawData(byte[] raw, int maxLength) {
if (raw.length > maxLength) {
byte[] raw2 = new byte[maxLength];
System.arraycopy(raw, 0, raw2, 0, maxLength);
@ -53,17 +58,17 @@ public abstract class ArtNetPacket {
setData(raw);
}
protected void setHeader() {
protected final void setHeader() {
data.setByteChunk(HEADER, 0, 8);
data.setInt16LE(type.getOpCode(), 8);
}
protected void setProtocol() {
protected final void setProtocol() {
data.setInt16(PROTOCOL_VERSION, 10);
}
@Override
public String toString() {
public final String toString() {
return data.toHex(getLength());
}

View file

@ -21,11 +21,11 @@ public class BuntiControllerImpl implements BuntiController, ApplicationEventPub
private BuntiDevicesDAO devicesDAO;
@Autowired
public void setDevicesDAO(BuntiDevicesDAO devicesDAO) {
public final void setDevicesDAO(BuntiDevicesDAO devicesDAO) {
this.devicesDAO = devicesDAO;
}
public void performJSONString(String json) {
public final void performJSONString(String json) {
JSONObject jsonobj = JSONObject.fromObject(json);
@ -42,7 +42,7 @@ public class BuntiControllerImpl implements BuntiController, ApplicationEventPub
}
@Override
public boolean setDevice(int deviceId, Map<String, Object> options) {
public final boolean setDevice(int deviceId, Map<String, Object> options) {
BuntiDevice device = devicesDAO.getDeviceById(deviceId);
@ -61,7 +61,7 @@ public class BuntiControllerImpl implements BuntiController, ApplicationEventPub
}
@Override
public void setApplicationEventPublisher(ApplicationEventPublisher publisher) {
public final void setApplicationEventPublisher(ApplicationEventPublisher publisher) {
this.applicationEventPublisher = publisher;
}

View file

@ -35,7 +35,7 @@ public class BuntiDevicesDAOImpl implements BuntiDevicesDAO {
@Override
public Collection<BuntiDMXDevice> getAllDMXDevices() {
public final Collection<BuntiDMXDevice> getAllDMXDevices() {
List<BuntiDMXDevice> liste = new ArrayList<BuntiDMXDevice>();
for (BuntiDevice device : devices) {
if( device instanceof BuntiDMXDevice ) {
@ -46,7 +46,7 @@ public class BuntiDevicesDAOImpl implements BuntiDevicesDAO {
}
@Override
public BuntiDevice getDeviceById(int deviceId) {
public final BuntiDevice getDeviceById(int deviceId) {
for (BuntiDevice dev : devices) {
if(dev.getDeviceId() == deviceId) {
return dev;

View file

@ -11,7 +11,7 @@ import de.ctdo.bunti.model.BuntiSwitchingDevice;
public class DeviceMixerImpl implements DeviceMixer, ApplicationListener<DeviceChangedEvent> {
@Override
public void onApplicationEvent(DeviceChangedEvent arg0) {
public final void onApplicationEvent(DeviceChangedEvent arg0) {
if( arg0.getDevice() instanceof BuntiSwitchingDevice) {

View file

@ -1,42 +1,47 @@
package de.ctdo.bunti.dmx;
public class DMX {
public final class DMX {
public static final int DMX_CHANNELS_MAX = (byte) 511;
public static final int DMX_CHANNELS_MIN = 0;
public static final int DMX_CHANNEL_VALUE_MAX = (byte) 255;
public static final int DMX_CHANNEL_VALUE_MIN = 0;
/**
* Offset by which startaddress differs from DMX512 Data Array location
*/
public static final int DMX_STARTADDRESS_OFFSET = -1;
public static final int DMX_CHANNELS_MAX = (byte) 511;
public static final int DMX_CHANNELS_MIN = 0;
public static final int DMX_CHANNEL_VALUE_MAX = (byte) 255;
public static final int DMX_CHANNEL_VALUE_MIN = 0;
/**
* Offset by which startaddress differs from DMX512 Data Array location
*/
public static final int DMX_STARTADDRESS_OFFSET = -1;
private DMX(){
private DMX() {
}
/**
* Checks the DMX Value boundaries
* @param value
* @return A valid DMX512 channel value
*/
public static int sanitizeDMXValue(int value) {
if(value < DMX_CHANNEL_VALUE_MIN) value = DMX_CHANNEL_VALUE_MIN;
if(value > DMX_CHANNEL_VALUE_MAX) value = DMX_CHANNEL_VALUE_MAX;
return value;
}
/**
* Checks the DMX Channel boundaries
* @param channel The channel to check
* @return True if channel is valid. Otherwise false.
*/
public static boolean checkChannelBoundaries(int channel) {
return (channel >= DMX_CHANNELS_MIN && channel <= DMX_CHANNELS_MAX);
}
/**
* Checks the DMX Value boundaries
*
* @param value
* @return A valid DMX512 channel value
*/
public static int sanitizeDMXValue(int value) {
if (value < DMX_CHANNEL_VALUE_MIN) {
return DMX_CHANNEL_VALUE_MIN;
}
if (value > DMX_CHANNEL_VALUE_MAX) {
return DMX_CHANNEL_VALUE_MAX;
}
return value;
}
/**
* Checks the DMX Channel boundaries
*
* @param channel The channel to check
* @return True if channel is valid. Otherwise false.
*/
public static boolean checkChannelBoundaries(int channel) {
return (channel >= DMX_CHANNELS_MIN && channel <= DMX_CHANNELS_MAX);
}
}

View file

@ -12,41 +12,41 @@ public class DMXChannel {
this.value = 0;
}
public int getValue() {
public final int getValue() {
return value;
}
public void setValue(int value) {
public final void setValue(int value) {
this.value = value;
lastChangedTimestamp = System.currentTimeMillis();
}
public long getLastChangedTimestamp() {
public final long getLastChangedTimestamp() {
return lastChangedTimestamp;
}
public int getOffset() {
public final int getOffset() {
return offset;
}
public void setOffset(int offset) {
public final void setOffset(int offset) {
this.offset = offset;
}
public String getName() {
public final String getName() {
return name;
}
public void setName(String name) {
public final void setName(String name) {
this.name = name;
}
public void hasbeenSendOut() {
public final void hasbeenSendOut() {
this.lastChangedTimestamp = System.currentTimeMillis();
}
@Override
public String toString() {
public final String toString() {
return "DMXChannel " + getName() + "," + getOffset() + "," + getValue();
}

View file

@ -12,14 +12,14 @@ import java.util.Map;
*/
public class DMXChannels {
protected Map<Integer,DMXChannel> channelByNumber = new HashMap<Integer, DMXChannel>();
protected Map<String,DMXChannel> channelByName = new HashMap<String, DMXChannel>();
private Map<Integer,DMXChannel> channelByNumber = new HashMap<Integer, DMXChannel>();
private Map<String,DMXChannel> channelByName = new HashMap<String, DMXChannel>();
/**
* Returns the number of channels
* @return number of channels
*/
public int getCount() {
public final int getCount() {
return this.channelByNumber.size();
}
@ -28,7 +28,7 @@ public class DMXChannels {
* @param name channel name
* @return channel or null if not found
*/
public DMXChannel getChannelByName(String name) {
public final DMXChannel getChannelByName(String name) {
if (name == null) {
return null;
}
@ -40,7 +40,7 @@ public class DMXChannels {
* @param number number
* @return channel or null if not found
*/
public DMXChannel getChannelByNumber(int number) {
public final DMXChannel getChannelByNumber(int number) {
return this.channelByNumber.get(number);
}
@ -49,7 +49,7 @@ public class DMXChannels {
* @param channel channel to add
* @return true on success, false on error
*/
public boolean addChannel(DMXChannel channel) {
public final boolean addChannel(DMXChannel channel) {
// object cannot be null
if (channel == null) {
return false;
@ -76,7 +76,7 @@ public class DMXChannels {
* @param offset offset
* @return removed channel or null if it does not exist
*/
public DMXChannel removeChannel(int offset) {
public final DMXChannel removeChannel(int offset) {
DMXChannel tmpChannel = this.channelByNumber.remove(offset);
if (tmpChannel != null) {
this.channelByName.remove(tmpChannel.getName());
@ -89,7 +89,7 @@ public class DMXChannels {
* @param name channel name
* @return removed channel or null if it does not exist
*/
public DMXChannel removeChannel(String name) {
public final DMXChannel removeChannel(String name) {
if (name == null) {
return null;
}
@ -105,7 +105,7 @@ public class DMXChannels {
* Returns an (unmodifiable) collection of all channels
* @return unmodifiable collection of all channels
*/
public Collection<DMXChannel> getAllChannels() {
public final Collection<DMXChannel> getAllChannels() {
return Collections.unmodifiableCollection(this.channelByNumber.values());
}

View file

@ -1,88 +1,90 @@
package de.ctdo.bunti.dmx;
import de.ctdo.bunti.DeviceChangedEvent;
import de.ctdo.bunti.artnet.SimpleArtNetSender;
import de.ctdo.bunti.model.BuntiDMXDevice;
import de.ctdo.bunti.model.BuntiDevice;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationListener;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationListener;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import de.ctdo.bunti.DeviceChangedEvent;
import de.ctdo.bunti.artnet.SimpleArtNetSender;
import de.ctdo.bunti.model.*;
@Component
public class DMXMixerImpl implements DMXMixer, ApplicationListener<DeviceChangedEvent> {
private static final Logger LOGGER = LoggerFactory.getLogger(DMXMixerImpl.class);
private static final String ARTNET_DEVICE_ADDRESS = "192.168.0.90";
private final Map<Integer,Integer> dmxMap = Collections.synchronizedMap(new HashMap<Integer,Integer>());
private SimpleArtNetSender artNetSender;
private boolean hasDataChanged = true;
@Autowired
public void setArtNetSender(SimpleArtNetSender artNetSender) {
this.artNetSender = artNetSender;
}
private static final Logger LOGGER = LoggerFactory.getLogger(DMXMixerImpl.class);
private static final String ARTNET_DEVICE_ADDRESS = "192.168.0.90";
private final Map<Integer, Integer> dmxMap = Collections.synchronizedMap(new HashMap<Integer, Integer>());
private SimpleArtNetSender artNetSender;
private boolean hasDataChanged = true;
@Autowired
public final void setArtNetSender(SimpleArtNetSender artNetSender) {
this.artNetSender = artNetSender;
}
public void initDMXData() {
for (int i = 0; i <= DMX.DMX_CHANNELS_MAX; i++) {
dmxMap.put(i, 0);
}
}
public final void initDMXData() {
for (int i = 0; i <= DMX.DMX_CHANNELS_MAX; i++) {
dmxMap.put(i, 0);
}
}
@Scheduled(fixedDelay=100) //TODO aendern auf 10ms
public void sendOutDMXBuffer() {
if( dmxMap.size() == 0) initDMXData();
@Scheduled(fixedDelay = 100) //TODO aendern auf 10ms
public final void sendOutDMXBuffer() {
if (dmxMap.size() == 0) {
initDMXData();
}
if (hasDataChanged) {
artNetSender.sendDMXData(dmxMap, ARTNET_DEVICE_ADDRESS);
hasDataChanged = false;
}
if( hasDataChanged ) {
artNetSender.sendDMXData(dmxMap, ARTNET_DEVICE_ADDRESS);
hasDataChanged = false;
}
// logger.debug(sb.toString());
}
public void updateDevice(BuntiDevice device, Map<String, Object> options) {
BuntiDMXDevice dmxDev = (BuntiDMXDevice)device;
if( dmxDev.setValuesFromOptions(options) ) {
dmxMap.putAll(dmxDev.getChannelData());
LOGGER.info("setValuesFromOptions on " + device);
} else {
LOGGER.info("setValuesFromOptions on " + device + " failed");
}
}
@Override
public void setDMX512Channel(int channel, int value) {
if(!DMX.checkChannelBoundaries(channel)) return;
value = DMX.sanitizeDMXValue(value);
dmxMap.put(channel, value);
hasDataChanged = true;
}
@Override
public void onApplicationEvent(DeviceChangedEvent arg0) {
if( arg0.getDevice() instanceof BuntiDMXDevice) {
updateDevice(arg0.getDevice(), arg0.getOptions());
hasDataChanged = true;
// TODO: hier kann man z.B. auch noch direkt einmal die DMX Daten zu verschicken veranlassen
}
}
}
public final void updateDevice(BuntiDevice device, Map<String, Object> options) {
BuntiDMXDevice dmxDev = (BuntiDMXDevice) device;
if (dmxDev.setValuesFromOptions(options)) {
dmxMap.putAll(dmxDev.getChannelData());
LOGGER.info("setValuesFromOptions on " + device);
}
else {
LOGGER.info("setValuesFromOptions on " + device + " failed");
}
}
@Override
public final void setDMX512Channel(int channel, int value) {
if (!DMX.checkChannelBoundaries(channel)) {
return;
}
dmxMap.put(channel, DMX.sanitizeDMXValue(value));
hasDataChanged = true;
}
@Override
public final void onApplicationEvent(DeviceChangedEvent arg0) {
if (arg0.getDevice() instanceof BuntiDMXDevice) {
updateDevice(arg0.getDevice(), arg0.getOptions());
hasDataChanged = true;
// TODO: hier kann man z.B. auch noch direkt einmal die DMX Daten zu verschicken veranlassen
}
}
}

View file

@ -7,29 +7,29 @@ import java.util.Map.Entry;
import de.ctdo.bunti.dmx.*;
public abstract class BuntiDMXDevice extends BuntiDevice {
protected int startAddress;
private int startAddress;
private long lastSendOut;
protected DMXChannels dmxChannels = new DMXChannels();
private DMXChannels dmxChannels = new DMXChannels();
public BuntiDMXDevice(int deviceId, int startAddress, String name) {
this.startAddress = startAddress;
this.deviceName = name;
this.deviceId = deviceId;
super(deviceId,name);
this.startAddress = startAddress;
}
public long getLastSendOut() {
public final long getLastSendOut() {
return lastSendOut;
}
public void setSendOutNow() {
public final void setSendOutNow() {
this.lastSendOut = System.currentTimeMillis();
}
public int getStartAddress() {
public final int getStartAddress() {
return startAddress;
}
public void setStartAddress(int startAddress) {
public final void setStartAddress(int startAddress) {
this.startAddress = startAddress;
}
@ -38,7 +38,7 @@ public abstract class BuntiDMXDevice extends BuntiDevice {
* @param name The channel name to change the value.
* @param value The channel value to set.
*/
protected void setChannelValueByName(String name, int value) {
protected final void setChannelValueByName(String name, int value) {
DMXChannel dx = dmxChannels.getChannelByName(name);
if(dx != null) {
dx.setValue(DMX.sanitizeDMXValue(value));
@ -51,7 +51,7 @@ public abstract class BuntiDMXDevice extends BuntiDevice {
* @param name The channel name to get the value from.
* @return The desired channel value.
*/
protected int getChannelValueByName(String name) {
protected final int getChannelValueByName(String name) {
DMXChannel dx = dmxChannels.getChannelByName(name);
if(dx != null) {
return dx.getValue();
@ -122,7 +122,7 @@ public abstract class BuntiDMXDevice extends BuntiDevice {
}
@Override
public boolean setValuesFromOptions(Map<String, Object> options) {
public final boolean setValuesFromOptions(Map<String, Object> options) {
for (Entry<String, Object> opt : options.entrySet()) {
@ -141,9 +141,13 @@ public abstract class BuntiDMXDevice extends BuntiDevice {
}
return true;
}
public final boolean addChannel(DMXChannel channel){
return dmxChannels.addChannel(channel);
}
@Override
public String toString() {
return "BuntiDMXDevice " + deviceId + ", " + deviceName;
return "BuntiDMXDevice " + getDeviceId() + ", " + getDeviceName();
}
}

View file

@ -3,27 +3,37 @@ package de.ctdo.bunti.model;
import java.util.Map;
public abstract class BuntiDevice {
protected int deviceId;
protected String deviceName;
private int deviceId;
private String deviceName;
private long lastChanged;
public int getDeviceId() {
public BuntiDevice(int deviceId, String deviceName, long lastChanged) {
this.deviceId = deviceId;
this.deviceName = deviceName;
this.lastChanged = lastChanged;
}
public BuntiDevice(int deviceId, String deviceName) {
this(deviceId,deviceName,0);
}
public final int getDeviceId() {
return deviceId;
}
public long getLastChanged() {
public final long getLastChanged() {
return lastChanged;
}
protected void lastChangedNow() {
protected final void lastChangedNow() {
this.lastChanged = System.currentTimeMillis();
}
public String getDeviceName() {
public final String getDeviceName() {
return deviceName;
}
public void setDeviceName(String deviceName) {
public final void setDeviceName(String deviceName) {
this.deviceName = deviceName;
}

View file

@ -4,7 +4,16 @@ import java.util.Map;
public class BuntiSwitchingDevice extends BuntiDevice {
@Override
public BuntiSwitchingDevice(int deviceId, String deviceName, long lastChanged) {
super(deviceId, deviceName, lastChanged);
}
public BuntiSwitchingDevice(int deviceId, String deviceName) {
super(deviceId, deviceName);
}
@Override
public void switchOff() {
// TODO Auto-generated method stub
@ -17,7 +26,7 @@ public class BuntiSwitchingDevice extends BuntiDevice {
}
@Override
public boolean setValuesFromOptions(Map<String, Object> options) {
public final boolean setValuesFromOptions(Map<String, Object> options) {
// TODO Auto-generated method stub
return false;
}

View file

@ -4,44 +4,45 @@ import de.ctdo.bunti.dmx.DMX;
import de.ctdo.bunti.dmx.DMXChannel;
public class Par56Spot extends BuntiDMXDevice {
private final static String CHANNEL_MODE = "mode";
private final static String CHANNEL_RED = "red";
private final static String CHANNEL_GREEN = "green";
private final static String CHANNEL_BLUE = "blue";
private final static String CHANNEL_SPEED = "speed";
private static final String CHANNEL_MODE = "mode";
private static final String CHANNEL_RED = "red";
private static final String CHANNEL_GREEN = "green";
private static final String CHANNEL_BLUE = "blue";
private static final String CHANNEL_SPEED = "speed";
public Par56Spot(int deviceId, int startAddress, String deviceName) {
super(deviceId, startAddress, deviceName);
dmxChannels.addChannel(new DMXChannel(0, CHANNEL_MODE));
dmxChannels.addChannel(new DMXChannel(1, "red"));
dmxChannels.addChannel(new DMXChannel(2, CHANNEL_GREEN));
dmxChannels.addChannel(new DMXChannel(3, CHANNEL_BLUE));
dmxChannels.addChannel(new DMXChannel(4, CHANNEL_SPEED));
addChannel(new DMXChannel(0, CHANNEL_MODE));
addChannel(new DMXChannel(1, "red"));
addChannel(new DMXChannel(2, CHANNEL_GREEN));
addChannel(new DMXChannel(3, CHANNEL_BLUE));
addChannel(new DMXChannel(4, CHANNEL_SPEED));
}
public void setColorRed(int value) {
public final void setColorRed(int value) {
setChannelValueByName(CHANNEL_RED, value);
}
public void setColorGreen(int value) {
public final void setColorGreen(int value) {
setChannelValueByName(CHANNEL_GREEN, value);
}
public void setColorBlue(int value) {
public final void setColorBlue(int value) {
setChannelValueByName(CHANNEL_BLUE, value);
}
public int getColorRed() {
public final int getColorRed() {
return getChannelValueByName(CHANNEL_RED);
}
public int getColorGreen() {
public final int getColorGreen() {
return getChannelValueByName(CHANNEL_GREEN);
}
public int getColorBlue() {
public final int getColorBlue() {
return getChannelValueByName(CHANNEL_BLUE);
}
@Override
public void switchOff() {
public final void switchOff() {
setChannelValueByName(CHANNEL_MODE, DMX.DMX_CHANNEL_VALUE_MIN);
setColorRed(DMX.DMX_CHANNEL_VALUE_MIN);
setColorGreen(DMX.DMX_CHANNEL_VALUE_MIN);
@ -50,7 +51,7 @@ public class Par56Spot extends BuntiDMXDevice {
}
@Override
public void switchOn() {
public final void switchOn() {
setChannelValueByName(CHANNEL_MODE, DMX.DMX_CHANNEL_VALUE_MIN);
setColorRed(DMX.DMX_CHANNEL_VALUE_MAX);
setColorGreen(DMX.DMX_CHANNEL_VALUE_MAX);
@ -59,8 +60,8 @@ public class Par56Spot extends BuntiDMXDevice {
}
@Override
public String toString() {
return "Par56Spot " + deviceId + ", " + deviceName + " " +
public final String toString() {
return "Par56Spot " + getDeviceId() + ", " + getDeviceName() + " " +
"[" + getColorRed() + "," + getColorGreen() + "," + getColorBlue() + "]";
}

View file

@ -5,54 +5,54 @@ import de.ctdo.bunti.dmx.DMXChannel;
public class Strobe1500 extends BuntiDMXDevice {
private final static String CHANNEL_SPEED = "speed";
private final static String CHANNEL_INTENSITY = "intensity";
private final static String CHANNEL_MODE = "mode";
private static final String CHANNEL_SPEED = "speed";
private static final String CHANNEL_INTENSITY = "intensity";
private static final String CHANNEL_MODE = "mode";
public Strobe1500(int deviceId, int startAddress, String deviceName) {
super(deviceId, startAddress, deviceName);
this.dmxChannels.addChannel(new DMXChannel(0, CHANNEL_SPEED));
this.dmxChannels.addChannel(new DMXChannel(1, CHANNEL_INTENSITY));
this.dmxChannels.addChannel(new DMXChannel(2, CHANNEL_MODE));
addChannel(new DMXChannel(0, CHANNEL_SPEED));
addChannel(new DMXChannel(1, CHANNEL_INTENSITY));
addChannel(new DMXChannel(2, CHANNEL_MODE));
}
public void setSpeed(int value) {
public final void setSpeed(int value) {
setChannelValueByName(CHANNEL_SPEED, value);
}
public void setIntensity(int value) {
public final void setIntensity(int value) {
setChannelValueByName(CHANNEL_INTENSITY, value);
}
public void setMode(int value) {
public final void setMode(int value) {
setChannelValueByName(CHANNEL_MODE, value);
}
public int getSpeed() {
public final int getSpeed() {
return getChannelValueByName(CHANNEL_SPEED);
}
public int getIntensity() {
public final int getIntensity() {
return getChannelValueByName(CHANNEL_INTENSITY);
}
public int getMode() {
public final int getMode() {
return getChannelValueByName(CHANNEL_MODE);
}
@Override
public void switchOff() {
public final void switchOff() {
setChannelValueByName(CHANNEL_MODE, DMX.DMX_CHANNEL_VALUE_MIN);
setChannelValueByName(CHANNEL_SPEED, DMX.DMX_CHANNEL_VALUE_MIN);
setChannelValueByName(CHANNEL_INTENSITY, DMX.DMX_CHANNEL_VALUE_MIN);
}
@Override
public void switchOn() {
public final void switchOn() {
setChannelValueByName(CHANNEL_MODE, DMX.DMX_CHANNEL_VALUE_MIN);
setChannelValueByName(CHANNEL_SPEED, DMX.DMX_CHANNEL_VALUE_MAX);
setChannelValueByName(CHANNEL_INTENSITY, DMX.DMX_CHANNEL_VALUE_MAX);
}
@Override
public String toString() {
return "Strobe1500 " + deviceId + ", " + deviceName +
public final String toString() {
return "Strobe1500 " + getDeviceId() + ", " + getDeviceName() +
"[" + getSpeed() + "," + getIntensity() + "," + getMode() + "]";
}

View file

@ -16,15 +16,15 @@ import de.ctdo.bunti.control.BuntiController;
@Controller
public class TestController {
private static final Logger LOGGER = LoggerFactory.getLogger(TestController.class);
BuntiController buntiController;
private BuntiController buntiController;
@Autowired
public void setBuntiController(BuntiController buntiController) {
public final void setBuntiController(BuntiController buntiController) {
this.buntiController = buntiController;
}
@RequestMapping("/foobar")
public ModelAndView blafasel() {
public final ModelAndView blafasel() {
Map<String,Object> options = new HashMap<String,Object>();
options.put("red", 124);
@ -59,7 +59,7 @@ public class TestController {
}
@RequestMapping("/foobar2")
public ModelAndView blafasel2() {
public final ModelAndView blafasel2() {
Map<String,Object> options = new HashMap<String,Object>();

View file

@ -12,23 +12,23 @@ import com.sun.grizzly.websockets.WebSocketListener;
@Component
public class BuntiControllerApplication extends WebSocketApplication {
Logger logger = LoggerFactory.getLogger(BuntiControllerApplication.class);
private static final Logger LOGGER = LoggerFactory.getLogger(BuntiControllerApplication.class);
@Override
public WebSocket createWebSocket(ProtocolHandler protocolHandler, WebSocketListener... listeners) {
public final WebSocket createWebSocket(ProtocolHandler protocolHandler, WebSocketListener... listeners) {
BuntiControllerWebSocket socket = new BuntiControllerWebSocket(protocolHandler, listeners);
// BuntiControllerImpl.getInstance().addListener(socket);
return socket;
}
@Override
public boolean isApplicationRequest(Request request) {
public final boolean isApplicationRequest(Request request) {
final String uri = request.requestURI().toString();
return uri.endsWith("/bunti");
}
@Override
public void onClose(WebSocket socket, com.sun.grizzly.websockets.DataFrame frame) {
public final void onClose(WebSocket socket, com.sun.grizzly.websockets.DataFrame frame) {
BuntiControllerWebSocket ws = (BuntiControllerWebSocket) socket;
// BuntiControllerImpl.getInstance().removeListener(ws);
}

View file

@ -9,32 +9,32 @@ import org.springframework.stereotype.Component;
@Component
public class BuntiControllerServlet { // extends HttpServlet {
private static final long serialVersionUID = 1L;
Logger logger = LoggerFactory.getLogger(BuntiControllerServlet.class);
private static final Logger LOGGER = LoggerFactory.getLogger(BuntiControllerServlet.class);
private BuntiControllerApplication app;
@Autowired
public void setApp(BuntiControllerApplication app) {
public final void setApp(BuntiControllerApplication app) {
this.app = app;
}
public void BuntiControllerApplication() {
public void buntiControllerApplication() {
// WebSocketEngine.getEngine().register(app);
// logger.debug("registered BuntiControllerApplication");
// LOGGER.debug("registered buntiControllerApplication");
}
// @Override
// public void init(ServletConfig config) throws ServletException {
// WebSocketEngine.getEngine().register(app);
// logger.debug("registered BuntiControllerApplication");
// LOGGER.debug("registered buntiControllerApplication");
// }
//
// @Override
// public void destroy() {
// WebSocketEngine.getEngine().unregister(app);
// logger.debug("unregistered BuntiControllerApplication");
// LOGGER.debug("unregistered buntiControllerApplication");
// }
}

View file

@ -14,7 +14,7 @@ import com.sun.grizzly.websockets.WebSocketListener;
*/
public class BuntiControllerWebSocket extends DefaultWebSocket {
Logger logger = LoggerFactory.getLogger(BuntiControllerWebSocket.class);
private static final Logger LOGGER = LoggerFactory.getLogger(BuntiControllerWebSocket.class);
public BuntiControllerWebSocket(ProtocolHandler protocolHandler, WebSocketListener[] listeners) {
super(protocolHandler, listeners);

File diff suppressed because one or more lines are too long

View file

@ -488,11 +488,11 @@ minDate:null,maxDate:null,duration:"fast",beforeShowDay:null,beforeShow:null,onS
function(b){b=d(b.target).closest("button, .ui-datepicker-prev, .ui-datepicker-next, .ui-datepicker-calendar td a");b.length&&b.removeClass("ui-state-hover ui-datepicker-prev-hover ui-datepicker-next-hover")}).bind("mouseover",function(b){b=d(b.target).closest("button, .ui-datepicker-prev, .ui-datepicker-next, .ui-datepicker-calendar td a");if(!(d.datepicker._isDisabledDatepicker(J.inline?a.parent()[0]:J.input[0])||!b.length)){b.parents(".ui-datepicker-calendar").find("a").removeClass("ui-state-hover");
b.addClass("ui-state-hover");b.hasClass("ui-datepicker-prev")&&b.addClass("ui-datepicker-prev-hover");b.hasClass("ui-datepicker-next")&&b.addClass("ui-datepicker-next-hover")}})}function H(a,b){d.extend(a,b);for(var c in b)if(b[c]==null||b[c]==C)a[c]=b[c];return a}d.extend(d.ui,{datepicker:{version:"1.8.16"}});var B=(new Date).getTime(),J;d.extend(M.prototype,{markerClassName:"hasDatepicker",maxRows:4,log:function(){this.debug&&console.log.apply("",arguments)},_widgetDatepicker:function(){return this.dpDiv},
setDefaults:function(a){H(this._defaults,a||{});return this},_attachDatepicker:function(a,b){var c=null;for(var e in this._defaults){var f=a.getAttribute("date:"+e);if(f){c=c||{};try{c[e]=eval(f)}catch(h){c[e]=f}}}e=a.nodeName.toLowerCase();f=e=="div"||e=="span";if(!a.id){this.uuid+=1;a.id="dp"+this.uuid}var i=this._newInst(d(a),f);i.settings=d.extend({},b||{},c||{});if(e=="input")this._connectDatepicker(a,i);else f&&this._inlineDatepicker(a,i)},_newInst:function(a,b){return{id:a[0].id.replace(/([^A-Za-z0-9_-])/g,
"\\\\$1"),input:a,selectedDay:0,selectedMonth:0,selectedYear:0,drawMonth:0,drawYear:0,inline:b,dpDiv:!b?this.dpDiv:N(d('<div class="'+this._inlineClass+' ui-datepicker ui-widget ui-widget-content ui-helper-clearfix ui-corner-all"></div>'))}},_connectDatepicker:function(a,b){var c=d(a);b.append=d([]);b.trigger=d([]);if(!c.hasClass(this.markerClassName)){this._attachments(c,b);c.addClass(this.markerClassName).keydown(this._doKeyDown).keypress(this._doKeyPress).keyup(this._doKeyUp).bind("setData.datepicker",
function(e,f,h){b.settings[f]=h}).bind("getData.datepicker",function(e,f){return this._get(b,f)});this._autoSize(b);d.data(a,"datepicker",b);b.settings.disabled&&this._disableDatepicker(a)}},_attachments:function(a,b){var c=this._get(b,"appendText"),e=this._get(b,"isRTL");b.append&&b.append.remove();if(c){b.append=d('<span class="'+this._appendClass+'">'+c+"</span>");a[e?"before":"after"](b.append)}a.unbind("focus",this._showDatepicker);b.trigger&&b.trigger.remove();c=this._get(b,"showOn");if(c==
"\\\\$1"),input:a,selectedDay:0,selectedMonth:0,selectedYear:0,drawMonth:0,drawYear:0,inline:b,dpDiv:!b?this.dpDiv:N(d('<div class="'+this._inlineClass+' ui-datepicker ui-widget ui-widget-content ui-helper-clearfix ui-corner-all"></div>'))}},_connectDatepicker:function(a,b){var c=d(a);b.append=d([]);b.trigger=d([]);if(!c.hasClass(this.markerClassName)){this._attachments(c,b);c.addClass(this.markerClassName).keydown(this._doKeyDown).keypress(this._doKeyPress).keyup(this._doKeyUp).bind("setRawData.datepicker",
function(e,f,h){b.settings[f]=h}).bind("getRawData.datepicker",function(e,f){return this._get(b,f)});this._autoSize(b);d.data(a,"datepicker",b);b.settings.disabled&&this._disableDatepicker(a)}},_attachments:function(a,b){var c=this._get(b,"appendText"),e=this._get(b,"isRTL");b.append&&b.append.remove();if(c){b.append=d('<span class="'+this._appendClass+'">'+c+"</span>");a[e?"before":"after"](b.append)}a.unbind("focus",this._showDatepicker);b.trigger&&b.trigger.remove();c=this._get(b,"showOn");if(c==
"focus"||c=="both")a.focus(this._showDatepicker);if(c=="button"||c=="both"){c=this._get(b,"buttonText");var f=this._get(b,"buttonImage");b.trigger=d(this._get(b,"buttonImageOnly")?d("<img/>").addClass(this._triggerClass).attr({src:f,alt:c,title:c}):d('<button type="button"></button>').addClass(this._triggerClass).html(f==""?c:d("<img/>").attr({src:f,alt:c,title:c})));a[e?"before":"after"](b.trigger);b.trigger.click(function(){d.datepicker._datepickerShowing&&d.datepicker._lastInput==a[0]?d.datepicker._hideDatepicker():
d.datepicker._showDatepicker(a[0]);return false})}},_autoSize:function(a){if(this._get(a,"autoSize")&&!a.inline){var b=new Date(2009,11,20),c=this._get(a,"dateFormat");if(c.match(/[DM]/)){var e=function(f){for(var h=0,i=0,g=0;g<f.length;g++)if(f[g].length>h){h=f[g].length;i=g}return i};b.setMonth(e(this._get(a,c.match(/MM/)?"monthNames":"monthNamesShort")));b.setDate(e(this._get(a,c.match(/DD/)?"dayNames":"dayNamesShort"))+20-b.getDay())}a.input.attr("size",this._formatDate(a,b).length)}},_inlineDatepicker:function(a,
b){var c=d(a);if(!c.hasClass(this.markerClassName)){c.addClass(this.markerClassName).append(b.dpDiv).bind("setData.datepicker",function(e,f,h){b.settings[f]=h}).bind("getData.datepicker",function(e,f){return this._get(b,f)});d.data(a,"datepicker",b);this._setDate(b,this._getDefaultDate(b),true);this._updateDatepicker(b);this._updateAlternate(b);b.settings.disabled&&this._disableDatepicker(a);b.dpDiv.css("display","block")}},_dialogDatepicker:function(a,b,c,e,f){a=this._dialogInst;if(!a){this.uuid+=
b){var c=d(a);if(!c.hasClass(this.markerClassName)){c.addClass(this.markerClassName).append(b.dpDiv).bind("setRawData.datepicker",function(e,f,h){b.settings[f]=h}).bind("getRawData.datepicker",function(e,f){return this._get(b,f)});d.data(a,"datepicker",b);this._setDate(b,this._getDefaultDate(b),true);this._updateDatepicker(b);this._updateAlternate(b);b.settings.disabled&&this._disableDatepicker(a);b.dpDiv.css("display","block")}},_dialogDatepicker:function(a,b,c,e,f){a=this._dialogInst;if(!a){this.uuid+=
1;this._dialogInput=d('<input type="text" id="'+("dp"+this.uuid)+'" style="position: absolute; top: -100px; width: 0px; z-index: -10;"/>');this._dialogInput.keydown(this._doKeyDown);d("body").append(this._dialogInput);a=this._dialogInst=this._newInst(this._dialogInput,false);a.settings={};d.data(this._dialogInput[0],"datepicker",a)}H(a.settings,e||{});b=b&&b.constructor==Date?this._formatDate(a,b):b;this._dialogInput.val(b);this._pos=f?f.length?f:[f.pageX,f.pageY]:null;if(!this._pos)this._pos=[document.documentElement.clientWidth/
2-100+(document.documentElement.scrollLeft||document.body.scrollLeft),document.documentElement.clientHeight/2-150+(document.documentElement.scrollTop||document.body.scrollTop)];this._dialogInput.css("left",this._pos[0]+20+"px").css("top",this._pos[1]+"px");a.settings.onSelect=c;this._inDialog=true;this.dpDiv.addClass(this._dialogClass);this._showDatepicker(this._dialogInput[0]);d.blockUI&&d.blockUI(this.dpDiv);d.data(this._dialogInput[0],"datepicker",a);return this},_destroyDatepicker:function(a){var b=
d(a),c=d.data(a,"datepicker");if(b.hasClass(this.markerClassName)){var e=a.nodeName.toLowerCase();d.removeData(a,"datepicker");if(e=="input"){c.append.remove();c.trigger.remove();b.removeClass(this.markerClassName).unbind("focus",this._showDatepicker).unbind("keydown",this._doKeyDown).unbind("keypress",this._doKeyPress).unbind("keyup",this._doKeyUp)}else if(e=="div"||e=="span")b.removeClass(this.markerClassName).empty()}},_enableDatepicker:function(a){var b=d(a),c=d.data(a,"datepicker");if(b.hasClass(this.markerClassName)){var e=