added non-track contact to tiles, re-implementes PowerOff to SetPower
This commit is contained in:
2
pom.xml
2
pom.xml
@@ -4,7 +4,7 @@
|
|||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>de.srsoftware</groupId>
|
<groupId>de.srsoftware</groupId>
|
||||||
<artifactId>web4rail</artifactId>
|
<artifactId>web4rail</artifactId>
|
||||||
<version>0.10.11</version>
|
<version>0.10.12</version>
|
||||||
<name>Web4Rail</name>
|
<name>Web4Rail</name>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
<description>Java Model Railway Control</description>
|
<description>Java Model Railway Control</description>
|
||||||
|
|||||||
@@ -59,13 +59,14 @@ new train : neuer Zug
|
|||||||
No : keine
|
No : keine
|
||||||
No free routes from {} : keine Route von {} frei
|
No free routes from {} : keine Route von {} frei
|
||||||
NORTH : Norden
|
NORTH : Norden
|
||||||
|
Off : Aus
|
||||||
|
On : An
|
||||||
One way\: : Richtung:
|
One way\: : Richtung:
|
||||||
Online Documentation : Online-Dokumentation
|
Online Documentation : Online-Dokumentation
|
||||||
other train properties : andere Zug-Eigenschaften
|
other train properties : andere Zug-Eigenschaften
|
||||||
Origin and destination : Start und Ziel
|
Origin and destination : Start und Ziel
|
||||||
Origin\: {} to {} : Start: {} nach {}
|
Origin\: {} to {} : Start: {} nach {}
|
||||||
Plan saved as "{}". : Plan als „{}“ gespeichert.
|
Plan saved as "{}". : Plan als „{}“ gespeichert.
|
||||||
PowerOff : Strom abschalten
|
|
||||||
Properties : Eigenschaften
|
Properties : Eigenschaften
|
||||||
Properties of {} : Eigenschaften von {}
|
Properties of {} : Eigenschaften von {}
|
||||||
Properties of {} @ ({},{}) : Eigenschaften von {} @ ({},{})
|
Properties of {} @ ({},{}) : Eigenschaften von {} @ ({},{})
|
||||||
@@ -84,6 +85,7 @@ SetRelay : Relais schalten
|
|||||||
SetSignalsToStop : Signale auf Halt stellen
|
SetSignalsToStop : Signale auf Halt stellen
|
||||||
SetSpeed : Geschwindigkeit ändern
|
SetSpeed : Geschwindigkeit ändern
|
||||||
Set {} to {} : {} auf {} setzen
|
Set {} to {} : {} auf {} setzen
|
||||||
|
SetPower : Strom schalten
|
||||||
Set speed to : Geschwindigkeit setzen
|
Set speed to : Geschwindigkeit setzen
|
||||||
Setup actions : Aktivierungs-Aktionen
|
Setup actions : Aktivierungs-Aktionen
|
||||||
Signals : Signale
|
Signals : Signale
|
||||||
@@ -92,8 +94,11 @@ Started {} : {} gestartet
|
|||||||
StopAuto : Automatikmodus abschalten
|
StopAuto : Automatikmodus abschalten
|
||||||
Straight port\: : Port für gerade
|
Straight port\: : Port für gerade
|
||||||
STRAIGHT : gerade
|
STRAIGHT : gerade
|
||||||
|
Switch power off : Strom ausschalten
|
||||||
|
Switch power on : Strom anschalten
|
||||||
Tags : Markierungen
|
Tags : Markierungen
|
||||||
Toggle power : Stom an/ausschalten
|
Toggle : umschalten
|
||||||
|
Toggle power : Stom umschalten
|
||||||
Train\: : Zug:
|
Train\: : Zug:
|
||||||
train does not have tag "{}" : Zug hat keine Markierung „{}“
|
train does not have tag "{}" : Zug hat keine Markierung „{}“
|
||||||
train has tag "{}" : Zug hat Markierung „{}“
|
train has tag "{}" : Zug hat Markierung „{}“
|
||||||
|
|||||||
@@ -157,7 +157,7 @@ public class ControlUnit extends Thread implements Constants{
|
|||||||
restart();
|
restart();
|
||||||
return t("Control unit (re)started.");
|
return t("Control unit (re)started.");
|
||||||
case ACTION_EMERGENCY:
|
case ACTION_EMERGENCY:
|
||||||
return emergency();
|
return set(false);
|
||||||
case ACTION_POWER:
|
case ACTION_POWER:
|
||||||
return togglePower();
|
return togglePower();
|
||||||
case ACTION_PROPS:
|
case ACTION_PROPS:
|
||||||
@@ -169,15 +169,6 @@ public class ControlUnit extends Thread implements Constants{
|
|||||||
return t("Unknown action: {}",params.get(ACTION));
|
return t("Unknown action: {}",params.get(ACTION));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* turn of power immediately
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Object emergency() {
|
|
||||||
power = true;
|
|
||||||
return togglePower();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* generate a properties view for the client
|
* generate a properties view for the client
|
||||||
* @return
|
* @return
|
||||||
@@ -268,6 +259,15 @@ public class ControlUnit extends Thread implements Constants{
|
|||||||
command.readReplyFrom(commandScanner);
|
command.readReplyFrom(commandScanner);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* set power state
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Object set(boolean on) {
|
||||||
|
power = !on;
|
||||||
|
return togglePower();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* set up the connection endpoint
|
* set up the connection endpoint
|
||||||
* @param newHost
|
* @param newHost
|
||||||
@@ -352,7 +352,7 @@ public class ControlUnit extends Thread implements Constants{
|
|||||||
* togge power on/off at the SRCP daemon
|
* togge power on/off at the SRCP daemon
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
private Command togglePower() {
|
public Command togglePower() {
|
||||||
power = !power;
|
power = !power;
|
||||||
String PW = power?"ON":"OFF";
|
String PW = power?"ON":"OFF";
|
||||||
Command command = new Command("SET {} POWER "+PW) {
|
Command command = new Command("SET {} POWER "+PW) {
|
||||||
|
|||||||
@@ -783,6 +783,7 @@ public class Plan extends BaseClass{
|
|||||||
new TurnoutLE().tag(null).addTo(tiles);
|
new TurnoutLE().tag(null).addTo(tiles);
|
||||||
new Turnout3E().tag(null).addTo(tiles);
|
new Turnout3E().tag(null).addTo(tiles);
|
||||||
new Relay().setLabel(true,"RL").tag(null).addTo(tiles);
|
new Relay().setLabel(true,"RL").tag(null).addTo(tiles);
|
||||||
|
new Contact().tag(null).addTo(tiles);
|
||||||
new Eraser().tag(null).addTo(tiles);
|
new Eraser().tag(null).addTo(tiles);
|
||||||
return tiles.addTo(tileMenu);
|
return tiles.addTo(tileMenu);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -108,7 +108,7 @@ public abstract class Action extends BaseClass {
|
|||||||
TriggerContact.class,
|
TriggerContact.class,
|
||||||
TurnTrain.class,
|
TurnTrain.class,
|
||||||
StopAuto.class,
|
StopAuto.class,
|
||||||
PowerOff.class,
|
SetPower.class,
|
||||||
SetRelay.class,
|
SetRelay.class,
|
||||||
DelayedAction.class
|
DelayedAction.class
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -1,10 +0,0 @@
|
|||||||
package de.srsoftware.web4rail.actions;
|
|
||||||
|
|
||||||
public class PowerOff extends Action{
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean fire(Context context) {
|
|
||||||
context.contact.plan().controlUnit().emergency();
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
94
src/main/java/de/srsoftware/web4rail/actions/SetPower.java
Normal file
94
src/main/java/de/srsoftware/web4rail/actions/SetPower.java
Normal file
@@ -0,0 +1,94 @@
|
|||||||
|
package de.srsoftware.web4rail.actions;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import de.srsoftware.tools.Tag;
|
||||||
|
import de.srsoftware.web4rail.ControlUnit;
|
||||||
|
import de.srsoftware.web4rail.Window;
|
||||||
|
import de.srsoftware.web4rail.tags.Button;
|
||||||
|
import de.srsoftware.web4rail.tags.Form;
|
||||||
|
import de.srsoftware.web4rail.tags.Input;
|
||||||
|
import de.srsoftware.web4rail.tags.Radio;
|
||||||
|
|
||||||
|
public class SetPower extends Action{
|
||||||
|
|
||||||
|
private static final String STATE = "state";
|
||||||
|
private POWERCHANGE pc = POWERCHANGE.OFF;
|
||||||
|
|
||||||
|
enum POWERCHANGE {
|
||||||
|
ON, OFF, TOGGLE;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean fire(Context context) {
|
||||||
|
ControlUnit cu = context.contact.plan().controlUnit();
|
||||||
|
switch (pc) {
|
||||||
|
case ON:
|
||||||
|
cu.set(true);
|
||||||
|
break;
|
||||||
|
case TOGGLE:
|
||||||
|
cu.togglePower();
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
cu.set(false);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public JSONObject json() {
|
||||||
|
JSONObject json = super.json();
|
||||||
|
json.put(STATE, pc);
|
||||||
|
return json;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Action load(JSONObject json) {
|
||||||
|
super.load(json);
|
||||||
|
pc = POWERCHANGE.valueOf(json.getString(STATE));
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Window properties(HashMap<String, String> params) {
|
||||||
|
Window win = super.properties(params);
|
||||||
|
Form form = new Form("action-prop-form-"+id);
|
||||||
|
new Input(REALM,REALM_ACTIONS).hideIn(form);
|
||||||
|
new Input(ID,params.get(ID)).hideIn(form);
|
||||||
|
new Input(ACTION,ACTION_UPDATE).hideIn(form);
|
||||||
|
new Input(CONTEXT,params.get(CONTEXT)).hideIn(form);
|
||||||
|
|
||||||
|
new Radio(STATE, POWERCHANGE.ON, t("On"), pc == POWERCHANGE.ON).addTo(form);
|
||||||
|
new Radio(STATE, POWERCHANGE.OFF, t("Off"), pc == POWERCHANGE.OFF).addTo(form);
|
||||||
|
new Radio(STATE, POWERCHANGE.TOGGLE, t("Toggle"), pc == POWERCHANGE.TOGGLE).addTo(form);
|
||||||
|
|
||||||
|
new Button(t("Apply"),form).addTo(form).addTo(win);
|
||||||
|
return win;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
switch (pc) {
|
||||||
|
case ON:
|
||||||
|
return t("Switch power on");
|
||||||
|
case OFF:
|
||||||
|
return t("Switch power off");
|
||||||
|
default:
|
||||||
|
return t("Toggle power");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Object update(HashMap<String, String> params) {
|
||||||
|
LOG.debug("update: {}",params);
|
||||||
|
String error = null;
|
||||||
|
String newState = params.get(STATE);
|
||||||
|
if (isSet(newState)) pc = POWERCHANGE.valueOf(newState);
|
||||||
|
Window win = properties(params);
|
||||||
|
return new Tag("span").content(error).addTo(win);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -37,7 +37,6 @@ public class SetSpeed extends Action{
|
|||||||
super.load(json);
|
super.load(json);
|
||||||
maxSpeed = json.getInt(MAX_SPEED);
|
maxSpeed = json.getInt(MAX_SPEED);
|
||||||
return this;
|
return this;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -6,9 +6,9 @@ public class Radio extends Tag {
|
|||||||
|
|
||||||
private static final long serialVersionUID = -7291730168237304236L;
|
private static final long serialVersionUID = -7291730168237304236L;
|
||||||
|
|
||||||
public Radio(String groupName, String value, String label, boolean preCheck) {
|
public Radio(String groupName, Object value, String label, boolean preCheck) {
|
||||||
super("label");
|
super("label");
|
||||||
Tag radio = new Tag("input").attr("type", "radio").attr("name", groupName).attr("value", value);
|
Tag radio = new Tag("input").attr("type", "radio").attr("name", groupName).attr("value", ""+value);
|
||||||
if (preCheck) radio.attr("checked", "checked");
|
if (preCheck) radio.attr("checked", "checked");
|
||||||
radio.addTo(this);
|
radio.addTo(this);
|
||||||
content(label);
|
content(label);
|
||||||
|
|||||||
@@ -10,13 +10,16 @@ import java.util.TreeMap;
|
|||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
|
|
||||||
import de.srsoftware.tools.Tag;
|
import de.srsoftware.tools.Tag;
|
||||||
|
import de.srsoftware.web4rail.Window;
|
||||||
|
import de.srsoftware.web4rail.actions.Action.Context;
|
||||||
|
import de.srsoftware.web4rail.actions.ActionList;
|
||||||
import de.srsoftware.web4rail.tags.Button;
|
import de.srsoftware.web4rail.tags.Button;
|
||||||
import de.srsoftware.web4rail.tags.Form;
|
import de.srsoftware.web4rail.tags.Form;
|
||||||
import de.srsoftware.web4rail.tags.Input;
|
import de.srsoftware.web4rail.tags.Input;
|
||||||
import de.srsoftware.web4rail.tags.Label;
|
import de.srsoftware.web4rail.tags.Label;
|
||||||
import de.srsoftware.web4rail.tags.Select;
|
import de.srsoftware.web4rail.tags.Select;
|
||||||
|
|
||||||
public abstract class Contact extends Tile{
|
public class Contact extends Tile{
|
||||||
|
|
||||||
private static final String ADDRESS = "address";
|
private static final String ADDRESS = "address";
|
||||||
private static final HashMap<String, Contact> contactsById = new HashMap<String, Contact>();
|
private static final HashMap<String, Contact> contactsById = new HashMap<String, Contact>();
|
||||||
@@ -24,27 +27,17 @@ public abstract class Contact extends Tile{
|
|||||||
private boolean active = false;
|
private boolean active = false;
|
||||||
private String trigger = null;
|
private String trigger = null;
|
||||||
private int addr = 0;
|
private int addr = 0;
|
||||||
|
private ActionList actions = new ActionList();
|
||||||
public void trigger(int duration) throws IOException {
|
|
||||||
activate(true);
|
|
||||||
new Thread() {
|
|
||||||
public void run() {
|
|
||||||
try {
|
|
||||||
sleep(duration);
|
|
||||||
activate(false);
|
|
||||||
} catch (Exception e) {}
|
|
||||||
}
|
|
||||||
}.start();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void activate(boolean active) {
|
public void activate(boolean active) {
|
||||||
this.active = active;
|
this.active = active;
|
||||||
if (active) {
|
if (active) {
|
||||||
if (route == null) {
|
if (isSet(route)) {
|
||||||
plan.warn(this);
|
|
||||||
} else {
|
|
||||||
route.contact(this);
|
route.contact(this);
|
||||||
|
} else if (getClass() != Contact.class) {
|
||||||
|
plan.warn(this);
|
||||||
}
|
}
|
||||||
|
actions.fire(new Context(this));
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
stream();
|
stream();
|
||||||
@@ -129,6 +122,26 @@ public abstract class Contact extends Tile{
|
|||||||
return form;
|
return form;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Window propMenu() {
|
||||||
|
Window win = super.propMenu();
|
||||||
|
new Tag("h4").content(t("Actions")).addTo(win);
|
||||||
|
actions.addTo(win, REALM_PLAN+":"+id());
|
||||||
|
return win;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Select selector(Contact preselect) {
|
||||||
|
TreeMap<String,Contact> sortedSet = new TreeMap<String, Contact>(); // Map from Name to Contact
|
||||||
|
for (Contact contact : contactsById.values()) sortedSet.put(contact.toString(), contact);
|
||||||
|
Select select = new Select(CONTACT);
|
||||||
|
for (Entry<String, Contact> entry : sortedSet.entrySet()) {
|
||||||
|
Contact contact = entry.getValue();
|
||||||
|
Tag option = select.addOption(contact.id(),contact);
|
||||||
|
if (contact == preselect) option.attr("selected", "selected");
|
||||||
|
}
|
||||||
|
return select;
|
||||||
|
}
|
||||||
|
|
||||||
public void stream() throws IOException {
|
public void stream() throws IOException {
|
||||||
Tag tag = super.tag(null);
|
Tag tag = super.tag(null);
|
||||||
if (active) tag.clazz(tag.get("class")+" active");
|
if (active) tag.clazz(tag.get("class")+" active");
|
||||||
@@ -146,21 +159,20 @@ public abstract class Contact extends Tile{
|
|||||||
return trigger;
|
return trigger;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void trigger(int duration) throws IOException {
|
||||||
|
activate(true);
|
||||||
|
new Thread() {
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
sleep(duration);
|
||||||
|
activate(false);
|
||||||
|
} catch (Exception e) {}
|
||||||
|
}
|
||||||
|
}.start();
|
||||||
|
}
|
||||||
@Override
|
@Override
|
||||||
public Tile update(HashMap<String, String> params) throws IOException {
|
public Tile update(HashMap<String, String> params) throws IOException {
|
||||||
if (params.containsKey(ADDRESS)) addr(Integer.parseInt(params.get(ADDRESS)));
|
if (params.containsKey(ADDRESS)) addr(Integer.parseInt(params.get(ADDRESS)));
|
||||||
return super.update(params);
|
return super.update(params);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Select selector(Contact preselect) {
|
|
||||||
TreeMap<String,Contact> sortedSet = new TreeMap<String, Contact>(); // Map from Name to Contact
|
|
||||||
for (Contact contact : contactsById.values()) sortedSet.put(contact.toString(), contact);
|
|
||||||
Select select = new Select(CONTACT);
|
|
||||||
for (Entry<String, Contact> entry : sortedSet.entrySet()) {
|
|
||||||
Contact contact = entry.getValue();
|
|
||||||
Tag option = select.addOption(contact.id(),contact);
|
|
||||||
if (contact == preselect) option.attr("selected", "selected");
|
|
||||||
}
|
|
||||||
return select;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -212,7 +212,7 @@ public abstract class Tile extends BaseClass{
|
|||||||
return form;
|
return form;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Tag propMenu() {
|
public Window propMenu() {
|
||||||
Window window = new Window("tile-properties",t("Properties of {} @ ({},{})",title(),x,y));
|
Window window = new Window("tile-properties",t("Properties of {} @ ({},{})",title(),x,y));
|
||||||
|
|
||||||
if (isSet(train)) {
|
if (isSet(train)) {
|
||||||
|
|||||||
Reference in New Issue
Block a user