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

20 Chapters to learn in Python

20 Chapters to learn in Python Introduction to Python : This chapter could cover the basics of Python, including how to install it and run it, as well as some basic syntax and concepts such as variables, data types, and control structures. Basic Data Types : This chapter could cover the various data types in Python, including integers, floats, strings, lists, tuples, and dictionaries. It could also cover how to manipulate and operate on these data types. Control Structures: This chapter could cover the various control structures in Python, including if-else statements, for loops, and while loops. It could also cover how to use these control structures to perform different types of operations. Functions: This chapter could cover how to define and use functions in Python, including how to pass arguments to functions and how to return values from functions. Modules and Packages: This chapter could cover how to import and use modules and packages in Python, including the standard library a...

What is so special about MidJourney v5 release?

Artwork by MidJourney MidJourney is a popular online service that allows users to generate realistic and artistic images from text prompts using artificial intelligence. It has been widely used by artists, designers, writers, and hobbyists for various creative purposes. However, until recently, MidJourney had some limitations in its image quality and diversity. For example, some images looked blurry or distorted, some had unrealistic colors or lighting effects, and some had anatomical errors such as extra fingers or missing limbs. That's why many users have been eagerly waiting for the MidJourney v5 release, which promises to deliver significant improvements in image generation. According to the MidJourney team, v5 is not just an update but a complete overhaul of the underlying algorithm that powers the service. Here are some of the key features and benefits of v5 that make it so special: - High resolution : v5 can generate images up to 1024x1024 pixels, which is four times larger ...

Living a Joyful Life on a Budget: Books to Inspire and Guide You

Living a Joyful Life on a Budget: Books to Inspire and Guide You Money can be a significant source of stress and worry for many people, especially when you are struggling to make ends meet. The pressure to pay off debts or keep up with the expenses of daily living can leave you feeling drained and overwhelmed. However, it is possible to find joy and fulfillment in life, even when you have a limited income. In this article, we will explore some of the best books that offer insights and strategies for living a joyful life on a budget. "The Art of Frugal Hedonism" by Annie Raser-Rowland and Adam Grubb If you are looking for a book that will inspire you to find pleasure in the simple things in life, "The Art of Frugal Hedonism" is an excellent place to start. This book is a celebration of the joys of frugal living, and it offers practical tips and suggestions for how to live a rich and fulfilling life without spending a lot of money. "The Art of Frugal Hedonism...

Risks of AI-generated Code: Google's Bard, Amazon Whisperer, and the Challenges with their New Features

Artificial intelligence (AI) has advanced so much in recent days that it is now used in various applications. Machine learning is used to teach AI systems how to learn on their own, and they are used in various industries such as healthcare, finance, and e-commerce. AI has revolutionized the way we interact with technology, and companies such as Google and Amazon have been at the forefront of AI research and development. However, with every new feature and advancement, there are bound to be issues and challenges that come with it. Google's Bard and Amazon Whisperer are two examples of AI language models that have been introduced in recent years, but they have faced some issues with their new code feature. Google's Bard Google's Bard is a language model that is designed to help people write poetry. It uses machine learning algorithms to generate verses based on the style and theme of the poem. Bard was introduced in 2021 and has since gained popularity among poetry enthusias...

Unleashing the Power of ChatGPT plugins

Unleashing the Power of ChatGPT plugins ChatGPT, an OpenAI-trained large language model, has been making waves in the world of artificial intelligence and conversational agents. ChatGPT has become even more powerful and versatile with the release of GPT-4 and additional third-party plugins. The addition of ChatGPT extensions is an exciting advancement in ChatGPT's capabilities. These extensions enable even more customization and flexibility in the use of the language model for a variety of purposes. ChatGPT extensions allow users to extend the base model's capabilities by adding functionality and features. ChatGPT extensions have limitless potential. They can be used for anything from language translation to natural language processing to chatbot development and game development. Customer service can also benefit from ChatGPT extensions. ChatGPT extensions can also be used to enhance customer service and support, automate time-consuming tasks, and even aid in research and data ...