mirror of
https://github.com/mtan93/SmartThingsPublic.git
synced 2026-04-08 06:13:07 +01:00
Modifying 'Slightly smarter use of motion sensor'
This commit is contained in:
@@ -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"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//==================================================================================
|
||||||
|
//==================================================================================
|
||||||
Reference in New Issue
Block a user