com.freedomotic.things.impl.Person Maven / Gradle / Ivy
The newest version!
/**
*
* Copyright (c) 2009-2014 Freedomotic team
* http://freedomotic.com
*
* This file is part of Freedomotic
*
* This Program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2, or (at your option)
* any later version.
*
* This Program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Freedomotic; see the file COPYING. If not, see
* .
*/
package com.freedomotic.things.impl;
import com.freedomotic.things.GenericPerson;
import com.freedomotic.events.ObjectReceiveClick;
import com.freedomotic.model.ds.Config;
import com.freedomotic.model.object.BooleanBehavior;
import com.freedomotic.model.object.ListBehavior;
import com.freedomotic.model.object.PropertiesBehavior;
import com.freedomotic.behaviors.BooleanBehaviorLogic;
import com.freedomotic.behaviors.ListBehaviorLogic;
import com.freedomotic.behaviors.PropertiesBehaviorLogic;
import com.freedomotic.reactions.Trigger;
import com.freedomotic.reactions.TriggerPersistence;
import java.util.logging.Logger;
/**
*
* @author Enrico
*/
public class Person extends GenericPerson {
protected BooleanBehaviorLogic present;
protected ListBehaviorLogic activity;
protected PropertiesBehaviorLogic properties;
private static final String BEHAVIOR_PRESENT = "present";
private static final String BEHAVIOR_PROPERTIES = "properties";
private static final String BEHAVIOR_ACTIVITY = "activity";
@Override
public void init() {
present = new BooleanBehaviorLogic((BooleanBehavior) getPojo().getBehavior(BEHAVIOR_PRESENT));
//add a listener to values changes
present.addListener(new BooleanBehaviorLogic.Listener() {
@Override
public void onTrue(Config params, boolean fireCommand) {
setPresent();
}
@Override
public void onFalse(Config params, boolean fireCommand) {
setNotPresent();
}
});
activity = new ListBehaviorLogic((ListBehavior) getPojo().getBehavior(BEHAVIOR_ACTIVITY));
activity.addListener(new ListBehaviorLogic.Listener() {
@Override
public void selectedChanged(Config params, boolean fireCommand) {
String oldActivity = activity.getSelected();
//in "value" property is stored the name of the new selection. It is a value from the list for sure and it is not the current one, already checked.
activity.setSelected(params.getProperty("value"));
LOG.severe("Person '" + getPojo().getName()
+ "' has changed its activity from " + oldActivity + " to "
+ activity.getSelected());
setChanged(true);
}
});
properties = new PropertiesBehaviorLogic((PropertiesBehavior) getPojo().getBehavior(BEHAVIOR_PROPERTIES));
properties.addListener(new PropertiesBehaviorLogic.Listener() {
@Override
public void propertyChanged(String key, String newValue, Config params, boolean fireCommand) {
//in "value" property is stored the name of the new selection. It is a value from the list for sure and it is not the current one, already checked.
// properties.setProperty(key, newValue);
LOG.severe("Person '" + getPojo().getName()
+ "' has changed its property from " + params.getProperty(key) + " to "
+ newValue);
setChanged(true);
}
});
//register this behavior to the superclass to make it visible to it
registerBehavior(present);
registerBehavior(activity);
registerBehavior(properties);
//caches hardware level commands and builds user command
super.init();
}
private void setPresent() {
present.setValue(true);
getPojo().setCurrentRepresentation(1);
setChanged(true);
}
private void setNotPresent() {
present.setValue(false);
getPojo().setCurrentRepresentation(0);
setChanged(true);
}
/**
*
*/
@Override
protected void createCommands() {
}
/**
*
*/
@Override
protected void createTriggers() {
Trigger clicked = new Trigger();
clicked.setName("When " + this.getPojo().getName() + " is clicked");
clicked.setChannel("app.event.sensor.object.behavior.clicked");
clicked.getPayload().addStatement("object.name",
this.getPojo().getName());
clicked.getPayload().addStatement("click", ObjectReceiveClick.SINGLE_CLICK);
clicked.setPersistence(false);
TriggerPersistence.add(clicked);
}
private static final Logger LOG = Logger.getLogger(Person.class.getName());
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy