mirror of
https://github.com/mtan93/SmartThingsPublic.git
synced 2026-04-04 06:13:07 +01:00
Compare commits
13 Commits
MSA-950-3
...
PROD_2016.
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
024a6cb698 | ||
|
|
410e9f40cc | ||
|
|
1578c48440 | ||
|
|
7526d2b445 | ||
|
|
caf761c015 | ||
|
|
62a965d90b | ||
|
|
fb9f1dee47 | ||
|
|
3a433d3865 | ||
|
|
8f25ff4434 | ||
|
|
515b268374 | ||
|
|
9b87d39fe8 | ||
|
|
a103d437c2 | ||
|
|
bdd88deb99 |
@@ -9,7 +9,6 @@ metadata {
|
||||
definition (name: "Hue Lux Bulb", namespace: "smartthings", author: "SmartThings") {
|
||||
capability "Switch Level"
|
||||
capability "Actuator"
|
||||
capability "Color Temperature"
|
||||
capability "Switch"
|
||||
capability "Refresh"
|
||||
capability "Sensor"
|
||||
@@ -53,7 +52,7 @@ metadata {
|
||||
}
|
||||
|
||||
main(["switch"])
|
||||
details(["rich-control", "colorTempSliderControl","refresh"])
|
||||
details(["rich-control", "refresh"])
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -1,142 +0,0 @@
|
||||
/**
|
||||
* Copyright 2015 SmartThings
|
||||
*
|
||||
* 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:
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software distributed under the License is distributed
|
||||
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License
|
||||
* for the specific language governing permissions and limitations under the License.
|
||||
*
|
||||
* Virtual Thermostat
|
||||
*
|
||||
* Author: SmartThings
|
||||
*/
|
||||
definition(
|
||||
name: "임희진",
|
||||
namespace: "smartthings",
|
||||
author: "SmartThings",
|
||||
description: "Control a space heater or window air conditioner in conjunction with any temperature sensor, like a SmartSense Multi.",
|
||||
category: "Green Living",
|
||||
iconUrl: "https://s3.amazonaws.com/smartapp-icons/Meta/temp_thermo-switch.png",
|
||||
iconX2Url: "https://s3.amazonaws.com/smartapp-icons/Meta/temp_thermo-switch@2x.png"
|
||||
)
|
||||
|
||||
preferences {
|
||||
section("Choose a temperature sensor... "){
|
||||
input "sensor", "capability.temperatureMeasurement", title: "Sensor"
|
||||
}
|
||||
section("Select the heater or air conditioner outlet(s)... "){
|
||||
input "outlets", "capability.switch", title: "Outlets", multiple: true
|
||||
}
|
||||
section("Set the desired temperature..."){
|
||||
input "setpoint", "decimal", title: "Set Temp"
|
||||
}
|
||||
section("When there's been movement from (optional, leave blank to not require motion)..."){
|
||||
input "motion", "capability.motionSensor", title: "Motion", required: false
|
||||
}
|
||||
section("Within this number of minutes..."){
|
||||
input "minutes", "number", title: "Minutes", required: false
|
||||
}
|
||||
section("But never go below (or above if A/C) this value with or without motion..."){
|
||||
input "emergencySetpoint", "decimal", title: "Emer Temp", required: false
|
||||
}
|
||||
section("Select 'heat' for a heater and 'cool' for an air conditioner..."){
|
||||
input "mode", "enum", title: "Heating or cooling?", options: ["heat","cool"]
|
||||
}
|
||||
}
|
||||
|
||||
def installed()
|
||||
{
|
||||
subscribe(sensor, "temperature", temperatureHandler)
|
||||
if (motion) {
|
||||
subscribe(motion, "motion", motionHandler)
|
||||
}
|
||||
}
|
||||
|
||||
def updated()
|
||||
{
|
||||
unsubscribe()
|
||||
subscribe(sensor, "temperature", temperatureHandler)
|
||||
if (motion) {
|
||||
subscribe(motion, "motion", motionHandler)
|
||||
}
|
||||
}
|
||||
|
||||
def temperatureHandler(evt)
|
||||
{
|
||||
def isActive = hasBeenRecentMotion()
|
||||
if (isActive || emergencySetpoint) {
|
||||
evaluate(evt.doubleValue, isActive ? setpoint : emergencySetpoint)
|
||||
}
|
||||
else {
|
||||
outlets.off()
|
||||
}
|
||||
}
|
||||
|
||||
def motionHandler(evt)
|
||||
{
|
||||
if (evt.value == "active") {
|
||||
def lastTemp = sensor.currentTemperature
|
||||
if (lastTemp != null) {
|
||||
evaluate(lastTemp, setpoint)
|
||||
}
|
||||
} else if (evt.value == "inactive") {
|
||||
def isActive = hasBeenRecentMotion()
|
||||
log.debug "INACTIVE($isActive)"
|
||||
if (isActive || emergencySetpoint) {
|
||||
def lastTemp = sensor.currentTemperature
|
||||
if (lastTemp != null) {
|
||||
evaluate(lastTemp, isActive ? setpoint : emergencySetpoint)
|
||||
}
|
||||
}
|
||||
else {
|
||||
outlets.off()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private evaluate(currentTemp, desiredTemp)
|
||||
{
|
||||
log.debug "EVALUATE($currentTemp, $desiredTemp)"
|
||||
def threshold = 1.0
|
||||
if (mode == "cool") {
|
||||
// air conditioner
|
||||
if (currentTemp - desiredTemp >= threshold) {
|
||||
outlets.on()
|
||||
}
|
||||
else if (desiredTemp - currentTemp >= threshold) {
|
||||
outlets.off()
|
||||
}
|
||||
}
|
||||
else {
|
||||
// heater
|
||||
if (desiredTemp - currentTemp >= threshold) {
|
||||
outlets.on()
|
||||
}
|
||||
else if (currentTemp - desiredTemp >= threshold) {
|
||||
outlets.off()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private hasBeenRecentMotion()
|
||||
{
|
||||
def isActive = false
|
||||
if (motion && minutes) {
|
||||
def deltaMinutes = minutes as Long
|
||||
if (deltaMinutes) {
|
||||
def motionEvents = motion.eventsSince(new Date(now() - (60000 * deltaMinutes)))
|
||||
log.trace "Found ${motionEvents?.size() ?: 0} events in the last $deltaMinutes minutes"
|
||||
if (motionEvents.find { it.value == "active" }) {
|
||||
isActive = true
|
||||
}
|
||||
}
|
||||
}
|
||||
else {
|
||||
isActive = true
|
||||
}
|
||||
isActive
|
||||
}
|
||||
@@ -76,7 +76,7 @@ def mainPage() {
|
||||
}
|
||||
section{
|
||||
input "actionType", "enum", title: "Action?", required: true, defaultValue: "Bell 1", options: [
|
||||
//"Custom Message",
|
||||
"Custom Message",
|
||||
"Bell 1",
|
||||
"Bell 2",
|
||||
"Dogs Barking",
|
||||
@@ -89,7 +89,7 @@ def mainPage() {
|
||||
"Someone is arriving",
|
||||
"Piano",
|
||||
"Lightsaber"]
|
||||
//input "message","text",title:"Play this message", required:false, multiple: false
|
||||
input "message","text",title:"Play this message", required:false, multiple: false
|
||||
}
|
||||
section {
|
||||
input "sonos", "capability.musicPlayer", title: "On this Speaker player", required: true
|
||||
@@ -408,13 +408,15 @@ private loadText() {
|
||||
case "Lightsaber":
|
||||
state.sound = [uri: "http://s3.amazonaws.com/smartapp-media/sonos/lightsaber.mp3", duration: "10"]
|
||||
break;
|
||||
default:
|
||||
/*if (message) {
|
||||
case "Custom Message":
|
||||
if (message) {
|
||||
state.sound = textToSpeech(message instanceof List ? message[0] : message) // not sure why this is (sometimes) needed)
|
||||
}
|
||||
else {
|
||||
state.sound = textToSpeech("You selected the custom message option but did not enter a message in the $app.label Smart App")
|
||||
}*/
|
||||
}
|
||||
break;
|
||||
default:
|
||||
state.sound = [uri: "http://s3.amazonaws.com/smartapp-media/sonos/bell1.mp3", duration: "10"]
|
||||
break;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user