//Create a class for power meter
package PowerMeter
-import Timer.SimulatedTimer
+import SmartThing.SmartThing
-public class PowerMeter {
- private String id
- private String label
- private String displayName
- private int power
- private int currentPower
+//Importing mutable integer class
+import MutableInteger.MutableInteger
- PowerMeter(String id, String label, String displayName, int power) {
+public class PowerMeter extends SmartThing {
+ // id, label, and display name of the device
+ StringBuilder id = new StringBuilder()
+ StringBuilder label = new StringBuilder()
+ StringBuilder displayName = new StringBuilder()
+ // Features with numberical values
+ MutableInteger currentPower = new MutableInteger()
+ // Maps from features to values
+ HashMap<String, MutableInteger> deviceIntValuesMap = new HashMap<String, MutableInteger>()
+
+ PowerMeter(Closure sendEvent, StringBuilder id, StringBuilder label, StringBuilder displayName, MutableInteger currentPower) {
+ deviceIntValuesMap = deviceIntValueSmartThing
+ idSmartThing = id
+ labelSmartThing = label
+ displayNameSmartThing = displayName
+ sendEventSmartThings = sendEvent
+
+ // Initialization
this.id = id
this.label = label
this.displayName = displayName
- this.power = power
- }
+ this.currentPower = currentPower
- //By Model Checker
- def setValue(String value) {
- println("the power is changed to $value!")
- this.power = value.toInteger()
- this.currentPower = value.toInteger()
+ deviceIntValuesMap.put("power", currentPower)
}
- def currentValue(String deviceFeature) {
- if (deviceFeature == "power") {
- return power
- }
+ // Methods to return values
+ def getCurrentPower() {
+ return currentPower.getValue()
}
-
- def latestValue(String deviceFeature) {
- if (deviceFeature == "power") {
- return power
- }
- }
-
}