PySimpleGUI: Using an Image as a Button

When you create a graphical user interface for your amazing program, you want to add a little bit of yourself to the application. One way to do that is to use images as buttons. While some people find these types of buttons unintuitive because they don't look like buttons, it is a legitimate way to differentiate your application from your competition.

PySimpleGUI provides a four-step process in their Cookbook for this process:

  1. Find your image (PNG or GIF)
  2. Convert your image into a Base64 byte string
  3. Add the Base64 byte string to your code
  4. Specify the Base64 byte string as the image to use when you create the button

You will follow this process in this tutorial. If you don't have PySimpleGUI installed, then you will need to issue the following command:

python -m pip install PySimpleGUI

Now that you have PySimpleGUI, your next step is to find an image to use for your button!

Finding an Image

There are many different places you can find an image. You may have your own collection on your computer. You can go and buy icon sets online. Or you can search the Internet for images and try to find open-source or other free icons. You shouldn't use images that are copyrighted as that can get your in legal trouble.

For this example, you can do a search using your favorite search engine. For the purpose of this tutorial, the following search string was used: "Purple Flower Icon" which found the following image on freeiconspng.com:

Flower icon

Now that you have an image to use, you need to convert it to a string!

Convert your image into a Base64 byte string

Now you need to convert your image to a base64 byte string. PySimpleGUI has two demos that you can use for this purpose:

  • Demo_Base64_Single_Image_Encoder.py - Convert a single input file and save the string to the clipboard
  • Demo_Base64_Image_Encoder.py - Convert an entire folder of images to strings and save it to output.py

Either of these programs will work. Since there is only one image for this example, that first demo may make the most sense.

Once you have run that demo against the flower photo, you will have the base64-encoded string in your computer's clipboard.

Add the Base64 byte string to your code 

You can take the base64-encoded string from your clipboard and paste it into your code. You'll want to assign that string to a variable so that you can reference it in your GUI code.

Here is the code you'll use to show your custom button:

import PySimpleGUI as sg

flower_base64 = b'paste your base64 encoded string here'

layout = [  [sg.Text('Base64 Button Demo')],
            [sg.Button('', image_data=flower_base64, 
            button_color=(sg.theme_background_color(),sg.theme_background_color()),border_width=0, key='Exit')]  ]

window = sg.Window('Flowers!', layout, no_titlebar=True)

while True:             # Event Loop
    event, values = window.read()
    print(event, values)
    if event in (sg.WIN_CLOSED, 'Exit'):
        break
window.close()

This code is based on the example from the PySimpleGUI Cookbook. You will need to paste in the base64 encoded string into this code. It is too long to include here.

When you run this code, you'll see a GUI that looks like this:

A flower button in a PySimpleGUI application

Doesn't that look nice? When you click on the flower button, it closes the application.

Wrapping Up

PySimpleGUI makes creating custom buttons simple. Your button-making capabilities are only limited by your imagination.

Related Reading

Want to more about PySimpleGUI, then check out the following resources:

Copyright © 2024 Mouse Vs Python | Powered by Pythonlibrary