Merge pull request #3008 from PySimpleGUI/Dev-latest
New Demo to display images using Graph Element
This commit is contained in:
commit
096198b082
|
@ -0,0 +1,95 @@
|
||||||
|
#!/usr/bin/env python
|
||||||
|
import PySimpleGUI as sg
|
||||||
|
from PIL import Image
|
||||||
|
import PIL
|
||||||
|
import io
|
||||||
|
import base64
|
||||||
|
import os
|
||||||
|
|
||||||
|
"""
|
||||||
|
Demo Image Album.... displays images on Graph Element and transitions
|
||||||
|
by sliding them across. Click on right side of image to navigate down through filenames, left side for up.
|
||||||
|
|
||||||
|
Contains a couple of handy PIL-based image functions that resize an image while maintaining correct proportion.
|
||||||
|
One you pass a filename, the other a BASE64 string.
|
||||||
|
|
||||||
|
Copyright 2020 PySimpleGUI.org
|
||||||
|
"""
|
||||||
|
|
||||||
|
G_SIZE = (400,400)
|
||||||
|
|
||||||
|
def get_img_filename(f, resize=None):
|
||||||
|
"""Generate image data using PIL
|
||||||
|
"""
|
||||||
|
img = PIL.Image.open(f)
|
||||||
|
cur_width, cur_height = img.size
|
||||||
|
if resize:
|
||||||
|
new_width, new_height = resize
|
||||||
|
if cur_width > cur_height:
|
||||||
|
new_height = int(new_height * cur_height/cur_width)
|
||||||
|
else:
|
||||||
|
new_width = int(new_width * cur_width/cur_height)
|
||||||
|
img = img.resize((new_width, new_height), PIL.Image.ANTIALIAS)
|
||||||
|
bio = io.BytesIO()
|
||||||
|
img.save(bio, format="PNG")
|
||||||
|
del img
|
||||||
|
return bio.getvalue()
|
||||||
|
|
||||||
|
|
||||||
|
def get_img_data(data, resize=None):
|
||||||
|
"""Generate PIL.Image data using PIL
|
||||||
|
"""
|
||||||
|
img = PIL.Image.open(io.BytesIO(base64.b64decode(data)))
|
||||||
|
cur_width, cur_height = img.size
|
||||||
|
if resize:
|
||||||
|
new_width, new_height = resize
|
||||||
|
if cur_width > cur_height:
|
||||||
|
new_height = int(new_height * cur_height/cur_width)
|
||||||
|
else:
|
||||||
|
new_width = int(new_width * cur_width/cur_height)
|
||||||
|
img = img.resize((new_width, new_height), PIL.Image.ANTIALIAS)
|
||||||
|
bio = io.BytesIO()
|
||||||
|
img.save(bio, format="PNG")
|
||||||
|
del img
|
||||||
|
return bio.getvalue()
|
||||||
|
|
||||||
|
folder = sg.popup_get_folder('Where are your images?')
|
||||||
|
if not folder:
|
||||||
|
exit(0)
|
||||||
|
|
||||||
|
file_list = os.listdir(folder)
|
||||||
|
fnames = [f for f in file_list if os.path.isfile(
|
||||||
|
os.path.join(folder, f)) and f.lower().endswith((".png", ".jpg", "jpeg", ".tiff", ".bmp"))]
|
||||||
|
num_files = len(fnames)
|
||||||
|
|
||||||
|
graph = sg.Graph(canvas_size=G_SIZE, graph_bottom_left=(0, 0), graph_top_right=G_SIZE, enable_events=True, key='-GRAPH-')
|
||||||
|
layout = [[graph]]
|
||||||
|
|
||||||
|
window = sg.Window('Scrolling Image Viewer', layout, margins=(0,0), element_padding=(0,0), use_default_focus=False, finalize=True)
|
||||||
|
|
||||||
|
offset, move_amount, direction = 0, 5, 'left'
|
||||||
|
while True:
|
||||||
|
file_to_display = os.path.join(folder, fnames[offset])
|
||||||
|
img_data = get_img_filename(file_to_display, resize=G_SIZE)
|
||||||
|
id = graph.draw_image(data=img_data, location=(0, G_SIZE[1]))
|
||||||
|
|
||||||
|
event, values = window.read()
|
||||||
|
if event == sg.WIN_CLOSED:
|
||||||
|
break
|
||||||
|
|
||||||
|
if event in ('<', '>'):
|
||||||
|
direction = 'left' if event == '<' else 'right'
|
||||||
|
elif event == '-GRAPH-':
|
||||||
|
direction = 'left' if values['-GRAPH-'][0] < (G_SIZE[0] // 2) else 'right'
|
||||||
|
|
||||||
|
for i in range(G_SIZE[0]//move_amount):
|
||||||
|
graph.move_figure(id, -move_amount if direction == 'left' else move_amount, 0)
|
||||||
|
window.read(timeout=0)
|
||||||
|
graph.delete_figure(id)
|
||||||
|
|
||||||
|
if direction == 'left':
|
||||||
|
offset = (offset + (num_files - 1)) % num_files # Decrement - roll over to MAX from 0
|
||||||
|
else:
|
||||||
|
offset = (offset + 1) % num_files # Increment to MAX then roll over to 0
|
||||||
|
|
||||||
|
window.close()
|
Loading…
Reference in New Issue