Python事多,做个笔记,区分。

PySide2 Signal Slot Test

from PySide2.QtWidgets import QMainWindow,QApplication,QWidget,QPushButton
from PySide2 import QtWidgets
from PySide2.QtCore import Slot, Signal import sys class MyCenWidget(QWidget): closeSignal = Signal() quitSignal = Signal() def __init__(self,parent = None):
super(MyCenWidget, self).__init__(parent)
# first create layout
self.createAndSetLayout()
# add widget to my layout
self.createButtons() def createAndSetLayout(self):
self.mainLayout = QtWidgets.QHBoxLayout()
self.setLayout(self.mainLayout) def createButtons(self):
self.closeBtn = QPushButton(self)
self.closeBtn.setText("Close")
self.closeBtn.clicked.connect(self.closeSignal) # 信号连接信号
self.mainLayout.addWidget(self.closeBtn) # Quit button settings
self.quitBtn = QPushButton(self)
self.quitBtn.setText("Quit")
self.quitBtn.clicked.connect(self.quitSlot)
self.mainLayout.addWidget(self.quitBtn) def quitSlot(self):
print("我的中心控件点了quit button")
self.quitSignal.emit() class MyWindow(QMainWindow):
def __init__(self):
super(MyWindow, self).__init__() # create my widget
self.setupMenuBar()
# bind my widget to function
self.accessMenuBar() # take my widget to here
cenWidget = MyCenWidget() # 野指针
cenWidget.closeSignal.connect(self.close) # 从我定义的窗口里发射的信号,这个是closeSignal
cenWidget.quitSignal.connect(self.close) self.setCentralWidget(cenWidget) # 基类有个函数让我设置它到我的QMainWindow def setupMenuBar(self):
parentMenuBar = self.menuBar() fileMenu = parentMenuBar.addMenu("File")
self.newAction = fileMenu.addAction("new") editMenu = parentMenuBar.addMenu("Edit")
self.undoAction = editMenu.addAction("undo") # make connection new action
def accessMenuBar(self):
self.newAction.triggered.connect(self.newSlot) @Slot(bool)
def newSlot(self, checked):
print("into my new slot") if __name__ == "__main__":
app = QApplication(sys.argv)
print("My window argv:", sys.argv)
w = MyWindow()
w.show()
app.exec_()

PyQt5 Reference Guide

http://pyqt.sourceforge.net/Docs/PyQt5/index.html

Qt4 signal:

class CopyFileThread(QtCore.QThread):
signal_process = QtCore.pyqtSignal(str, str, bool) def __init__(self, parent=None):
super(CopyFileThread, self).__init__(parent)
self.finished.connect(self.taskEnd) def setSourceAndDestination(self, src, des):
self.source = src
self.des = des
self.status = False def run(self):
#print "copy -> ", self.source, self.des
# QtCore.QFile.copy(self.source,self.des)
try:
shutil.copy(self.source, self.des)
self.status = True
except:
self.status = False def taskEnd(self):
self.signal_process.emit(self.source, self.des, self.status)

接受这个signal槽:

@QtCore.pyqtSlot(str, str, bool)
def perThreadCopyEnd(self, src, des, status):
self.taskNum += 1
if (status):
self.throwMessage(">>" + src + "\t->->->->\t" + des + "<<copy end")
else:
self.throwMessage(">>" + src + "\tT_T T_T T_T\t" + des + "<<copy failed")
if self.taskNum == len(self.sources):
self.throwMessage(">> process end")

Qt5展示的一些发射信号:

from PyQt5.QtCore import QObject, pyqtSignal

class Foo(QObject):

    # Define a new signal called 'trigger' that has no arguments.
trigger = pyqtSignal() def connect_and_emit_trigger(self):
# Connect the trigger signal to a slot.
self.trigger.connect(self.handle_trigger) # Emit the signal.
self.trigger.emit() def handle_trigger(self):
# Show that the slot has been called. print "trigger signal received"

信号重载

from PyQt5.QtWidgets import QComboBox

class Bar(QComboBox):

    def connect_activated(self):
# The PyQt5 documentation will define what the default overload is.
# In this case it is the overload with the single integer argument.
self.activated.connect(self.handle_int) # For non-default overloads we have to specify which we want to
# connect. In this case the one with the single string argument.
# (Note that we could also explicitly specify the default if we
# wanted to.)
self.activated[str].connect(self.handle_string) def handle_int(self, index):
print "activated signal passed integer", index def handle_string(self, text):
print "activated signal passed QString", text

QML:

<1> show 一个qml里的window

import QtQuick 2.0
import QtQuick.Window 2.2
import QtQuick.Controls 1
import QtQuick.Dialogs 1.2 Window
{
id:root
width:1280
height:720
Rectangle
{
id:rec
color:"#FF2020"
width:100
height:100
anchors.centerIn:parent
border.color:"#202020"
border.width:1
}
MouseArea
{
id:quitArea
anchors.fill:
{
rec
}
onClicked:
{
close()
}
} }

main.py:

from PyQt5 import QtWidgets,QtGui,QtCore
from PyQt5 import QtQml
from PyQt5.QtQuick import QQuickView,QQuickWindow import sys
if __name__ == "__main__":
app = QtGui.QGuiApplication(sys.argv) eng = QtQml.QQmlApplicationEngine()
eng.load(QtCore.QUrl.fromLocalFile('./UI/main.qml')) topLevel = eng.rootObjects()[0]
print topLevel
topLevel.show() app.exec_()

创建混合窗口:

按钮是QPushButton,下面的白色区域是QtQuickWindow

from PyQt5 import QtWidgets,QtGui,QtCore
from PyQt5 import QtQml
from PyQt5.QtQuick import QQuickView,QQuickWindow import sys
if __name__ == "__main__":
app = QtWidgets.QApplication(sys.argv) eng = QtQml.QQmlApplicationEngine() eng.load(QtCore.QUrl.fromLocalFile('./UI/Main.qml')) topLevel = eng.rootObjects()[0]
print topLevel
#topLevel.show() layout = QtWidgets.QVBoxLayout()
button = QtWidgets.QPushButton()
button.setText("houdini")
layout.addWidget(button) mainWidget = QtWidgets.QWidget() quickWidget = QtWidgets.QWidget.createWindowContainer(topLevel)
#quickWidget.show()
mainWidget.setLayout(layout)
layout.addWidget(quickWidget)
mainWidget.show()
app.exec_()

PyQt4 / PyQt5的更多相关文章

  1. Python pyQt4/PyQt5 学习笔记3(绝对对位,盒布局,网格布局)

    本节研究布局管理的内容. (一)绝对对位  import sys from PyQt4 import QtGui class Example(QtGui.QWidget): def __init__( ...

  2. Python pyQt4/pyQt5 学习笔记2(状态栏、菜单栏和工具栏)

    例子:状态栏.菜单栏和工具栏 import sys from PyQt4 import QtGui class Example(QtGui.QMainWindow): def __init__(sel ...

  3. Python pyQt4/pyQt5 学习笔记1(空白窗口,按钮,控件事件,控件提示,窗体显示到屏幕中间,messagebox)

    PyQt4是用来编写有图形界面程序(GUI applications)的一个工具包.PyQt4作为一个Python模块来使用,它有440个类和超过6000种函数和方法.同时它也是一个可以在几乎所有主流 ...

  4. Python pyQt4/PyQt5 学习笔记4(事件和信号)

    信号 & 槽 import sys from PyQt5.QtCore import Qt from PyQt5.QtWidgets import (QWidget,QLCDNumber,QS ...

  5. PyQt 5.4参考指南 ---- PyQt5和PyQt4之间的差异

    欢迎关注博主主页,学习python视频资源,还有大量免费python经典文章 sklearn实战-乳腺癌细胞数据挖掘(博主亲自录制视频) https://study.163.com/course/in ...

  6. PyQt5初识

    学习PyQt5是个机缘,那是因为我的linux16.04+python3.6使了浑身解数也装不上PyQt4! PyQt5的官方文档貌似是要钱的!又想快速了解这个东东,我还是借鉴了万能的博客园大佬博主: ...

  7. GUI1_综合介绍

    最终比较,选择pyqt用于GUI开发 https://pythonspot.com/en/gui/ 图形化界面可以使用PyQt5, PyQt4, wxPython or Tk.模板 Graphical ...

  8. 共有49款Windows GUI开发框架开源软件 【转】

    源文 : http://www.oschina.net/project/tag/178/gui?lang=36&os=0&sort=view&p=1 桌面应用开发引擎 Allo ...

  9. 【pyqtgraph绘图】安装pyqtgraph

    解读官方API-安装 安装 参考:http://www.pyqtgraph.org/documentation/installation.html 根据您的需要,有许多不同的方式来安装pyqtgrap ...

随机推荐

  1. root登陆欢迎界面设置

    root登陆欢迎界面设置 #!/bin/bash echo -ne "\033[0;36m" cat<<EOF _oo0oo_ (| -_- |) \ = / ___/ ...

  2. SpringBoot项目部署在同一个tomcat容器报错

    在一个Tomcat容器中部署了两个springboot的应用,在启动时发现一直都是第一个启动的项目能启动成功,第二个项目启动报错,错误信息如下: 2018-01-30 15:49:27.810 ERR ...

  3. JAVA-Clone 对象拷贝

    JAVA 中对象的赋值是复制对象的引用,即复制引用 public static void main(String[] args) { User user = new User(1,"asds ...

  4. 11.享元模式(Flyweight Pattern)

    面向对象的代价    面向对象很好地解决了系统抽象性的问题,同时在大多数情况下,也不会损及系统的性能.但是,在某些特殊的应用中下,由于对象的数量太大,采用面向对象会给系统带来难以承受的内存开销.比如: ...

  5. [JVM-1]Java运行时数据区域

    Java虚拟机(JVM)内部定义了程序在运行时需要使用到的内存区域 这些区域都有自己的用途,以及创建和销毁的时间.有些区域随着虚拟机进程的启动而存在,有的区域则依赖用户线程的启动和结束而销毁和建立. ...

  6. logging 模块 与 logging 固定模块

    import logging # 1. 控制日志级别# 2. 控制日志格式# 3. 控制输出的目标为文件logging.basicConfig(filename='access.log', forma ...

  7. JS中var、let、const区别? 用3句话概括

    使用var声明的变量,其作用域为该语句所在的函数内,且存在变量提升现象: 使用let声明的变量,其作用域为该语句所在的代码块内,不存在变量提升: 使用const声明的是常量,在后面出现的代码中不能再修 ...

  8. 三十四、Linux 进程与信号——信号特点、信号集和信号屏蔽函数

    34.1 信号特点 信号的发生是随机的,但信号在何种条件下发生是可预测的 进程杠开始启动时,所有信号的处理方式要么默认,要么忽略:忽略是 SIGUSR1 和 SIGUSR2 两个信号,其他都采取默认方 ...

  9. python基础 range()与np.arange()

    range()返回的是range object,而np.nrange()返回的是numpy.ndarray() range尽可用于迭代,而np.nrange作用远不止于此,它是一个序列,可被当做向量使 ...

  10. class按传递时分析

    class FEF{ public: int a; FEF(int a,int b){ this->a = a*b; } }; void mam(FEF a){ printf("%d ...