How to create a gauge / speedometer graphic with Python
This article discusses how to easily create a speedometer / gauge image in Python with only the Pillow library.
View source code and images on GitHub: python-gauge
The gauge graphic is separated into two images. The first image is the needle that points to a number on the gauge. The second image is the gauge without the needle. The final gauge image is generated by rotating the needle image then pasting it on the gauge.
The script is simple. The gauge is half a circle therefore the needle needs to rotate between 0 and 180 degrees. The gauge goes from 0 to 100. So if you want the gauge to point to 20, the script just takes 20% of 180 degrees to rotate the needle.
""" Copyright (C) 2018 FireEye, Inc., created by Andrew Shay. All Rights Reserved. """ import PIL from PIL import Image percent = 20 # Percent for gauge output_file_name = 'new_gauge.png' # X and Y coordinates of the center bottom of the needle starting from the top left corner # of the image x = 825 y = 825 loc = (x, y) percent = percent / 100 rotation = 180 * percent # 180 degrees because the gauge is half a circle rotation = 90 - rotation # Factor in the needle graphic pointing to 50 (90 degrees) dial = Image.open('needle.png') dial = dial.rotate(rotation, resample=PIL.Image.BICUBIC, center=loc) # Rotate needle gauge = Image.open('gauge.png') gauge.paste(dial, mask=dial) # Paste needle onto gauge gauge.save(output_file_name)
To modify the gauge image, modify
gauge.png should be the gauge without the needle (hide the needle layer).
needle.png should only be the needle on a transparent background and should point at 50 (hide all layers except needle).