Skip to main content

How to Create a Simple Image Viewer with Python?

How to Create a Simple Image Viewer with Python?
How to Create a Simple Image Viewer with Python?

In this article, we will go through the steps of creating a simple image viewer app using Python's GUI library Tkinter. This app allows the user to navigate through a folder of images, viewing each one in turn.

Introduction

Have you ever wanted to view a folder of images in an organized manner? Well, look no further! With a little bit of Python code, you can create a simple image viewer that does exactly that. We'll be using Tkinter, a popular Python GUI library, to make this app.

Building the App

The first step in building the image viewer app is to import the required libraries and create a GUI window using Tkinter. You'll then need to specify the dimensions of the window, as well as its title, font, and other visual elements.

Once the window is set up, you can start adding widgets to it. In this case, we'll be using label widgets to display the images. To navigate through the images, we'll add buttons for "Next" and "Previous" navigation. The code will load the next or previous image in the folder based on the button that is pressed.

Adding Functionality

Next, we'll add the functionality to our image viewer. This includes defining the folder that contains the images, parsing the values of the images, and loading each image in turn. We'll also specify what happens when the "Next" and "Previous" buttons are pressed.

The code for this step involves a bit of logic, but don't worry, it's not too difficult. Essentially, the code checks the current location of the image within the folder, and either increments or decrements it depending on the button that was pressed. The code then loads the image at the new location and displays it in the window.

Finishing Up

Finally, we'll add the finishing touches to our image viewer app. This includes positioning the "Next" and "Previous" buttons, as well as adding a "Close" button to close the window.

With these few simple steps, you now have a functional image viewer app built using Python and Tkinter. You can now easily view folders of images in an organized and user-friendly manner.

Food for Thought

Building a simple image viewer is just the beginning of what you can do with Python and Tkinter. There are many more features and capabilities that you can add to this app, such as zooming in on images, adding a thumbnail view, and much more. The possibilities are endless, and the best part is, you can build it all with just a little bit of Python code. So go ahead and try it out for yourself!

Example

Here is an example:

import tkinter as tk
from tkinter import filedialog
from tkinter import messagebox
from PIL import Image, ImageTk
import os

class ImageViewer:
    def __init__(self, master):
        self.master = master
        self.master.title("Python Simple Image Viewer")
        self.master.geometry("600x600")

        self.top_frame = tk.Frame(self.master, width=600, bd=1, relief="solid")
        self.top_frame.pack(side="top", fill="both", expand="yes")

        self.mid_frame = tk.Frame(self.master, width=300, height=200, bd=1, relief="solid")
        self.mid_frame.pack(side="top")

        self.images = []
        self.location = 0

        self.lbl_title = tk.Label(self.top_frame, text="Label", font=("Arial", 20))
        self.lbl_title.pack()

        self.forward = tk.Button(self.top_frame, text="Forward", command=lambda: self.load_image(1))
        self.forward.pack(side="left")

        self.back = tk.Button(self.top_frame, text="Back", command=lambda: self.load_image(-1))
        self.back.pack(side="left")

        self.parse_folder()

    def parse_folder(self):
        file_path = filedialog.askdirectory()
        if not file_path:
            messagebox.showerror("Error", "No folder selected.")
            return

        try:
            for file in os.listdir(file_path):
                if file.endswith(".jpg") or file.endswith(".png"):
                    self.images.append(os.path.join(file_path, file))
        except Exception as e:
            messagebox.showerror("Error", str(e))
            return

        if not self.images:
            messagebox.showerror("Error", "No images found in the selected folder.")
            return

        self.load_image(0)

    def load_image(self, direction):
        self.location += direction
        if self.location >= len(self.images):
            self.location = 0
        elif self.location < 0:
            self.location = len(self.images) - 1

        image = Image.open(self.images[self.location])
        image = image.resize((300, 200), Image.ANTIALIAS)
        image = ImageTk.PhotoImage(image)

        self.lbl_title.config(image=image)
        self.lbl_title.image = image

if __name__ == "__main__":
    root = tk.Tk()
    viewer = ImageViewer(root)
    root.mainloop() 

Popular posts from this blog

Python Tutorial Chapter #2: Basic Data Types

In Python, there are several built-in data types that you can use to store and manipulate data. In this tutorial, we will cover the following data types: Python Tutorial Chapter #2: Basic Data Types Integers: Integers are whole numbers that can be positive, negative, or zero. In Python, you can create an integer by assigning an integer value to a variable. For example: Floats: Floats are numbers with decimal points. In Python, you can create a float by assigning a float value to a variable. For example: Strings: Strings are sequences of characters. In Python, you can create a string by enclosing a sequence of characters in quotation marks. You can use single quotes or double quotes, but you must use the same type of quotes to start and end the string. For example: Lists: Lists are ordered collections of items. In Python, you can create a list by enclosing a comma-separated list of items in square brackets. Lists can contain items of any data type, and the items do not have to be of the...

Unlocking Endless Possibilities: Hugging Face Chat

If you're looking for a chatbot that can generate natural language responses for various tasks and domains, you might have heard of ChatGPT, a powerful model developed by OpenAI. But did you know that there is an open-source alternative to ChatGPT that you can use for free? It's called HuggingChat, and it's created by Hugging Face, a popular AI startup that provides ML tools and AI code hub. In this article, I'll show you what HuggingChat can do, how it works, and why it's a great option for anyone interested in chatbot technology. Hugging Face Chat HuggingChat is a web-based chatbot that you can access at hf.co/chat. It's built on the LLaMa 30B SFT 6 model , which is a modified version of Meta's 30 billion parameter LLaMA model. The LLaMa model is trained on a large corpus of text from various sources, such as Wikipedia, Reddit, news articles, books, and more. It can generate text in natural language or in a specific format when prompted by the user. Huggin...

Now on Google News!

We have some exciting news to share with you!  Our website is now listed on Google News, which means that our content will reach a wider audience and more potential customers.  Google News Logo Google News is a platform that aggregates news from various sources and displays them according to the user's preferences and interests. Being listed on Google News is a great achievement for us, as it shows that our website meets the high standards of quality and relevance that Google requires. We are proud of our work and we hope that you will enjoy reading our articles and finding out more about our products and services.  Siri Sarah LLC on Google News If you haven't already, you can subscribe to our website on Google News by following these simple steps: - Open the Google News app on your device or go to news.google.com on your browser. - Search for our website name in the search bar. - Tap or click on the "Follow" button next to our website logo. That's it! You will no...

What is Auto-GPT, why do I need to care?

Are you interested in the latest advancements in artificial intelligence?  If so, you might want to check out Auto-GPT, an experimental open-source application that showcases the capabilities of the GPT-4 language model. This program is driven by GPT-4 and autonomously develops and manages businesses to increase net worth. As one of the first examples of GPT-4 running fully autonomously, Auto-GPT pushes the boundaries of what is possible with AI. GPT Architecture If you're curious about Auto-GPT, you'll be pleased to know that a demo was recently released on March 30th, 2023. So, what can Auto-GPT do? Well, it has a range of features, including internet access for searches and information gathering, long-term and short-term memory management, GPT-4 instances for text generation, access to popular websites and platforms, file storage and summarization with GPT-3.5, and much more. To use Auto-GPT, you'll need Python 3.7 or later and an OpenAI API key. If you want to use Speec...

Bing's Image creator vs MidJourney AI vs Stable Diffusion

Microsoft's Bing has recently launched a new AI-based image creation tool called Bing Image Creator. With this new tool, users can turn words into images to express their imagination, providing access to infinite image possibilities right from within Bing. The tool is created by OpenAI's DALL-E to generate pictures based on text prompts. Image generated by MidJourney AI Using the Bing Image Creator is simple and straightforward. Users can type in a word or phrase and Bing will generate an image based on the text entered. The tool is similar to other text-to-image generators like DALL-E and Stable. The images created by the Bing Image Creator can be used for a wide range of purposes, including vivid dreams, birthday invitations, and new concept proposals. The launch of Bing's Image Creator has garnered attention from the tech community, with many praising its innovative use of AI. However, some have also raised concerns about the potential misuse of the tool, such as creatin...