Modifying 'Slightly smarter use of motion sensor'

This commit is contained in:
PASCI
2017-01-10 09:55:02 -08:00
parent 4b8e94b7ca
commit 93219abcc8

View File

@@ -1,8 +1,9 @@
//==================================================================================
/** /**
* Motion-Switch-Sched SmartApp * Motion-Switch-Sched SmartApp
* *
* Copyright 2017 PASCI Ciro Ippolito 2017 * Copyright 2017 PASCI Ciro Ippolito 2017
* ***********************************************************************************
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at: * in compliance with the License. You may obtain a copy of the License at:
* *
@@ -13,6 +14,7 @@
* for the specific language governing permissions and limitations under the License. * for the specific language governing permissions and limitations under the License.
* *
*/ */
//==================================================================================
definition( definition(
name: "Motion Switch SmartTimeframe", name: "Motion Switch SmartTimeframe",
namespace: "PASCI", namespace: "PASCI",
@@ -26,6 +28,7 @@ definition(
//iconUrl: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience.png", //iconUrl: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience.png",
//iconX2Url: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience@2x.png", //iconX2Url: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience@2x.png",
//iconX3Url: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience@2x.png") //iconX3Url: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience@2x.png")
//==================================================================================
preferences { preferences {
section("When MOTION is detected") { section("When MOTION is detected") {
input "themotion", "capability.motionSensor", required: true, title: "WHERE" input "themotion", "capability.motionSensor", required: true, title: "WHERE"
@@ -41,30 +44,36 @@ preferences {
input "TOTime", "time", title: "To", required: true input "TOTime", "time", title: "To", required: true
} }
} }
//==================================================================================
def installed() { def installed() {
log.debug "Installed with settings: ${settings}" log.debug "Installed with settings: ${settings}"
initialize() initialize()
} }
//==================================================================================
def updated() { def updated() {
log.debug "Updated with settings: ${settings}" log.debug "Updated with settings: ${settings}"
unsubscribe() unsubscribe()
initialize() initialize()
} }
//==================================================================================
def initialize() { def initialize() {
log.debug "Installata at: " + now() log.debug "Installata at: " + now()
schedule(FROMTime, handlerFROMTIME) schedule(FROMTime, handlerFROMTIME)
schedule(TOTime, handlerTOTime) schedule(TOTime, handlerTOTime)
subscribe(themotion, "motion", motionDetectedHandler) subscribe(themotion, "motion.active", handler_Motion___Active)
subscribe(themotion, "motion.inactive", handler_motion_inactive)
} }
// HANDLERS // HANDLERS
//==================================================================================
def handlerFROMTIME() { def handlerFROMTIME() {
log.debug "TURN ON at ${new Date()}" log.debug "FROM TIME at ${new Date()}"
OUTLE.on() OUTLE.on()
} }
//==================================================================================
def handlerTOTime() { def handlerTOTime() {
log.debug "TO TIME at ${new Date()}"
checkMotion();
/*
def motionState = themotion.currentState("motion") def motionState = themotion.currentState("motion")
log.debug "state of motion sensor is: " + motionState.value log.debug "state of motion sensor is: " + motionState.value
log.debug "TURN OFF at ${new Date()}" log.debug "TURN OFF at ${new Date()}"
@@ -75,19 +84,42 @@ def handlerTOTime() {
OUTLE.off() OUTLE.off()
log.debug "state of motion sensor is INACTIVE" log.debug "state of motion sensor is INACTIVE"
} }
*/
} }
def motionDetectedHandler(evt) { //==================================================================================
log.debug "motionDetectedHandler called: $evt" def handler_Motion___Active(evt) {
log.debug "INACTIVE"; log.debug("MOT Active")
def between = timeOfDayIsBetween(FROMTime, TOTime, new Date(), location.timeZone) OUTLE.on()
}
//==================================================================================
def handler_motion_inactive(evt) {
log.debug("MOT Inactive")
def between = timeOfDayIsBetween(FROMTime, TOTime, new Date(), location.timeZone)
if (between) { if (between) {
log.debug("It dasan't mattar Christopha")
OUTLE.on() OUTLE.on()
} else { } else {
if (evt.value == "active"){ runIn(60 * minutes, checkMotion)
log.debug "ACTIVE";
OUTLE.on()
}else{
OUTLE.off()
}
} }
} }
//==================================================================================
def checkMotion() {
log.debug "In checkMotion scheduled method"
// get the current state object for the motion sensor
def motionState = themotion.currentState("motion")
if (motionState.value == "inactive") {
def elapsed = now() - motionState.date.time // time elapsed between now and when the motion reported inactive
def threshold = 1000 * 60 * minutes // elapsed time is in milliseconds
if (elapsed >= threshold) {
log.debug "Motion has stayed inactive long enough since last check ($elapsed ms): turning switch off"
OUTLE.off()
} else {
log.debug "Motion has not stayed inactive long enough since last check ($elapsed ms): doing nothing"
}
} else {
// Motion active; just log it and do nothing
log.debug "Motion is active, do nothing and wait for inactive"
}
}
//==================================================================================
//==================================================================================