hpgl_qt.py

Fri, 11 Jan 2008 18:50:08 +0100

author
David Douard <david.douard@logilab.fr>
date
Fri, 11 Jan 2008 18:50:08 +0100
changeset 21
66b7cd43bac1
child 23
cb97962a1ae9
permissions
-rw-r--r--

Add HPGL plotter backend for Qt4

21
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
1 # -*- coding: utf-8 -*-
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
2 import numpy
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
3 import pylab
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
4 import math
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
5 import new # monkey patching...
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
6
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
7 from PyQt4 import QtGui, QtCore
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
8 from PyQt4.QtCore import Qt, SIGNAL
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
9
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
10 from hpgl_parser import HPGLParser
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
11
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
12 class QHPGLPlotterWidget(HPGLParser, QtGui.QWidget):
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
13 pen_styles = {2: [0.4, 0.6],
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
14 3: [0.6, 0.4],
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
15 4: [0.7, 0.1, 0.1, 0.1],
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
16 5: [0.6, 0.1, 0.2, 0.1],
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
17 6: [0.45, 0.1, 0.1, 0.2, 0.1, 0.05],
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
18 }
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
19 pen_colors = ["black", "green", "red", "blue", "yellow", "cyan", "magenta",
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
20 "darkred", "darkblue"]
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
21
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
22 def __init__(self, parent=None):
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
23 QtGui.QWidget.__init__(self, parent)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
24
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
25 self.qpen = QtGui.QPen(QtCore.Qt.blue)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
26 self.qbrush = QtGui.QBrush(QtCore.Qt.blue)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
27 self.qfont = QtGui.QFont('Courier')
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
28 self.qantialiased = False
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
29 self.qtransformed = False
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
30 self.qscene = QtGui.QGraphicsScene()
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
31 self.qview = QtGui.QGraphicsView(self.qscene, self)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
32 self.qview.scale(0.5,-0.5)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
33 l = QtGui.QVBoxLayout(self)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
34 l.addWidget(self.qview)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
35 self.setBackgroundRole(QtGui.QPalette.Base)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
36 self.setSizePolicy(QtGui.QSizePolicy.Expanding,
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
37 QtGui.QSizePolicy.Expanding)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
38 HPGLParser.__init__(self)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
39
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
40 def _get_PW(self):
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
41 return self._pen_width
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
42 def _set_PW(self, value):
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
43 value = float(value)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
44 #print "set pen width", value, value*300.0/75.0
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
45 #self.qpen.setWidthF(value*300.0/75.0)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
46 self._pen_width = value
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
47 pen_width = property(_get_PW, _set_PW)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
48
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
49 def LT(self):
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
50 HPGLParser.LT(self)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
51 if self.line_type == 0:
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
52 self.qpen.setStyle(Qt.SolidLine)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
53 elif self.line_type == 1:
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
54 self.qpen.setStyle(Qt.DotLine)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
55 else:
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
56 pattern = numpy.array(self.pen_styles[self.line_type])
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
57 x0, x1, y0, y1 = self.scale
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
58 dist = math.sqrt((x1-x0)**2 + (y1-y0)**2)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
59 pattern = self.pattern_len*dist/100.0 * pattern
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
60 if self.qpen.widthF()>0:
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
61 pattern = pattern/self.qpen.widthF()
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
62 self.qpen.setDashPattern(pattern.tolist())
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
63
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
64 def SP(self):
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
65 HPGLParser.SP(self)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
66 self.qpen.setColor(QtGui.QColor(self.pen_colors[self.pen]))
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
67
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
68 def parse(self, data):
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
69 HPGLParser.parse(self, data)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
70 self.update()
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
71 self.qview.fitInView(self.qscene.sceneRect(), Qt.KeepAspectRatio)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
72
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
73 def minimumSizeHint(self):
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
74 return QtCore.QSize(100, 100)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
75
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
76 def sizeHint(self):
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
77 return QtCore.QSize(400, 400)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
78
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
79 def resizeEvent(self, event):
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
80 self.qview.fitInView(self.qscene.sceneRect(), Qt.KeepAspectRatio)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
81 QtGui.QWidget.resizeEvent(self, event)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
82
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
83 def plot_lines(self, points):
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
84 if len(points) == 1:
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
85 return
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
86 pa = QtGui.QPainterPath()
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
87 pa.addPolygon(QtGui.QPolygonF([QtCore.QPointF(*p) for p in points]))
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
88 self.qscene.addPath(pa, self.qpen)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
89
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
90 def plot_symbols(self, points):
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
91 pass
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
92
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
93 def plot_string(self, s):
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
94 cw, ch = self.get_char_size()
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
95 # this is very ugly and so, but I don't understand haw is
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
96 # computed string positionning in HPGL...
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
97 t0 = self.qscene.addSimpleText(" ", self.qfont)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
98 br = t0.boundingRect()
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
99 mw = br.width()
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
100 mh = br.height()
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
101 self.qscene.removeItem(t0)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
102 # don't ask me why theses constants are here, they seem OK, that's all
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
103 t = self.qscene.addSimpleText(s, self.qfont)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
104 t.scale(1.5 * cw/mw, -2.0 * ch/mh)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
105 x, y = self.pos
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
106 t.moveBy(x,y)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
107 br = t.boundingRect()
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
108 t.moveBy(-0.5*cw, math.sqrt(2)*ch)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
109
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
110
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
111 if __name__=='__main__':
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
112 import sys
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
113 a = QtGui.QApplication(sys.argv)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
114 mw = QtGui.QMainWindow()
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
115 w = QtGui.QWidget(mw)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
116 mw.setCentralWidget(w)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
117
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
118 l = QtGui.QVBoxLayout(w)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
119 p = QHPGLPlotterWidget(w)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
120 l.addWidget(p, 1)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
121 b = QtGui.QPushButton("Replot", w)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
122 l.addWidget(b)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
123 def plot():
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
124 p.parse(open(sys.argv[1]).read())
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
125 b.connect(b, SIGNAL('pressed()'), plot)
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
126 mw.show()
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
127 plot()
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
128 a.exec_()
66b7cd43bac1 Add HPGL plotter backend for Qt4
David Douard <david.douard@logilab.fr>
parents:
diff changeset
129

mercurial