Software is pretty crippled but it works somehwat!
This commit is contained in:
commit
0873ef3b4e
Binary file not shown.
Binary file not shown.
After Width: | Height: | Size: 13 KiB |
Binary file not shown.
Binary file not shown.
After Width: | Height: | Size: 86 KiB |
|
@ -0,0 +1 @@
|
|||
PySSTV==0.4.3
|
|
@ -0,0 +1,54 @@
|
|||
from shutil import copyfile
|
||||
from PIL import Image, ImageFont, ImageDraw
|
||||
from pysstv import color
|
||||
|
||||
def take_photo():
|
||||
# This def is meant to take a photograph from the robot,
|
||||
# it should include all steps and error checking to raise the mast
|
||||
# Take the photo, and put the mast down.
|
||||
|
||||
# Copy in the test pattern png (if photo process errors out, this will be used instead)
|
||||
copyfile('photos/TEST_PATTERN.jpg', 'working/working.jpg')
|
||||
|
||||
# Software to take the photo should be here
|
||||
copyfile('photos/camera_latest.jpg', 'working/working.jpg')
|
||||
|
||||
def mark_photo():
|
||||
raw_img = Image.open("working/working.jpg") # Open the current working image
|
||||
img = raw_img.resize((320, 240), Image.ANTIALIAS) # resize it for the radio
|
||||
|
||||
|
||||
TINT_COLOR = (255, 255, 255) # White text bg
|
||||
TRANSPARENCY = .25 # Degree of transparency, 0-100%
|
||||
OPACITY = int(255 * TRANSPARENCY)
|
||||
overlay = Image.new('RGBA', img.size, TINT_COLOR+(0,))
|
||||
|
||||
draw = ImageDraw.Draw(overlay)
|
||||
bigfont = ImageFont.truetype(r'C:\Users\System-Pc\Desktop\arial.ttf', 20)
|
||||
smallfont = ImageFont.truetype(r'C:\Users\System-Pc\Desktop\arial.ttf', 17)
|
||||
|
||||
draw.rectangle(((0, 0), (90, 20)), fill=TINT_COLOR+(OPACITY,))
|
||||
draw.text((0, 0),"KW1FOX",(0,0,0),font=bigfont) # Draw KW1FOX in the top left
|
||||
|
||||
draw.rectangle(((0, 40), (83, 100)), fill=TINT_COLOR+(OPACITY,))
|
||||
draw.text((0, 40),"day: 25.2",(0,0,0),font=smallfont)
|
||||
draw.text((0, 60),"Volt: 13.8",(0,0,0),font=smallfont)
|
||||
draw.text((0, 80),"Miles: 1.02",(0,0,0),font=smallfont)
|
||||
|
||||
img = img.convert("RGBA")
|
||||
img = Image.alpha_composite(img, overlay)
|
||||
img = img.convert("RGB")
|
||||
img.save('working/working.jpg') # Save the working image
|
||||
return img
|
||||
|
||||
if __name__ == "__main__":
|
||||
# Take photograph.
|
||||
take_photo() # Saves a photograph to the working/working.jpg location
|
||||
|
||||
# Draw neccicary text on photo
|
||||
radio_photo = mark_photo() # draws text on working/working.jpg and returns a PIL image
|
||||
|
||||
slowscan = color.Robot36(radio_photo, 48000, 16) # Image, rate, bits
|
||||
slowscan.write_wav('working/working.wav')
|
||||
|
||||
#sstv('working/working.png', 'working/radio.wav', mode='Robot36')
|
Binary file not shown.
After Width: | Height: | Size: 17 KiB |
Binary file not shown.
Loading…
Reference in New Issue