第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會有你想問的

如何調(diào)試 QComboBox 發(fā)出多個(gè)“激活”信號

如何調(diào)試 QComboBox 發(fā)出多個(gè)“激活”信號

瀟瀟雨雨 2022-06-07 19:59:35
我在這里找到了一個(gè)很好的資源來構(gòu)建一個(gè) QComboBox,它提供了一個(gè)過濾的建議列表。除了每次我在組合框中選擇建議的選項(xiàng)時(shí),“activated”和“currentIndexChanged”信號會發(fā)出三次之外,它運(yùn)行良好。行為會有所不同,具體取決于是通過鼠標(biāo)還是使用箭頭鍵和 Enter 按鈕選擇了該選項(xiàng)。我的問題是,我該如何調(diào)試?代碼中沒有必要捕獲和阻止前兩個(gè)信號發(fā)出。有沒有辦法覆蓋 QComboBox “激活”信號以嘗試在行為中捕獲它?還是我必須定義自己的信號并使用它?這是代碼:#!/usr/bin/env python# -*- coding: utf-8 -*-from PySide2 import QtCore, QtGui, QtWidgetsfrom PySide2.QtCore import Qt, QSortFilterProxyModelfrom PySide2.QtWidgets import QCompleter, QComboBoxclass ExtendedComboBox(QComboBox):    def __init__(self, parent=None):        super(ExtendedComboBox, self).__init__(parent)        self.setFocusPolicy(Qt.StrongFocus)        self.setEditable(True)        # add a filter model to filter matching items        self.pFilterModel = QSortFilterProxyModel(self)        self.pFilterModel.setFilterCaseSensitivity(Qt.CaseInsensitive)        self.pFilterModel.setSourceModel(self.model())        # add a completer, which uses the filter model        self.completer = QtWidgets.QCompleter(self)        self.completer.setModel(self.pFilterModel)        # always show all (filtered) completions        self.completer.setCompletionMode(QCompleter.UnfilteredPopupCompletion)        self.setCompleter(self.completer)        # connect signals        self.lineEdit().textEdited.connect(self.pFilterModel.setFilterFixedString)        self.completer.activated.connect(self.on_completer_activated)    # on selection of an item from the completer, select the corresponding item from combobox     def on_completer_activated(self, text):        if text:            index = self.findText(text)            self.setCurrentIndex(index)            # self.activated.emit(self.itemText(index))您會注意到,如果您運(yùn)行代碼并開始在文本框中輸入“hello”,然后單擊建議的“hello world”,activated信號會返回正確的“hello world”。如果你開始輸入“hello”,但這次使用箭頭鍵向下滾動到“hello world”,它會發(fā)出 3 次。我已經(jīng)嘗試過多次實(shí)現(xiàn)同樣的想法,結(jié)果都一樣。在用新模型替換模型后,我什至注意到未修改的 QComboBox 的類似行為。PySide2 5.6.0a1 Windows 10.0.18362 內(nèi)部版本 18362謝謝參觀!
查看完整描述

2 回答

?
隔江千里

TA貢獻(xiàn)1906條經(jīng)驗(yàn) 獲得超10個(gè)贊

我使用的是 PySide2 5.6.0a1,因?yàn)檫@是 Anaconda 在 Python 2.7 環(huán)境中安裝的一個(gè)。@eyllanesc 指出這是一個(gè)早期和過時(shí)的版本,可能有問題。

當(dāng)我在 Python 3.7 環(huán)境中使用 PySide2-5.13.1 嘗試相同的代碼時(shí),一切都按預(yù)期工作。


查看完整回答
反對 回復(fù) 2022-06-07
?
人到中年有點(diǎn)甜

TA貢獻(xiàn)1895條經(jīng)驗(yàn) 獲得超7個(gè)贊

我沒有 PySide2,但在大多數(shù)情況下,我認(rèn)為您所要做的就是用 PySide2 替換我的 PyQt5 引用——因?yàn)檫@就是我所做的一切讓你的程序從 PySide2 切換到 PyQt5 ——還有一點(diǎn)重組和微調(diào)給了我以下功能代碼:


from sys import exit as sysExit


from PyQt5.QtCore import Qt, QSortFilterProxyModel, QStringListModel, pyqtSlot

from PyQt5.QtWidgets import QApplication, QWidget, QCompleter, QComboBox, QCompleter, QHBoxLayout


class ExtendedComboBox(QComboBox):

    def __init__(self):

        QComboBox.__init__(self)


        self.setFocusPolicy(Qt.StrongFocus)

        self.setEditable(True)


        # add a filter model to filter matching items

        self.pFilterModel = QSortFilterProxyModel(self)

        self.pFilterModel.setFilterCaseSensitivity(Qt.CaseInsensitive)

        self.pFilterModel.setSourceModel(self.model())


        # add a completer, which uses the filter model

        self.completer = QCompleter(self)

        self.completer.setModel(self.pFilterModel)


        # always show all (filtered) completions

        self.completer.setCompletionMode(QCompleter.UnfilteredPopupCompletion)

        self.setCompleter(self.completer)


        # connect signals

        self.lineEdit().textEdited.connect(self.pFilterModel.setFilterFixedString)

        self.completer.activated.connect(self.on_completer_activated)


    # on selection of an item from the completer, select the corresponding item from combobox 

    def on_completer_activated(self, text):

        if text:

            index = self.findText(text)

            self.setCurrentIndex(index)

            # self.activated.emit(self.itemText(index))



    # on model change, update the models of the filter and completer as well 

    def setModel(self, model):

        self.setModel(model)

        self.pFilterModel.setSourceModel(model)

        self.completer.setModel(self.pFilterModel)



    # on model column change, update the model column of the filter and completer as well

    def setModelColumn(self, column):

        self.completer.setCompletionColumn(column)

        self.pFilterModel.setFilterKeyColumn(column)

        self.setModelColumn(column)    


class MainApp(QWidget):

    def __init__(self):

        QWidget.__init__(self)


        string_list = ['hola muchachos', 'adios amigos', 'hello world', 'good bye']


        self.combo = ExtendedComboBox()


        # either fill the standard model of the combobox

        self.combo.addItems(string_list)

        self.combo.currentIndexChanged[str].connect(self.change_option)

        # or use another model

        #combo.setModel(QStringListModel(string_list))


        self.resize(300, 100)

        self.combo.resize(300, 50)


        HBox = QHBoxLayout()

        HBox.addWidget(self.combo)


        self.setLayout(HBox)


    @pyqtSlot(str)

    def change_option(self, text):

        print(text)


if __name__ == "__main__":

    MainThred = QApplication([])


    MainGui = MainApp()

    MainGui.show()


    sysExit(MainThred.exec_())

我認(rèn)為問題是您試圖將 Signals/Slots 與非 QObject 函數(shù)(又名)一起使用,您的 change_option 函數(shù)與從 QObject 繼承的任何內(nèi)容都沒有直接關(guān)聯(lián),所以我不確定它在做什么或沒有在做什么,但是只是一個(gè)猜測,因?yàn)槲宜龅囊磺卸急环湃肓艘粋€(gè)正常的 Qt 結(jié)構(gòu)中,它工作得很好


查看完整回答
反對 回復(fù) 2022-06-07
  • 2 回答
  • 0 關(guān)注
  • 223 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號