TKINTER TUTORIAL
Chương trình "Hello, World!" bằng Tkinter trong Python Tìm hiểu cửa sổ Tkinter trong Python Tìm hiểu về các Widget Tkinter trong Python 3 cách đặt Options cho Widget Tkinter trong Python Ràng buộc lệnh trong Tkinter Tìm hiểu Event Binding của Tkinter trong Python Giới thiệu widget Label trong Tkinter Cách sử dụng widget Entry trong Tkinter Trình quản lý hình học Pack trong Tkinter Trình quản lý hình học Grid trong Tkinter Trình quản lý hình học Place trong Tkinter Kích thước Widget trong Tkinter Tìm hiểu về widget Frame trong Tkinter Cách sử dụng widget Text của Tkinter Tìm hiểu về widget Scrollbar của Tkinter Cách sử dụng widget ScrolledText của Tkinter Cách sử dụng widget Separator của Tkinter Cách sử dụng Widget Checkbox Trong Tkinter Cách sử dụng widget radio button của Tkinter Cách tạo widget combobox trong Tkinter Cách sử dụng widget Listbox trong Tkinter Sử dụng widget PanedWindow trong Tkinter Cách tạo widget Spinbox trong Tkinter Hướng dẫn sử dụng Slider trong Tkinter Cách sử dụng widget Sizegrip trong Tkinter Cách sử dụng widget LabelFrame trong Tkinter Cách sử dụng widget Progressbar trong Tkinter Cách sử dụng widget Notebook trong Tkinter Cách sử dụng về widget Treeview trong Tkinter Hướng dẫn về Canvas trong Tkinter Cách thiết lập con trỏ widget trong Tkinter. Window hướng đối tượng trong Tkinter Các Frame hướng đối tượng trong Tkinter Cách sử dụng Object-Oriented Application trong Tkinter Phương thức tkraise() của Frame trong Tkinter Các kiểu (Styles) trong Tkinter Cách thay đổi theme trong Tkinter Các element của ttk trong Tkinter Tìm hiểu về đối tượng Tkinter StringVar trong Tkinter Cách sử dụng phương thức map() của ttk.Style Cách sử dụng phương thức after() của Tkinter Cách sử dụng threads trong Tkinter Cách hiển thị progress bar khi thread đang chạy trong Tkinter. Cách tạo nhiều cửa sổ trong một Tkinter Cách sử dụng widget PhotoImage của Tkinter Cấu trúc MVC trong Tkinter Cách sử dụng Validate trong Tkinter Cách hiển thị đồ thị từ thư viện Matplotlib trong Tkinter Ứng dụng System Tray với Tkinter
CÁC CHỦ ĐỀ
BÀI MỚI NHẤT
MỚI CẬP NHẬT

Thông báo: Download 4 khóa học Python từ cơ bản đến nâng cao tại đây.

Cách sử dụng widget PhotoImage của Tkinter

Trong bài viết này, mình sẽ tìm hiểu cách sử dụng widget PhotoImage của Tkinter để hiển thị hình ảnh trên các widget khác như LabelButton. Việc hiển thị hình ảnh trong giao diện đồ họa không chỉ giúp ứng dụng trở nên trực quan hơn mà còn nâng cao trải nghiệm người dùng. Tkinter, với tính năng hỗ trợ hình ảnh thông qua widget PhotoImage, cung cấp một cách dễ dàng để tích hợp hình ảnh vào ứng dụng Python của bạn. Hãy cùng tìm hiểu cách triển khai và sử dụng PhotoImage một cách hiệu quả trong các ứng dụng Tkinter.

test php

banquyen png
Bài viết này được đăng tại freetuts.net, không được copy dưới mọi hình thức.

Giới thiệu về widget PhotoImage trong Tkinter

Trong Tkinter, một số widget như LabelButton có thể hiển thị hình ảnh. Những widget này có tham số image cho phép bạn truyền vào một hình ảnh để hiển thị. Tuy nhiên, bạn không thể chỉ đơn giản truyền đường dẫn của file ảnh vào tham số image. Thay vào đó, bạn cần tạo một đối tượng PhotoImage và truyền đối tượng này vào tham số image.

Để tạo một đối tượng PhotoImage mới, bạn sử dụng cú pháp sau:

photo_image = tk.PhotoImage(file=path_to_image)

Trong cú pháp này, bạn truyền đường dẫn tới file ảnh vào tham số file để tạo một đối tượng PhotoImage mới. Ngoài ra, bạn cũng có thể truyền một đối tượng bytes chứa dữ liệu hình ảnh vào tham số data.

Bài viết này được đăng tại [free tuts .net]

Sau khi tạo đối tượng PhotoImage, bạn có thể sử dụng nó trong các widget chấp nhận tham số image, ví dụ:

label = ttk.Label(root, image=photo_image)

Lưu ý quan trọng là bạn cần giữ tham chiếu đến đối tượng PhotoImage trong phạm vi của chương trình miễn là hình ảnh vẫn còn được hiển thị. Nếu không, hình ảnh sẽ không xuất hiện.

Ví dụ về sử dụng PhotoImage trong Tkinter

Dưới đây là một ví dụ cố gắng hiển thị hình ảnh với đường dẫn './assets/python.png' trên cửa sổ chính:

import tkinter as tk
from tkinter import ttk

class App(tk.Tk):
    def __init__(self):
        super().__init__()
        python_image = tk.PhotoImage(file='./assets/python.png')
        ttk.Label(self, image=python_image).pack()

if __name__ == "__main__":
    app = App()
    app.mainloop()

Nếu bạn chạy chương trình này, bạn sẽ nhận thấy rằng cửa sổ không hiển thị hình ảnh. Tại sao lại như vậy?

Đó là vì python_image bị hủy ngay sau khi phương thức __init__() kết thúc. Do chương trình không có tham chiếu đến đối tượng PhotoImage, hình ảnh biến mất ngay cả khi bạn đã đưa nó vào bố cục giao diện.

Để khắc phục vấn đề này, bạn cần đảm bảo rằng python_image không bị thoát khỏi phạm vi sau khi phương thức __init__() kết thúc. Ví dụ, bạn có thể giữ nó trong đối tượng App như sau:

import tkinter as tk
from tkinter import ttk

class App(tk.Tk):
    def __init__(self):
        super().__init__()
        self.title('Tkinter PhotoImage Demo')
        self.geometry('320x150')

        self.python_image = tk.PhotoImage(file='./assets/python.png')
        ttk.Label(self, image=self.python_image).pack()

if __name__ == "__main__":
    app = App()
    app.mainloop()

Định dạng file hỗ trợ bởi Tkinter PhotoImage

Hiện tại, widget PhotoImage chỉ hỗ trợ các định dạng file GIF, PGM, PPM và PNG kể từ phiên bản Tkinter 8.6.

Để hỗ trợ các định dạng file khác như JPG, JPEG, hoặc BMP, bạn có thể sử dụng thư viện xử lý hình ảnh như Pillow để chuyển đổi chúng thành định dạng mà widget PhotoImage có thể hiểu.

Thực tế, thư viện Pillow có một widget PhotoImage tương thích với Tkinter được đặt trong module PIL.ImageTk.

Để cài đặt thư viện Pillow, bạn sử dụng lệnh pip sau:

pip install Pillow

Để sử dụng thư viện Pillow, bạn thực hiện các bước sau:

Bước 1: Import các lớp ImageImageTk:

from PIL import Image, ImageTk

Bước 2: Mở file ảnh và tạo một đối tượng PhotoImage mới:

image = Image.open('./assets/python.jpg')
python_image = ImageTk.PhotoImage(image)

Bước 3: Gán đối tượng ImageTk.PhotoImage vào tham số image:

image_label = ttk.Label(root, image=python_image)

Chương trình sau đây minh họa cách sử dụng widget PhotoImage từ thư viện Pillow:

import tkinter as tk
from tkinter import ttk
from PIL import Image, ImageTk

class App(tk.Tk):
    def __init__(self):
        super().__init__()
        self.title('Tkinter PhotoImage Demo')

        self.image = Image.open('./assets/python.jpg')
        self.python_image = ImageTk.PhotoImage(self.image)

        ttk.Label(self, image=self.python_image).pack()

if __name__ == '__main__':
    app = App()
    app.mainloop()

Kết bài

Tóm lại, widget PhotoImage trong Tkinter là một công cụ hữu ích để hiển thị hình ảnh trên các widget như Label hoặc Button. Tuy nhiên, PhotoImage chỉ hỗ trợ các định dạng file phổ biến như GIF, PGM, PPM, và PNG. Để làm việc với các định dạng file khác như JPG hoặc BMP, bạn có thể sử dụng widget PhotoImage từ module PIL.ImageTk của thư viện Pillow. Điều này mở rộng khả năng hiển thị hình ảnh trong ứng dụng Tkinter của bạn, giúp bạn tạo ra các giao diện trực quan và sinh động hơn.

Cùng chuyên mục:

Cách sử dụng lớp QTreeWidget của PyQt

Cách sử dụng lớp QTreeWidget của PyQt

Cách sử dụng lớp QTableWidget để tạo một bảng

Cách sử dụng lớp QTableWidget để tạo một bảng

Cách sử dụng lớp QListWidget trong Python

Cách sử dụng lớp QListWidget trong Python

Cách dùng lớp QStatusBar trong PyQt để tạo thanh status bar

Cách dùng lớp QStatusBar trong PyQt để tạo thanh status bar

Cách dùng lớp QDockWidget của PyQt để tạo một widget

Cách dùng lớp QDockWidget của PyQt để tạo một widget

Cách dùng lớp PyQt QToolBar để tạo các widget toolbar

Cách dùng lớp PyQt QToolBar để tạo các widget toolbar

Cách sử dụng lớp PyQt QMenu để tạo menu

Cách sử dụng lớp PyQt QMenu để tạo menu

Cách sử dụng lớp QMainWindow của PyQt để tạo cửa sổ

Cách sử dụng lớp QMainWindow của PyQt để tạo cửa sổ

Cách dùng lớp PyQt QFileDialog để tạo hộp thoại chọn file

Cách dùng lớp PyQt QFileDialog để tạo hộp thoại chọn file

Cách dùng lớp PyQt QInputDialog để tạo một hộp thoại nhập liệu

Cách dùng lớp PyQt QInputDialog để tạo một hộp thoại nhập liệu

Cách sử dụng lớp PyQt QMessageBox để tạo một hộp thoại

Cách sử dụng lớp PyQt QMessageBox để tạo một hộp thoại

Cách sử dụng lớp PyQt QProgressBar để tạo một widget progress bar

Cách sử dụng lớp PyQt QProgressBar để tạo một widget progress bar

Cách dùng lớp PyQt QTextEdit để tạo một widget cho phép chỉnh sửa

Cách dùng lớp PyQt QTextEdit để tạo một widget cho phép chỉnh sửa

Cách dùng lớp PyQt QGroupBox để tạo một khung nhóm với tiêu đề

Cách dùng lớp PyQt QGroupBox để tạo một khung nhóm với tiêu đề

Cách dùng lớp PyQt QTabWidget để tạo một widget dạng tab

Cách dùng lớp PyQt QTabWidget để tạo một widget dạng tab

Cách dùng PyQt QWidget để làm container chứa các widget khác.

Cách dùng PyQt QWidget để làm container chứa các widget khác.

Cách sử dụng lớp PyQt QSlider để tạo một widget thanh trượt (slider).

Cách sử dụng lớp PyQt QSlider để tạo một widget thanh trượt (slider).

Cách tạo một widget nhập ngày và giờ sử dụng PyQt QDateTimeEdit

Cách tạo một widget nhập ngày và giờ sử dụng PyQt QDateTimeEdit

Cách tạo một widget nhập giờ sử dụng lớp PyQt QTimeEdit

Cách tạo một widget nhập giờ sử dụng lớp PyQt QTimeEdit

Cách tạo một widget nhập ngày sử dụng lớp PyQt QDateEdit

Cách tạo một widget nhập ngày sử dụng lớp PyQt QDateEdit

Top