Persist selected state of controls across simulator restarts
This commit is contained in:
parent
d7f46c0fb5
commit
f30eac41e9
@ -81,7 +81,6 @@ namespace pxsim.control {
|
|||||||
export function dmesg(s: string) {
|
export function dmesg(s: string) {
|
||||||
console.log("DMESG: " + s)
|
console.log("DMESG: " + s)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace pxsim.output {
|
namespace pxsim.output {
|
||||||
|
@ -340,6 +340,28 @@ namespace pxsim.visuals {
|
|||||||
cancelAnimationFrame(animationId);
|
cancelAnimationFrame(animationId);
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
// Save previous inputs for the next cycle
|
||||||
|
EV3View.previousSelectedInputs = ev3board().getInputNodes().map((node, index) => (this.getDisplayViewForNode(node.id, index).getSelected()) ? node.id : -1)
|
||||||
|
EV3View.previousSeletedOutputs = ev3board().getMotors().map((node, index) => (this.getDisplayViewForNode(node.id, index).getSelected()) ? node.id : -1);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static previousSelectedInputs: number[];
|
||||||
|
private static previousSeletedOutputs: number[];
|
||||||
|
|
||||||
|
private static isPreviousInputSelected(index: number, id: number) {
|
||||||
|
if (EV3View.previousSelectedInputs && EV3View.previousSelectedInputs[index] == id) {
|
||||||
|
EV3View.previousSelectedInputs[index] = undefined;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static isPreviousOutputSelected(index: number, id: number) {
|
||||||
|
if (EV3View.previousSeletedOutputs && EV3View.previousSeletedOutputs[index] == id) {
|
||||||
|
EV3View.previousSeletedOutputs[index] = undefined;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private begin() {
|
private begin() {
|
||||||
@ -382,7 +404,9 @@ namespace pxsim.visuals {
|
|||||||
const view = this.getDisplayViewForNode(node.id, index);
|
const view = this.getDisplayViewForNode(node.id, index);
|
||||||
if (!node.didChange() && !view.didChange()) return;
|
if (!node.didChange() && !view.didChange()) return;
|
||||||
if (view) {
|
if (view) {
|
||||||
const control = view.getSelected() ? this.getControlForNode(node.id, index) : undefined;
|
const isSelected = EV3View.isPreviousInputSelected(index, node.id) || view.getSelected();
|
||||||
|
if (isSelected && !view.getSelected()) view.setSelected(true);
|
||||||
|
const control = isSelected ? this.getControlForNode(node.id, index) : undefined;
|
||||||
const closeIcon = control ? this.getCloseIconView() : undefined;
|
const closeIcon = control ? this.getCloseIconView() : undefined;
|
||||||
this.layoutView.setInput(index, view, control, closeIcon);
|
this.layoutView.setInput(index, view, control, closeIcon);
|
||||||
view.updateState();
|
view.updateState();
|
||||||
@ -401,7 +425,9 @@ namespace pxsim.visuals {
|
|||||||
const view = this.getDisplayViewForNode(node.id, index);
|
const view = this.getDisplayViewForNode(node.id, index);
|
||||||
if (!node.didChange() && !view.didChange()) return;
|
if (!node.didChange() && !view.didChange()) return;
|
||||||
if (view) {
|
if (view) {
|
||||||
const control = view.getSelected() ? this.getControlForNode(node.id, index) : undefined;
|
const isSelected = EV3View.isPreviousOutputSelected(index, node.id) || view.getSelected();
|
||||||
|
if (isSelected && !view.getSelected()) view.setSelected(true);
|
||||||
|
const control = isSelected ? this.getControlForNode(node.id, index) : undefined;
|
||||||
const closeIcon = control ? this.getCloseIconView() : undefined;
|
const closeIcon = control ? this.getCloseIconView() : undefined;
|
||||||
this.layoutView.setOutput(index, view, control, closeIcon);
|
this.layoutView.setOutput(index, view, control, closeIcon);
|
||||||
view.updateState();
|
view.updateState();
|
||||||
|
@ -14,6 +14,7 @@ namespace pxsim.visuals {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public updateState() {
|
public updateState() {
|
||||||
|
super.updateState();
|
||||||
// TODO: show different color modes
|
// TODO: show different color modes
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -10,6 +10,7 @@ namespace pxsim.visuals {
|
|||||||
}
|
}
|
||||||
|
|
||||||
updateState() {
|
updateState() {
|
||||||
|
super.updateState();
|
||||||
const motorState = ev3board().getMotors()[this.port];
|
const motorState = ev3board().getMotors()[this.port];
|
||||||
if (!motorState) return;
|
if (!motorState) return;
|
||||||
const speed = motorState.getSpeed();
|
const speed = motorState.getSpeed();
|
||||||
|
@ -20,6 +20,7 @@ namespace pxsim.visuals {
|
|||||||
}
|
}
|
||||||
|
|
||||||
updateState() {
|
updateState() {
|
||||||
|
super.updateState();
|
||||||
const motorState = ev3board().getMotors()[this.port];
|
const motorState = ev3board().getMotors()[this.port];
|
||||||
if (!motorState) return;
|
if (!motorState) return;
|
||||||
const speed = motorState.getSpeed();
|
const speed = motorState.getSpeed();
|
||||||
|
@ -4,7 +4,8 @@ namespace pxsim.visuals {
|
|||||||
protected content: SVGSVGElement;
|
protected content: SVGSVGElement;
|
||||||
|
|
||||||
protected controlShown: boolean;
|
protected controlShown: boolean;
|
||||||
protected selected: boolean;
|
|
||||||
|
protected opacity: number;
|
||||||
|
|
||||||
constructor(protected xml: string, protected prefix: string, protected id: NodeType, protected port: NodeType) {
|
constructor(protected xml: string, protected prefix: string, protected id: NodeType, protected port: NodeType) {
|
||||||
super();
|
super();
|
||||||
@ -106,19 +107,24 @@ namespace pxsim.visuals {
|
|||||||
this.updateOpacity();
|
this.updateOpacity();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public updateState() {
|
||||||
|
this.updateOpacity();
|
||||||
|
}
|
||||||
|
|
||||||
protected updateOpacity() {
|
protected updateOpacity() {
|
||||||
if (this.rendered) {
|
if (this.rendered) {
|
||||||
const opacity = this.selected ? "0.2" : "1";
|
const opacity = this.selected ? 0.2 : 1;
|
||||||
if (this.hasClick()) {
|
if (this.hasClick() && this.opacity != opacity) {
|
||||||
this.setOpacity(opacity);
|
this.opacity = opacity;
|
||||||
|
this.setOpacity(this.opacity);
|
||||||
if (this.selected) this.content.style.cursor = "";
|
if (this.selected) this.content.style.cursor = "";
|
||||||
else this.content.style.cursor = "pointer";
|
else this.content.style.cursor = "pointer";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected setOpacity(opacity: string) {
|
protected setOpacity(opacity: number) {
|
||||||
this.element.setAttribute("opacity", opacity);
|
this.element.setAttribute("opacity", `${opacity}`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -219,7 +219,6 @@ namespace pxsim.visuals {
|
|||||||
this.changed = false;
|
this.changed = false;
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export abstract class SimView<T extends BaseNode> extends View implements LayoutElement {
|
export abstract class SimView<T extends BaseNode> extends View implements LayoutElement {
|
||||||
|
Loading…
Reference in New Issue
Block a user