An SDL3 widget that attempts to looks like the good ol' Windows Vista/7 weather widget
Even though I'm a Linux user 99% of the time, one of the few things I miss is the weather widget from Windows Vista/7: it's simple, but I genuinely find it attractive and useful.
While there are various weather widgets for Linux using Conky, I've never come across one that resembled the Windows 7 version. So, I decided to create my own with C and SDL3. Windy is open source and works on Linux, FreeBSD, MacOS, and Windows.
Windy:
Change the following lines of request.py
file with the lat/long of your city
(exact location not needed!):
#
# Example:
# LATITUDE="35.69"
# LONGITUDE="139.69"
# LOCATION="Tokyo, Japan"
#
LATITUDE="<change to your location>"
LONGITUDE="<change to your location>"
LOCATION="<City, State>"
and then run:
$ ./windy -c "python request.py"
Unlike most weather programs/widgets, Windy doesn't attempt to embed one or more forecast APIs within itself. Instead, it delegates this responsibility to an external program/script.
Windy accomplishes this by invoking an external script provided as a parameter by the user. This script returns JSON output through stdout, which Windy reads and displays on the screen. Essentially, Windy serves as a GUI for an external program.
By default, Windy provides the request.py
script, which uses the
OpenMeteo's API to fetch weather information.
However, users can supply any script, program, etc., in their preferred language,
as long as it follows the JSON format below:
{
"temperature": 22,
"condition": "clear",
"max_temp": 20,
"min_temp": 15,
"location": "Tokyo, Japan",
"provider": "OpenMeteo",
"forecast": [
{
"max_temp": 34,
"min_temp": 27,
"condition": "rainfall"
},
{
"max_temp": 34,
"min_temp": 27,
"condition": "clouds"
},
{
"max_temp": 34,
"min_temp": 27,
"condition": "clouds"
}
]
}
acceptable values for condition
are: clear
, fog
, clouds
, showers
,
rainfall
, thunder
, and snow
.
Windy also supports changing the weather update interval (-t
) and the screen
coordinates (-x
and -y
) where it should appear. Below are all the available
options:
$ ./windy -h
Usage: ./windy [options] -c <command-to-run>
Options:
-t Interval time (in seconds) to check for weather
updates (default = 10 minutes)
-c <command> Command to execute when the update time reaches
-x <pos> Set the window X coordinate
-y <pos> Set the window Y coordinate
-h This help
Example:
Update the weather info each 30 minutes, by running the command
'python request.py'
$ ./windy -t 1800 -c "python request.py"
Obs: Options -t,-x and -y are not required, -c is required!
Windy requires SDL3
1 and SDL3_ttf
to build, if you don't have
them installed and your distro/OS doesn't have packages for them (highly likely,
as they're still under development) build with CMake:
$ git clone https://github.com/Theldus/windy.git
$ cd windy
$ mkdir build
$ cd build
$ cmake ..
$ make -j4
CMake will check if the libs can be found on the system, and if not, it will download and build them.
Optionally, if you are running Linux and already have the libraries installed on your system, just a 'make' is enough:
$ git clone https://github.com/Theldus/windy.git
$ cd windy
$ make -j4
Windy is always open to the community and willing to accept contributions, whether with issues, documentation, testing, new features, bugfixes, typos, and etc. Welcome aboard.
Windy is licensed under the MIT license.
Weather icons were created by gnokii and are licensed under the Creative Commons Attribution 3.0 License.
NotoSans font was created by Google and is licensed under the OFL license.
Footnotes
-
SDL3 is the first version of SDL to support transparent framebuffer, which is why version 3 is required. ↩