openhab-addons/bundles/org.openhab.binding.meteostick/README.md
Kai Kreuzer 4be0e341d8 Codebase as of f11ddbc2a3 as an initial commit for the shrunk repo
Signed-off-by: Kai Kreuzer <kai@openhab.org>
2020-09-20 23:52:13 +02:00

180 lines
9.2 KiB
Markdown

# Meteostick Binding
This is the binding for the [Meteostick](https://www.smartbedded.com/wiki/index.php/Meteostick) weather receiver dongle.
This is an RF receiver that can receive data directly from Davis weather devices (and others).
## Supported Things
This binding support 2 different things types
| Thing | Type | Description |
|----------------------|--------|-----------------------------------|
| meteostick_bridge | Bridge | This is the Meteostick USB stick |
| meteostick_davis_iss | Thing | This is the Davis Vue ISS |
## Binding Configuration
The Meteostick things need to be manually added - there is no discovery in the Meteostick binding.
First add and configure the Meteostick bridge - the port and frequency band for your region need to be set.
Next add the sensor and configure the channel number.
## Thing Configuration
### meteostick_bridge Configuration Options
| Option | Description |
|--------|----------------------------------------------------|
| port | Sets the serial port to be used for the stick |
| mode | Sets the mode (frequency band) |
Set mode to one of the following depending on your device and region:
| Mode | Device | Region | Frequency |
|-------|--------------|------------------|-----------|
| 0 | Davis | North America | 915 Mhz |
| 1 | Davis | Europe | 868 Mhz |
| 2 | Davis | Australia | 915 Mhz |
| 3 | Fine Offset | North America | 915 Mhz |
| 4 | Fine Offset | Europe | 868 Mhz |
| 5 | Davis | New Zealand | 931.5 Mhz |
### meteostick_davis_iss Configuration Options
| Option | Description |
|---------|-------------------------------------------|
| channel | Sets the RF channel used for this sensor |
| spoon | Size of rain spoon assembly for this sensor in mm. Default value is 0.254 (0.01") for use with Davis part number 7345.280. Set to 0.2 for use with Davis part number 7345.319 |
## Channels
### Meteostick
| Channel Type ID | Item Type | Description |
|--------------------|--------------------|--------------------|
| pressure | Number:Pressure | Air pressure |
| indoor-temperature | Number:Temperature | Indoor temperature |
### Davis ISS
| Channel Type ID | Item Type | Description |
|---------------------|-----------------------|-------------------------------------------------|
| outdoor-temperature | Number:Temperature | Outside temperature |
| humidity | Number | Humidity |
| wind-direction | Number:Angle | Wind direction |
| wind-direction-last2min-average | Number:Angle | Wind direction average over last 2 minutes |
| wind-speed | Number:Speed | Wind speed |
| wind-speed-last2min-average | Number:Speed | Wind speed average over last 2 minutes |
| wind-speed-last2min-maximum | Number:Speed | Wind speed maximum over last 2 minutes |
| rain-raw | Number | Raw rain counter from the tipping spoon sensor |
| rain-currenthour | Number:Length | The rainfall in the last 60 minutes |
| rain-lasthour | Number:Length | The rainfall in the previous hour |
| solar-power | Number | Solar power from the sensor station |
| signal-strength | Number | Received signal strength |
| low-battery | Switch | Low battery warning |
#### Rainfall
There are three channels associated with rainfall.
The raw counter from the tipping bucket is provided, the rainfall in the last 60 minutes is updated on each received rainfall and provides the past 60 minutes of rainfall.
The rainfall in the previous hour is the rainfall for each hour of the day and is updated on the hour.
## Full Example
This example uploads weather data to for your personal weather station at Weather Underground every two minutes.
Steps:
1. Install the [MeteoStick](https://www.smartbedded.com/wiki/index.php/Meteostick) binding for use with your [Davis Vantage Vue Integrated Sensor Suite (ISS)](https://www.davisnet.com/solution/vantage-vue/).
1. [Register](https://www.wunderground.com/personal-weather-station/signup.asp) your personal weather station with Weather Underground and make note of the station ID and password issued.
1. Add the following files to your openHAB configuration:
### things/meteostick.things
Things can be defined in the .things file as follows:
```
meteostick:meteostick_bridge:receiver [ port="/dev/tty.usbserial-AI02XA60", mode=1 ]
meteostick:meteostick_davis_iss:iss (meteostick:meteostick_bridge:receiver) [ channel=1, spoon=0.2 ]
```
Note the configuration options for `port`, `mode`, `channel` and `spoon` above and adjust as needed for your specific hardware.
### items/meteostick.items
```
Number:Pressure MeteoStickPressure "Meteostick Pressure [%.1f hPa]"{ channel="meteostick:meteostick_bridge:receiver:pressure" }
Number:Temperature DavisVantageVueOutdoorTemperature "ISS Outdoor Temp [%.1f °C]" { channel="meteostick:meteostick_davis_iss:iss:outdoor-temperature" }
Number DavisVantageVueHumidity "ISS Humidity [%.0f %%]" { channel="meteostick:meteostick_davis_iss:iss:humidity" }
Number:Angle DavisVantageVueWindDirection "ISS Wind Direction [%.0f °]" { channel="meteostick:meteostick_davis_iss:iss:wind-direction" }
Number:Angle DavisVantageVueWindDirectionAverage "ISS Average Wind Direction [%.0f °]" { channel="meteostick:meteostick_davis_iss:iss:wind-direction-last2min-average" }
Number:Speed DavisVantageVueWindSpeed "ISS Wind Speed [%.1f m/s]" { channel="meteostick:meteostick_davis_iss:iss:wind-speed" }
Number:Speed DavisVantageVueWindSpeedAverage "ISS Average Wind Speed [%.1f m/s]" { channel="meteostick:meteostick_davis_iss:iss:wind-speed-last2min-average" }
Number:Speed DavisVantageVueWindSpeedMaximum "ISS Maximum Wind Speed [%.1f m/s]" { channel="meteostick:meteostick_davis_iss:iss:wind-speed-last2min-maximum" }
Number:Length DavisVantageVueRainCurrentHour "ISS Rain Current Hour [%.1f mm]" { channel="meteostick:meteostick_davis_iss:iss:rain-currenthour" }
```
### rules/meteostick.rules
Replace `YOUR_ID` and `your_password` below with the values from the the Weather Underground registration process.
```
import java.net.URLEncoder
import java.text.SimpleDateFormat
import java.util.Date
import java.util.Map
import java.util.TimeZone
/* Uploads weather station data using the format documented here:
https://feedback.weather.com/customer/en/portal/articles/2924682-pws-upload-protocol?b_id=17298
*/
rule PWS
when
Item DavisVantageVueWindDirectionAverage received update
then
val id = 'YOUR_ID'
val pw = 'your_password'
val sdf = new SimpleDateFormat('yyyy-MM-dd HH:mm:ss')
sdf.setTimeZone(TimeZone.getTimeZone('UTC'))
val double rh = DavisVantageVueHumidity.getStateAs(DecimalType).doubleValue
val double tempc = DavisVantageVueOutdoorTemperature.getStateAs(QuantityType).toUnit('°C').doubleValue
val double dewptc = 243.04 * (Math.log(rh/100) + ((17.625 * tempc) / (243.04 + tempc))) / (17.625 - Math.log(rh/100) - ((17.625 * tempc) / (243.04 + tempc)))
val double dewptf = new QuantityType(dewptc, CELSIUS).toUnit('°F').doubleValue
val Map<String, Object> params = newLinkedHashMap(
'action' -> 'updateraw',
'ID' -> id,
'PASSWORD' -> pw,
'dateutc' -> sdf.format(new Date()),
'winddir' -> DavisVantageVueWindDirection.getStateAs(QuantityType).toUnit('°').intValue,
'windspeedmph' -> DavisVantageVueWindSpeed.getStateAs(QuantityType).toUnit('mph').doubleValue,
'windgustmph' -> DavisVantageVueWindSpeedMaximum.getStateAs(QuantityType).toUnit('mph').doubleValue,
'windgustdir' -> DavisVantageVueWindDirectionAverage.getStateAs(QuantityType).toUnit('°').intValue,
'windspdmph_avg2m' -> DavisVantageVueWindSpeedAverage.getStateAs(QuantityType).toUnit('mph').doubleValue,
'winddir_avg2m' -> DavisVantageVueWindDirectionAverage.getStateAs(QuantityType).toUnit('°').intValue,
'humidity' -> DavisVantageVueHumidity.state,
'dewptf' -> dewptf,
'tempf' -> DavisVantageVueOutdoorTemperature.getStateAs(QuantityType).toUnit('°F').doubleValue,
'rainin' -> DavisVantageVueRainCurrentHour.getStateAs(QuantityType).toUnit('in').doubleValue,
'baromin' -> MeteoStickPressure.getStateAs(QuantityType).toUnit('inHg').doubleValue,
'softwaretype' -> 'openHAB 2.4')
var url = 'https://weatherstation.wunderground.com/weatherstation/updateweatherstation.php?'
var first = true
for (key : params.keySet()) {
if (!first) {
url += '&'
}
url += key + '=' + URLEncoder::encode(params.get(key).toString, 'UTF-8')
first = false
}
logDebug('PWS', 'url is {}', url)
sendHttpGetRequest(url)
end
```
openHAB will now report your weather station data to Weather Underground every two minutes.