婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PyQt5入門之基于QListWidget版本實現圖片縮略圖列表功能

PyQt5入門之基于QListWidget版本實現圖片縮略圖列表功能

熱門標簽:湛江電銷防封卡 徐州天音防封電銷卡 電話機器人適用業務 鄭州智能外呼系統運營商 獲客智能電銷機器人 佛山防封外呼系統收費 南昌辦理400電話怎么安裝 不錯的400電話辦理 哈爾濱外呼系統代理商

需求描述

最近在寫一個圖像標注小工具,其中需要用到一個縮略圖列表,來查看文件夾內的圖片文件。

這里整理一個基于QListWidget實現的版本,簡單可用。

示例效果

代碼示例

QListWidget官方文檔:[link]

其中,需要用到的QListWidget信號:

itemSelectionChanged:所選項發生變化時發送。

先定義縮略圖列表部分,繼承自QListWidget。每個QListWidgetItem可以設置QIcon圖片和文本。

import os
from qtpy.QtCore import QSize
from qtpy.QtGui import QIcon,QPixmap
from PyQt5.QtWidgets import QListWidget,QListWidgetItem,QListView,QWidget,QApplication,QHBoxLayout,QLabel

class ImageListWidget(QListWidget):
    def __init__(self):
        super(ImageListWidget, self).__init__()
        self.setFlow(QListView.Flow(1))#0: left to right,1: top to bottom
        self.setIconSize(QSize(150,100))

    def add_image_items(self,image_paths=[]):
        for img_path in image_paths:
            if os.path.isfile(img_path):
                img_name = os.path.basename(img_path)
                item = QListWidgetItem(QIcon(img_path),img_name)
                # item.setText(img_name)
                # item.setIcon(QIcon(img_path))
                self.addItem(item)

再來簡單布局下窗體控件:

左邊區域用QLabel加載圖像,右邊區域是圖片縮略圖列表,點擊縮略圖,可以在左邊查看大圖。

class ImageViewerWidget(QWidget):
    def __init__(self):
        super(QWidget, self).__init__()
        # 顯示控件
        self.list_widget = ImageListWidget()
        self.list_widget.setMinimumWidth(200)
        self.show_label = QLabel(self)
        self.show_label.setFixedSize(600,400)
        self.image_paths = []
        self.currentImgIdx = 0
        self.currentImg = None

        # 水平布局
        self.layout = QHBoxLayout(self)
        self.layout.addWidget(self.show_label)
        self.layout.addWidget(self.list_widget)

        # 信號與連接
        self.list_widget.itemSelectionChanged.connect(self.loadImage)

    def load_from_paths(self,img_paths=[]):
        self.image_paths = img_paths
        self.list_widget.add_image_items(img_paths)

    def loadImage(self):
        self.currentImgIdx = self.list_widget.currentIndex().row()
        if self.currentImgIdx in range(len(self.image_paths)):
            self.currentImg = QPixmap(self.image_paths[self.currentImgIdx]).scaledToHeight(400)
            self.show_label.setPixmap(self.currentImg)

加載一些圖片路徑,并運行窗口:

if __name__=="__main__":
    import sys
    app = QApplication(sys.argv)

    # 圖像路徑
    img_dir = r"E:\Pic"
    filenames = os.listdir(img_dir)
    img_paths=[]
    for file in filenames:
        if file[-4:]==".png" or file[-4:]==".jpg":
            img_paths.append(os.path.join(img_dir,file))

    # 顯示控件
    main_widget = ImageViewerWidget()
    main_widget.load_from_paths(img_paths)
    main_widget.setWindowTitle("ImageViewer")
    main_widget.show()

    # 應用程序運行
    sys.exit(app.exec_())

小結

  • 上面代碼只是一個實現思路,實際應用中最好另開一個線程加載圖片,并且隨著滾動條下拉,再不斷加載緩存。
  • QListWidget可以實現簡單的圖標+文字列表,如果列表項中涉及自定義控件和其他操作邏輯,建議采用QListView和Model實現。

到此這篇關于PyQt5入門之QListWidget實現圖片縮略圖列表功能的文章就介紹到這了,更多相關PyQt5 QListWidget圖片縮略圖內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • pyqt5 QListWidget的用法解析
  • PyQt5 在QListWidget自定義Item的操作
  • PyQt5 QListWidget選擇多項并返回的實例

標簽:安康 蘭州 紹興 廣西 呂梁 蕪湖 吉安 懷化

巨人網絡通訊聲明:本文標題《PyQt5入門之基于QListWidget版本實現圖片縮略圖列表功能》,本文關鍵詞  PyQt5,入門,之,基于,QListWidget,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PyQt5入門之基于QListWidget版本實現圖片縮略圖列表功能》相關的同類信息!
  • 本頁收集關于PyQt5入門之基于QListWidget版本實現圖片縮略圖列表功能的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 中超| 南郑县| 台前县| 阿克陶县| 大新县| 紫金县| 沽源县| 哈密市| 三都| 海伦市| 江阴市| 车险| 噶尔县| 静海县| 磐石市| 隆化县| 义马市| 石城县| 蒙山县| 侯马市| 行唐县| 兴山县| 凌海市| 文山县| 潞西市| 望都县| 邵阳市| 泰宁县| 霍林郭勒市| 英吉沙县| 安化县| 临洮县| 陆川县| 民和| 运城市| 丹阳市| 庆阳市| 台山市| 华坪县| 呼伦贝尔市| 汉川市|