forked from prehensile/waveshare-clock
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathrun-EDIT-ME.sh
executable file
·117 lines (93 loc) · 7.46 KB
/
run-EDIT-ME.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
#!/bin/bash
# This script is to either:
# - test and trial run epaper-clock-and-more manually
# - be luanched by provided epaper.service (that must be registered under /etc/systemd - your mileage may vary depending what distribution you use)
#
# Please read README.md first to understand what is the meaning the variables below.
#
# WARNING WARNING WARNING
# - rename run-EDIT-ME.sh to run.sh and comment out the following 2 lines and re-configure the environment variables below
echo "Please edit and configure this script for your needs"
exit 1
# Developer debug mode - no epaper device is required to develop or debug - the output that is originally
# sent to device is being saved as bmp files here: /tmp/epaper*.bmp
#export EPAPER_DEBUG_MODE=true
# An extension to above DEBUG_MODE - useful for Travis CI - don't loop endlessly, just exit after fist display of data
#export EPAPER_DEBUG_MODE_DONT_LOOP=true
# Experimental modification of LUT tables that form waveforms that refresh "pixels" - implemented only for 2.7" displays.
# This modification makes refresh about 10 times faster for black die, and 2-3 times faster for red die. This of course has
# consequences in not-so ideal refresh and with time some random artifacts may start to build up. To recover you would need
# to turn this feature off for some time until original LUT tables won't remove those artifacts.
# Enable this feature on your own responsibility!
#export EPAPER_FAST_REFRESH=true
# Homebase name (a name for LAT,LON below)
export HOME_NAME-"Home"
# Lat & lon of your home (a base point)
export LAT=50.0618971 # using Rynek Główny @ KRK, as Plac Centralny doesn't temporarily work properly with Airly (#6) 50.0720519
export LON=19.9345672 # 20.0373204
# A key for traffic delays from Google Maps Distance Matrix API
export GOOGLE_MAPS_KEY=GET_YOUR_OWN_KEY # get the key from: https://developers.google.com/maps/documentation/embed/get-api-key
# A key for weather forecasts from OpenWeather One Call API
export OPENWEATHER_KEY=GET_YOUR_OWN_KEY # get the key from: https://openweathermap.org/home/sign_up & subscribe to the One Call API 3.0 by clicking 'Subscribe' button in the "One Call API 3.0", https://openweathermap.org/full-price#onecall
# A key for weather forecasts + alerts from Weatherbit.io API
export WEATHERBIT_IO_KEY=GET_YOUR_OWN_KEY # get the key from: https://www.weatherbit.io/account/create
# A key for AQI (Air Quality Index) from AIRLY.EU API (data for certain countries only, as yet, but you may order their device to provide data also for your neighbours)
export AIRLY_KEY=GET_YOUR_OWN_KEY # get the key from: https://developer.airly.eu/register
# A key for AQI (Air Quality Index) from AQICN API (data for cities across the world) - used as a fallback if Airly key above is not defined.
# See AQICN_CITY_OR_ID below to optionally specify city instead of lat&lon as above, or to use IP based geolocation.
export AQICN_KEY=GET_YOUR_OWN_KEY # get the key from: https://aqicn.org/data-platform/token/
# Cache TTLs in minutes for each data fetcher (refer to free accounts limitations before you change the values any lower than 10m)
export GOOGLE_MAPS_TTL=20
export AIRLY_TTL=20
export AQICN_TTL=20
export OPENWEATHER_TTL=15
export WEATHERBIT_IO_TTL=15
# AQICN City or ID (see: https://aqicn.org/search/) to use instead of LAT&LON coords, if you set it to 'here' then it is going to be based on IP geolocation
#export AQICN_CITY_OR_ID=here
# Meteoalarm.org country and province name to provide weather alerts in Europe (optional feature, uncomment and provide values for both to turn it on).
# To get the country name and province name visit Meteoalarm.org website. Mind that the country & province must have ATOM feed available (go here: https://feeds.meteoalarm.org/ - use country name as stated in atom feed url)
#export METEOALARM_COUNTRY=poland
# Please do remember to use UTF-8 encoding for province name. Also, apparently there's a problem with (some) UTF-8 encoded province names - they might not be found by meteoalarmapi library (to be investigated)
#export METEOALARM_PROVINCE=Kraków
# Units
export GOOGLE_MAPS_UNITS=metric # refer to: https://developers.google.com/maps/documentation/distance-matrix/intro#unit_systems for allowed values (metric, imperial)
export OPENWEATHER_UNITS=metric # refer to: https://openweathermap.org/api/one-call-api#data for allowed values (metric, imperial, etc)
export WEATHERBIT_IO_UNITS=M # refer to: https://www.weatherbit.io/api/weather-current for allowed values (M, I, S)
export WEATHER_UNITS=si # si (SI i.e. km) or mi (miles) for thunderstorm vacvinity - it depends on weather provider if it returns such data and whether in km or miles.
# Warning levels
export AQI_WARN_LEVEL=75 # above this value the displayed gauge will become red (on supported displays)
export WEATHER_STORM_DISTANCE_WARN=10 # display warning if storm is closer than this value in km/miles (take a look at units above) - if supported by weather provider
# Lat & lon of destination you want to calculate the current driving time including traffic
export FIRST_TIME_TO_DESTINATION_LAT=49.9823219
export FIRST_TIME_TO_DESTINATION_LON=20.0578518
export FIRST_DEST_NAME="Wieliczka"
# The displayed gauge will become red (on supported displays) when driving time exceeds by %
export FIRST_TIME_WARN_ABOVE_PERCENT=50
# Lat & lon of second destination (for a second member of a household?) you want to calculate the current driving time including traffic
export SECOND_TIME_TO_DESTINATION_LAT=49.9684476
export SECOND_TIME_TO_DESTINATION_LON=20.4303646
export SECOND_DEST_NAME="Bochnia"
# The displayed gauge will become red (on supported displays) when driving time exceeds by %
export SECOND_TIME_WARN_ABOVE_PERCENT=50
# Whether to paint black font on red canvas (for warn statuses) - helps visual espect if red dye faded out already
export WARN_PAINTED_BLACK_ON_RED=false
# Dead times - between stated hours data & display update is being done once in an hour and minutes won't be displayed. Default is [] - no dead times.
# This env var will be evaluated by python - so becareful, first: don't expose this env to outside world (security), second: follow the syntax otherwise program will die
#export DEAD_TIMES="[range(1,5),range(10,15)]"
# Whether to draw two vertical dots to separate hours and minutes (to avoid confusion that a year is being displayed... yes, I know people who first thought that was a year displayed)
export CLOCK_HRS_MINS_SEPARATOR=true
# Whether to prefer Airly.eu local temperature if available instead of current temperature returned by weather provider. Metric (Celsius) temperature only.
#export PREFER_AIRLY_LOCAL_TEMP=false
# A type of EPAPER display you want to use - either Waveshare 4"2 (b&w) or 2"7 (tri-color) - this automatically sets EPAPER_MONO to "true" for 2"7 and to "false" for 4"2
#export EPAPER_TYPE=waveshare-4.2
export EPAPER_TYPE=waveshare-2.7
# You can override the setting as whether the display is mono or not - though, it will require update (replacement) of relevant epdXinX.py library to support mono or tri-color
#export EPAPER_MONO=true
# You can override whether to listen for button press (enabled by default)
#export EPAPER_BUTTONS_ENABLED=true
# You can override GPIO pins assigned to buttons (these values are set by default and reflect 2.7" HUT version)
#export EPAPER_GPIO_PIN_FOR_KEY1=5
#export EPAPER_GPIO_PIN_FOR_KEY2=6
#export EPAPER_GPIO_PIN_FOR_KEY3=13
#export EPAPER_GPIO_PIN_FOR_KEY4=19
python3 main.py