zoukankan      html  css  js  c++  java
  • MyQThread new

    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
    """
    @version: 001
    @author: jianpan
    @file: MyQThread.py
    @time: 2017/6/3 11:54
    """
    from PyQt4.QtCore import *
    import Tkinter as tk
    import multiprocessing
    import os
    import psutil
    
    
    class MyQThread(QThread):
        def __init__(self, parent=None):
            super(MyQThread, self).__init__(parent)
            self.working = True
            self.num = 0
    
        def __del__(self):
            self.working = False
            self.wait()
            self.pid = 0
    
        def run(self):
            pass
    
        def open(self):
            try:
                os.popen('taskkill /pid %s  -f' % (str(self.pid)))
            except Exception, e:
                print e
            pool = multiprocessing.Pool(processes=1)
            print os.getpid()
            for i in xrange(1):
                pool.apply_async(func,)  # 维持执行的进程总数为processes,当一个进程执行完毕后会添加新的进程进去
            t = psutil.Process()
            print "Process :", t.pid
            pool.close()
            children = t.children()
            for child in children:
                print('Child pid is {}'.format(child.pid))
                self.pid = child.pid
            # pool.join()  # 调用join之前,先调用close函数,否则会出错。执行完close后不会有新的进程加入到pool,join函数等待所有子进程结束
            print "Sub-process(es) done."
    
    
    def func():
        root = WarningTK()
    
    
    class MyQThreadSleep60(QThread):
        def __init__(self, parent=None):
            super(MyQThreadSleep60, self).__init__(parent)
            self.working = True
            self.num = 0
    
        def __del__(self):
            self.working = False
            self.wait()
    
        def run(self):
            while self.working == True:
                file_str = 'File index {0}'.format(self.num)
                self.num += 1
                self.sleep(10)
                self.emit(SIGNAL('output(QString)'), file_str)
    
    
    
    class MyQThread_30(QThread):
        def __init__(self, parent=None):
            super(MyQThread_30, self).__init__(parent)
            self.working = True
            self.num = 0
    
        def __del__(self):
            self.working = False
            self.wait()
    
        def run(self):
            while self.working == True:
                file_str = 'File index {0}'.format(self.num)
                self.num += 1
                self.sleep(20)
                self.emit(SIGNAL('output(QString)'), file_str)
    
    
    class MyQThreadDelay(QThread):
        def __init__(self, parent=None):
            super(MyQThreadDelay, self).__init__(parent)
            self.working = True
            self.num = 0
    
        def run(self):
            os.popen('warning.mp3')
            print 'finish'
    
    
    class MyQThread_Warning(QThread):
        def __init__(self, parent=None):
            super(MyQThread_Warning, self).__init__(parent)
            self.working = True
            self.num = 0
    
        def run(self):
            print '1'
    
        def open(self):
            self.root = WarningTK()
            self.root.mainloop()
    
        def getDlg(self):
            return self.root.destroy
    
        def close(self):
            try:
                self.root.quit()
                self.root.destroy()
            except Exception, e:
                print e
    
    
    class WarningTK(tk.Tk):
        def __init__(self, master=None):
            tk.Tk.__init__(self, master)
            self.title('test')
            self.withdraw()
            screenwidth = self.winfo_screenwidth()
            screenheight = self.winfo_screenheight() - 100
            self.resizable(False, False)
            # 添加组件
            self.title("Warning!!")
            frame = tk.Frame(self, relief=tk.RIDGE, borderwidth=3)
            frame.pack(fill=tk.BOTH, expand=1)  # pack() 放置组件若没有则组件不会显示
            # 窗口显示的文字、并设置字体、字号
            label = tk.Label(frame, text="You have been working 30 minutes! Please have a break!!", 
                             font="Monotype Corsiva -20 bold")
            label.pack(fill=tk.BOTH, expand=1)
            # 按钮的设置
            self.button1 = tk.Button(frame, text="OK", font="Cooper -25 bold", fg="red", command=self.destroy)
            self.button1.pack(side=tk.BOTTOM)
    
            self.update_idletasks()
            self.deiconify()  # now the window size was calculated
            self.withdraw()  # hide the window again 防止窗口出现被拖动的感觉 具体原理未知?
            self.geometry(
                '%sx%s+%s+%s' % (self.winfo_width() + 10, self.winfo_height() + 10,
                                 (screenwidth - self.winfo_width()) / 2,
                                 (screenheight - self.winfo_height()) / 2))
            self.deiconify()
            self.mainloop()
    
    
    
  • 相关阅读:
    老旧ObjectARX SDK下载地址
    AutoCAD Civil 3D .NET 二次开发 勘误
    lisp网站
    Autodesk论坛中看到的一段代码,留存备用
    revit图纸导出dxf文件批量修改
    查询给定区域内曲面平均高程
    angular 输入型指令directive
    get set方法
    android 环境配置
    使用nginx启动angular项目
  • 原文地址:https://www.cnblogs.com/jian-pan/p/6941246.html
Copyright © 2011-2022 走看看