wxPython实现画图板

yipeiwu_com5年前Python基础

本文实例为大家分享了wxPython画图板展示的具体代码,供大家参考,具体内容如下

#coding:GBK
'''
Created on 2012-3-22
@author: cWX53049
'''
import wx
import time
from bsddb.test.test_pickle import cPickle
import os
 
_formatStr="%Y-%m-%d %H:%M:%S"
 
class SkethWindow(wx.Window):
 
 
  def __init__(self,parent,ID):
    wx.Window.__init__(self,parent,ID)
    self.SetBackgroundColour("White")
    self.color="Black"
    self.thickness=1
    self.pen=wx.Pen(self.color,self.thickness,wx.SOLID)#创建一个pen
    self.lines=[]
    self.curLine=[]
    self.pos=(0,0)
    self.InitBuffer()
    self.Bind(wx.EVT_LEFT_DOWN, self.OnLeftDown)
    self.Bind(wx.EVT_LEFT_UP, self.OnLeftUp)
    self.Bind(wx.EVT_MOTION, self.OnMotion)
    self.Bind(wx.EVT_SIZE, self.OnSize)
    self.Bind(wx.EVT_SIZE, self.OnSize)
    self.Bind(wx.EVT_IDLE,self.OnIdle)
    self.Bind(wx.EVT_PAINT, self.OnPaint)
  def InitBuffer(self):
    size = self.GetClientSize()
    self.buffer=wx.EmptyBitmap(size.width,size.height)
    dc = wx.BufferedDC(None,self.buffer)
    dc.SetBackground(wx.Brush(self.GetBackgroundColour())) 
    dc.Clear()
    self.DrawLines(dc)
    self.reInitBuffer=False
  def GetLinesData(self):
    return self.lines[:]
  def SetLinesData(self,lines):
    self.lines = lines[:]
    self.InitBuffer()
    self.Refresh()  
  def OnLeftDown(self,event):
    self.curLine=[] 
    self.pos=event.GetPositionTuple()#得到鼠标的位置
    self.CaptureMouse()#捕获鼠标
  def OnLeftUp(self,event):
    if self.HasCapture():
      self.lines.append((self.color,
               self.thickness,
               self.curLine))
      self.curLine=[]
      self.ReleaseMouse()#释放鼠标
  def OnMotion(self,event):
    if event.Dragging() and event.LeftIsDown():#确定是否在拖动
      dc = wx.BufferedDC(wx.ClientDC(self),self.buffer)#创建另一个
      self.drawMotion(dc,event)
    event.Skip()
  def drawMotion(self,dc,event):
    dc.SetPen(self.pen)
    newPos=event.GetPositionTuple()
    coords=self.pos+newPos
    self.curLine.append(coords)
    dc.DrawLine(*coords)
    self.pos=newPos 
  def OnSize(self,event):
    self.reInitBuffer=True#处理一个resize事件
  def OnIdle(self,event):
    if self.reInitBuffer:
      self.InitBuffer()
      self.Refresh()
  def OnPaint(self,event):
    wx.BufferedPaintDC(self,self.buffer)
  def DrawLines(self,dc):
    for colur,thickness,line in self.lines:
      pen = wx.Pen(colur,thickness,wx.SOLID)
      dc.SetPen(pen)
      for coords in line:
        dc.DrawLine(*coords)
  def SetColor(self,color):
    self.color = color
    self.pen = wx.Pen(self.color,self.thickness,wx.SOLID)
  def SetThickness(self,num):
    self.thickness=num
    self.pen=wx.Pen(self.color,self.thickness,wx.SOLID)
    
    
class SkethFrame(wx.Frame):
  def __init__(self,parent):
    self.title="绘画窗体"
    wx.Frame.__init__(self,parent,-1,self.title,size=(500,500))
    self.sketh=SkethWindow(self,-1)
    self.InitStatusBar()
    self.sketh.Bind(wx.EVT_MOTION, self.showPosition)
    self.initMenuBar()
    self.wildcard="Sketch file(*.sketch)|All files(*.*)|*.*"
    self.fileName=""
    
  def OnNew(self,event):
    pass
  def OnOpen(self,event):
    pass
  def OnSave(self,event):
    if not self.fileName:
      self.OnSaveAs(event)
    else:
      self.SaveFile()
      
  def SaveFile(self):
    if self.fileName:
      data = self.sketh.GetLinesData()
      f = open(self.fileName,'w')  
      cPickle.dump(data, f)
      f.close()
  def OnSaveAs(self,event):
    dlf = wx.FileDialog(self,"Sketch file",os.getcwd(),style=wx.SAVE|wx.OVERWRITE_PROMPT)
    if dlf.ShowModal()==wx.ID_OK:
      fileName = dlf.GetPath()
      if not os.path.splitext(fileName)[1]:
        fileName=fileName+'.sketch'
        self.fileName=fileName 
        self.SaveFile()
    self.SetTitle(self.title+'--'+self.fileName)
    dlf.Destroy()           
  def OnColor(self,event):
    pass
  def OnCloseWindow(self,event):
    self.Destroy()  
  def menuData(self):
    return [("&File",(
         ("&New","New Sketch file",self.OnNew),
         ("&Open","open sketch file",self.OnOpen),
         ("&Save","save sktech file",self.OnSave),
         ("","",""),
         ("&Color",(
         ("&Black","",self.OnColor,wx.ITEM_RADIO),
         ("&Red","",self.OnColor,wx.ITEM_RADIO),
         ("&Red","",self.OnColor,wx.ITEM_RADIO),
         ("&Blue","",self.OnColor,wx.ITEM_RADIO))),
         ("","",""),
         ("&Quit","quit sketch ",self.OnCloseWindow)))]  
 
  def initMenuBar(self):
    menuBar=wx.MenuBar()
    for eachMenu in self.menuData():
      eachMenuLabel = eachMenu[0]
      eachMenuItems = eachMenu[1]
      menuBar.Append(self.createMenu(eachMenuItems),eachMenuLabel)
    self.SetMenuBar(menuBar)   
   
  def createMenu(self,menuData):
    menu = wx.Menu()
    for eachMenu in menuData:
      if len(eachMenu)==2:
        label = eachMenu[0]
        subBar =self.createMenu(eachMenu[1]) 
        menu.AppendMenu(wx.NewId(),label,subBar)
      else:
        self.createMenuItem(menu,*eachMenu)
    return menu
  
  def createMenuItem(self,menu,label,status,handler,kind=wx.ITEM_NORMAL):
    if not label:
      menu.AppendSeparator()
      return
    menuItem=menu.Append(-1,label,status,kind)
    self.Bind(wx.EVT_MENU,handler,menuItem)    
      
      
  def InitStatusBar(self):
    self.statusBar=self.CreateStatusBar()
    self.statusBar.SetFieldsCount(4)
    self.statusBar.SetStatusWidths([-1,-2,-2,-2])
    self.timer=wx.Timer(self)
    self.Bind(wx.EVT_TIMER, self.updateTime, self.timer)
    self.timer.Start(1000)
    self.statusBar.SetStatusText("Time is %s"%time.strftime(_formatStr,time.localtime()),3)
    self.statusBar.SetStatusText("Pos (0,0)",1)
    self.statusBar.SetStatusText("Cur Line 0",2)
    self.statusBar.SetStatusText("Lines 0" ,3)
    
    
  def showPosition(self,event):
    self.statusBar.SetStatusText("Pos %s"%str(event.GetPositionTuple()),0)
    self.statusBar.SetStatusText("Cur Line %s"%len(self.sketh.curLine),1)
    self.statusBar.SetStatusText("Lines %s"%len(self.sketh.lines),2)
    event.Skip() 
      
  def updateTime(self,event):
    self.statusBar.SetStatusText("Time is %s"%time.strftime(_formatStr,time.localtime()),3)
     
      
if __name__=="__main__":
  app = wx.PySimpleApp(False)
  frame=SkethFrame(None)
  frame.Center()
  frame.Show(True)
  app.MainLoop() 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持【听图阁-专注于Python设计】。

相关文章

numpy ndarray 按条件筛选数组,关联筛选的例子

最近的项目中大量涉及数据的预处理工作,对于ndarray的使用非常频繁。其中ndarray如何进行数值筛选,总结了几种方法。 1.按某些固定值筛选 如下面这段代码从,ndarray中可...

对Python模块导入时全局变量__all__的作用详解

对Python模块导入时全局变量__all__的作用详解

Python中一个py文件就是一个模块,“__all__”变量是一个特殊的变量,可以在py文件中,也可以在包的__init__.py中出现。 1、在普通模块中使用时,表示一个模块中允许哪...

python类的方法属性与方法属性的动态绑定代码详解

动态语言与静态语言有很多不同,最大的特性之一就是可以实现动态的对类和实例进行修改,在Python中,我们创建了一个类后可以对实例和类绑定心的方法或者属性,实现动态绑定。 最近在学习pyt...

python仿抖音表白神器

python仿抖音表白神器

Python能够干嘛? 可以做日常任务,比如自动备份你的MP3; 可以做网站,很多著名的网站像知乎、YouTube就是Python写的; 可以做网络游戏的后台,很多在线游戏的后台都是Py...

python实现比较两段文本不同之处的方法

本文实例讲述了python实现比较两段文本不同之处的方法。分享给大家供大家参考。具体实现方法如下: # find the difference between two texts #...