Browse Source

added non-track contact to tiles, re-implementes PowerOff to SetPower

lookup-tables
Stephan Richter 5 years ago
parent
commit
880ef561dd
  1. 2
      pom.xml
  2. 9
      resources/translations/Application.de.translation
  3. 22
      src/main/java/de/srsoftware/web4rail/ControlUnit.java
  4. 1
      src/main/java/de/srsoftware/web4rail/Plan.java
  5. 2
      src/main/java/de/srsoftware/web4rail/actions/Action.java
  6. 10
      src/main/java/de/srsoftware/web4rail/actions/PowerOff.java
  7. 94
      src/main/java/de/srsoftware/web4rail/actions/SetPower.java
  8. 3
      src/main/java/de/srsoftware/web4rail/actions/SetSpeed.java
  9. 4
      src/main/java/de/srsoftware/web4rail/tags/Radio.java
  10. 68
      src/main/java/de/srsoftware/web4rail/tiles/Contact.java
  11. 2
      src/main/java/de/srsoftware/web4rail/tiles/Tile.java

2
pom.xml

@ -4,7 +4,7 @@ @@ -4,7 +4,7 @@
<modelVersion>4.0.0</modelVersion>
<groupId>de.srsoftware</groupId>
<artifactId>web4rail</artifactId>
<version>0.10.11</version>
<version>0.10.12</version>
<name>Web4Rail</name>
<packaging>jar</packaging>
<description>Java Model Railway Control</description>

9
resources/translations/Application.de.translation

@ -59,13 +59,14 @@ new train : neuer Zug @@ -59,13 +59,14 @@ new train : neuer Zug
No : keine
No free routes from {} : keine Route von {} frei
NORTH : Norden
Off : Aus
On : An
One way\: : Richtung:
Online Documentation : Online-Dokumentation
other train properties : andere Zug-Eigenschaften
Origin and destination : Start und Ziel
Origin\: {} to {} : Start: {} nach {}
Plan saved as "{}". : Plan als „{}“ gespeichert.
PowerOff : Strom abschalten
Properties : Eigenschaften
Properties of {} : Eigenschaften von {}
Properties of {} @ ({},{}) : Eigenschaften von {} @ ({},{})
@ -84,6 +85,7 @@ SetRelay : Relais schalten @@ -84,6 +85,7 @@ SetRelay : Relais schalten
SetSignalsToStop : Signale auf Halt stellen
SetSpeed : Geschwindigkeit ändern
Set {} to {} : {} auf {} setzen
SetPower : Strom schalten
Set speed to : Geschwindigkeit setzen
Setup actions : Aktivierungs-Aktionen
Signals : Signale
@ -92,8 +94,11 @@ Started {} : {} gestartet @@ -92,8 +94,11 @@ Started {} : {} gestartet
StopAuto : Automatikmodus abschalten
Straight port\: : Port für gerade
STRAIGHT : gerade
Switch power off : Strom ausschalten
Switch power on : Strom anschalten
Tags : Markierungen
Toggle power : Stom an/ausschalten
Toggle : umschalten
Toggle power : Stom umschalten
Train\: : Zug:
train does not have tag "{}" : Zug hat keine Markierung „{}“
train has tag "{}" : Zug hat Markierung „{}“

22
src/main/java/de/srsoftware/web4rail/ControlUnit.java

@ -157,7 +157,7 @@ public class ControlUnit extends Thread implements Constants{ @@ -157,7 +157,7 @@ public class ControlUnit extends Thread implements Constants{
restart();
return t("Control unit (re)started.");
case ACTION_EMERGENCY:
return emergency();
return set(false);
case ACTION_POWER:
return togglePower();
case ACTION_PROPS:
@ -169,15 +169,6 @@ public class ControlUnit extends Thread implements Constants{ @@ -169,15 +169,6 @@ public class ControlUnit extends Thread implements Constants{
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
* @return
@ -268,6 +259,15 @@ public class ControlUnit extends Thread implements Constants{ @@ -268,6 +259,15 @@ public class ControlUnit extends Thread implements Constants{
command.readReplyFrom(commandScanner);
}
/**
* set power state
* @return
*/
public Object set(boolean on) {
power = !on;
return togglePower();
}
/**
* set up the connection endpoint
* @param newHost
@ -352,7 +352,7 @@ public class ControlUnit extends Thread implements Constants{ @@ -352,7 +352,7 @@ public class ControlUnit extends Thread implements Constants{
* togge power on/off at the SRCP daemon
* @return
*/
private Command togglePower() {
public Command togglePower() {
power = !power;
String PW = power?"ON":"OFF";
Command command = new Command("SET {} POWER "+PW) {

1
src/main/java/de/srsoftware/web4rail/Plan.java

@ -783,6 +783,7 @@ public class Plan extends BaseClass{ @@ -783,6 +783,7 @@ public class Plan extends BaseClass{
new TurnoutLE().tag(null).addTo(tiles);
new Turnout3E().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);
return tiles.addTo(tileMenu);
}

2
src/main/java/de/srsoftware/web4rail/actions/Action.java

@ -108,7 +108,7 @@ public abstract class Action extends BaseClass { @@ -108,7 +108,7 @@ public abstract class Action extends BaseClass {
TriggerContact.class,
TurnTrain.class,
StopAuto.class,
PowerOff.class,
SetPower.class,
SetRelay.class,
DelayedAction.class
);

10
src/main/java/de/srsoftware/web4rail/actions/PowerOff.java

@ -1,10 +0,0 @@ @@ -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

@ -0,0 +1,94 @@ @@ -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);
}
}

3
src/main/java/de/srsoftware/web4rail/actions/SetSpeed.java

@ -36,8 +36,7 @@ public class SetSpeed extends Action{ @@ -36,8 +36,7 @@ public class SetSpeed extends Action{
public Action load(JSONObject json) {
super.load(json);
maxSpeed = json.getInt(MAX_SPEED);
return this;
return this;
}
@Override

4
src/main/java/de/srsoftware/web4rail/tags/Radio.java

@ -6,9 +6,9 @@ public class Radio extends Tag { @@ -6,9 +6,9 @@ public class Radio extends Tag {
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");
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");
radio.addTo(this);
content(label);

68
src/main/java/de/srsoftware/web4rail/tiles/Contact.java

@ -10,13 +10,16 @@ import java.util.TreeMap; @@ -10,13 +10,16 @@ import java.util.TreeMap;
import org.json.JSONObject;
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.Form;
import de.srsoftware.web4rail.tags.Input;
import de.srsoftware.web4rail.tags.Label;
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 HashMap<String, Contact> contactsById = new HashMap<String, Contact>();
@ -24,27 +27,17 @@ public abstract class Contact extends Tile{ @@ -24,27 +27,17 @@ public abstract class Contact extends Tile{
private boolean active = false;
private String trigger = null;
private int addr = 0;
public void trigger(int duration) throws IOException {
activate(true);
new Thread() {
public void run() {
try {
sleep(duration);
activate(false);
} catch (Exception e) {}
}
}.start();
}
private ActionList actions = new ActionList();
public void activate(boolean active) {
this.active = active;
if (active) {
if (route == null) {
plan.warn(this);
} else {
if (isSet(route)) {
route.contact(this);
} else if (getClass() != Contact.class) {
plan.warn(this);
}
actions.fire(new Context(this));
}
try {
stream();
@ -129,6 +122,26 @@ public abstract class Contact extends Tile{ @@ -129,6 +122,26 @@ public abstract class Contact extends Tile{
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 {
Tag tag = super.tag(null);
if (active) tag.clazz(tag.get("class")+" active");
@ -146,21 +159,20 @@ public abstract class Contact extends Tile{ @@ -146,21 +159,20 @@ public abstract class Contact extends Tile{
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
public Tile update(HashMap<String, String> params) throws IOException {
if (params.containsKey(ADDRESS)) addr(Integer.parseInt(params.get(ADDRESS)));
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;
}
}

2
src/main/java/de/srsoftware/web4rail/tiles/Tile.java

@ -212,7 +212,7 @@ public abstract class Tile extends BaseClass{ @@ -212,7 +212,7 @@ public abstract class Tile extends BaseClass{
return form;
}
public Tag propMenu() {
public Window propMenu() {
Window window = new Window("tile-properties",t("Properties of {} @ ({},{})",title(),x,y));
if (isSet(train)) {

Loading…
Cancel
Save