Example #1
0
 def draw_shapes(self):
   # really ugly redraw everything
   self.scene.clear()
   self.webview = QGraphicsWebView()
   self.webview.setZoomFactor(3.0)
   self.scene.setBackgroundBrush(Qt.black)
   self.scene.addItem(self.webview)
   w = self.width()*.5
   h = self.height()*.5
   width = "%spx" % (w)
   height = "%spx" % (h)
   dx = (int(self.parent.gl_dx + 1)/2)*2
   dy = (int(self.parent.gl_dy + 1)/2)*2
   vx = dx
   dy = dy
   self.dx = dx
   self.dy = dy
   print dx, dy
   # TODO: clever viewbox calculation     
   viewbox = "%d %d %d %d" % (-self.q*dx/2, -self.q*dy/2, self.q*dx, self.q*dy)
   rect = svgfig.Rect(-dx/2,-dy/2,dx/2,dy/2, fill='black', stroke=None).SVG(trans=self.trans)
   dot_field = self.draw_dot_field()
   print self.box.contentsRect()
   print width, height, viewbox
   svg_g = svgfig.SVG("g")
   svg_g.append(rect)
   for x in dot_field:
     svg_g.append(x)
   for shape in self.shapes:
     self.set_color(shape['type'])
     if 'shape' in shape:
       dispatch = {
         'circle': self.circle,
         'disc': self.disc,
         'label': self.label,
         'line': self.vertex,
         'vertex': self.vertex,
         'octagon': self.octagon,
         'rect': self.rect,
         'polygon': self.polygon,
         'hole': self.hole,
       }
       shape_svg = dispatch.get(shape['shape'], self.skip)(shape)
       print shape_svg
       for x in shape_svg:
         svg_g.append(x)
   
   #print subs
   canvas = svgfig.canvas(svg_g, width=width, height=height, viewBox=viewbox)
   xml = canvas.standalone_xml()
   print xml
   self.webview.setContent(QtCore.QByteArray(xml))
Example #2
0
 def __init__(self, parent, box):
   self.scene = QtGui.QGraphicsScene()
   super(JYDSVGWidget, self).__init__(self.scene, parent)
   self.parent = parent
   self.box = box
   self.webview = QGraphicsWebView()
   self.webview.setZoomFactor(3.0)
   self.scene.setBackgroundBrush(Qt.black)
   self.scene.addItem(self.webview)
   #self.scene.addText('Hello, world')
   self.zoomfactor = 42
   self.is_gl = False
   self.color_scheme = color_schemes[str(parent.setting('gl/colorscheme'))]
   self.trans = trans
   self.q = Q
Example #3
0
 def draw_shapes(self):
   # really ugly redraw everything
   self.scene.clear()
   self.webview = QGraphicsWebView()
   self.webview.setZoomFactor(3.0)
   self.scene.setBackgroundBrush(Qt.black)
   self.scene.addItem(self.webview)
   w = self.width()*.5
   h = self.height()*.5
   width = "%spx" % (w)
   height = "%spx" % (h)
   dx = (int(self.parent.gl_dx + 1)/2)*2
   dy = (int(self.parent.gl_dy + 1)/2)*2
   vx = dx
   dy = dy
   self.dx = dx
   self.dy = dy
   print dx, dy
   # TODO: clever viewbox calculation     
   viewbox = "%d %d %d %d" % (-self.q*dx/2, -self.q*dy/2, self.q*dx, self.q*dy)
   rect = svgfig.Rect(-dx/2,-dy/2,dx/2,dy/2, fill='black', stroke=None).SVG(trans=self.trans)
   dot_field = self.draw_dot_field()
   #print self.box.contentsRect()
   print width, height, viewbox
   svg_g = svgfig.SVG("g")
   svg_g.append(rect)
   for x in dot_field:
     svg_g.append(x)
   for shape in self.shapes:
     self.set_color(shape['type'])
     if 'shape' in shape:
       dispatch = {
         'circle': self.circle,
         'disc': self.disc,
         'label': self.label,
         'line': self.vertex,
         'vertex': self.vertex,
         'octagon': self.octagon,
         'rect': self.rect,
         'polygon': self.polygon,
         'hole': self.hole,
       }
       shape_svg = dispatch.get(shape['shape'], self.skip)(shape)
       #print shape_svg
       for x in shape_svg:
         svg_g.append(x)
   
   #print subs
   canvas = svgfig.canvas(svg_g, width=width, height=height, viewBox=viewbox)
   xml = canvas.standalone_xml()
   #print xml
   self.webview.setContent(QtCore.QByteArray(xml))
Example #4
0
 def __init__(self, parent, box):
   self.scene = QtGui.QGraphicsScene()
   super(JYDSVGWidget, self).__init__(self.scene, parent)
   self.parent = parent
   self.box = box
   self.webview = QGraphicsWebView()
   self.webview.setZoomFactor(3.0)
   self.scene.setBackgroundBrush(Qt.black)
   self.scene.addItem(self.webview)
   #self.scene.addText('Hello, world')
   self.zoomfactor = 42
   self.is_gl = False
   self.color_scheme = color_schemes[str(parent.setting('gl/colorscheme'))]
   self.trans = trans
   self.q = Q
Example #5
0
class JYDSVGWidget(QtGui.QGraphicsView):

  def __init__(self, parent, box):
    self.scene = QtGui.QGraphicsScene()
    super(JYDSVGWidget, self).__init__(self.scene, parent)
    self.parent = parent
    self.box = box
    self.webview = QGraphicsWebView()
    self.webview.setZoomFactor(3.0)
    self.scene.setBackgroundBrush(Qt.black)
    self.scene.addItem(self.webview)
    #self.scene.addText('Hello, world')
    self.zoomfactor = 42
    self.is_gl = False
    self.color_scheme = color_schemes[str(parent.setting('gl/colorscheme'))]
    self.trans = trans
    self.q = Q

  def _line(self, x1, y1, x2, y2, w):
    return [svgfig.Line(x1, y1, x2, y2, stroke_width=w*self.q, stroke=self.color).SVG(trans=self.trans)]

  def _ellipse(self, x, y, rx, ry, brush, w=0.05):
    stroke_width=None
    stroke=None
    fill=self.color
    if not brush:
      stroke = self.color
      stroke_width = w*self.q
      fill=None
    if rx-ry < 0.0001:
      (cx, cy) = self.trans(x,y)
      return [svgfig.SVG("circle",cx=cx,cy=cy,r=rx*self.q, stroke=stroke,stroke_width=stroke_width,fill=fill)]
    else:
      return [svgfig.Ellipse(x,y,rx,0,ry,stroke=stroke,stroke_width=stroke_width,fill=fill).SVG(trans=self.trans)]

  def draw_dot_field(self):
    self.dot_field_data = np.array(
      [[x,y] for x in range(-self.dx/2, self.dx/2+1) for y in range(-self.dy/2, self.dy/2+1)],
      dtype=np.float32)
    #grid drawing is really slow
    #re-enable when it is not redrawn every time
    self.set_color('grid')
    #for (x,y) in self.dot_field_data:
    #  self.scene.addEllipse(x, y, 0.001, 0.001, self.pen, self.brush)
    r = 0.05
    rpx = "%spx" % (r)
    dots = svgfig.Dots(self.dot_field_data, svgfig.make_symbol("dot_field", stroke=None, fill=self.color, r=r*self.q)).SVG(trans=self.trans)
    self.set_color('axes')
    res = [dots]
    res += self._line(-self.dx/2,0,self.dx/2,0, r)
    res += self._line(0,-self.dy/2, 0, self.dy/2, r)
    return res

  def set_shapes(self, shapes):
    self.shapes = shapes
    self.update()

  def update(self):
    self.draw_shapes()

  def set_color(self, t):
    if t == 'cu':
      t = 'smd'
    (r,g,b,a) = self.color_scheme.get(t, self.color_scheme['unknown'])
    self.color = svgfig.rgb(r,g,b)
    self.opacity = a

  # todo use itemgroups?
  def _hole(self, x, y, rx, ry):
    self.set_color('hole')
    res = []
    res += self._ellipse(x, y, rx, ry, False)
    rxa = rx/sqrt(2.0)
    rya = ry/sqrt(2.0)
    res += self._line(x-rxa, y-rya, x+rxa ,y+rya, 0.05)
    res += self._line(x+rxa, y-rya, x-rxa ,y+rya, 0.05)
    return res

  def _disc(self, x, y, rx, ry, drill, drill_dx, drill_dy, irx = 0.0, iry = 0.0):
    res = []
    res += self._ellipse(x, y, rx, ry, True)
    self.color = '#000000'
    res += self._ellipse(x+drill_dx, y+drill_dy, drill/2, drill/2, True)
    # label?
    return res

  def _txt(self, s, x, y, dy):
    txt = svgfig.Text(x, y-dy/2.5, s, font_size=dy*self.q, fill=self.color).SVG(trans=self.trans)
    return [txt]

  def skip(self, shape):
    pass

  def circle(self, shape):
    r = fget(shape, 'r')
    rx = fget(shape, 'rx', r)
    ry = fget(shape, 'ry', r)
    x = fget(shape,'x')
    y = fget(shape,'y')
    w = fget(shape,'w')
    # TODO irx/iry handling
    # TODO a1/a2 handling
    return self._ellipse(x, y, rx, ry, False, w)

  def disc(self, shape):
    r = fget(shape, 'r')
    rx = fget(shape, 'rx', r)
    ry = fget(shape, 'ry', r)
    x = fget(shape,'x')
    y = fget(shape,'y')
    drill = fget(shape,'drill')
    drill_dx = fget(shape,'drill_dx')
    drill_dy = fget(shape,'drill_dy')
    res = []
    res += self._disc(x, y, rx, ry, drill, drill_dx, drill_dy)
    res += self._hole(x,y, drill/2, drill/2)
    if 'name' in shape:
      self.set_color('name')
      res += self._txt(shape['name'], x, y, 2*max(ry, drill))
    return res

  def label(self, shape):
    x = fget(shape,'x')
    y = fget(shape,'y')
    dy = fget(shape,'dy', 1)
    dx = fget(shape,'dx', 100.0) # arbitrary large number
    if 'name' in shape:
      s = str(shape['name'])
    elif 'value' in shape:
      s = str(shape['value'])
    else: return
    return self._txt(s, x, y, dy)

  def vertex(self, shape):
    x1 = fget(shape, 'x1')
    y1 = fget(shape, 'y1')
    x2 = fget(shape, 'x2')
    y2 = fget(shape, 'y2')
    w = fget(shape, 'w')
    # TODO curves
    res = []
    res += self._line(x1, y1, x2, y2, w)
    res += self._ellipse(x1,y1,w/2,w/2,True)
    res += self._ellipse(x2,y2,w/2,w/2,True)
    return res

  def octagon(self, shape):
    pass

  def rect(self, shape):
    x = fget(shape, 'x')
    y = fget(shape, 'y')
    dx = fget(shape, 'dx')
    dy = fget(shape, 'dy')
    ro = fget(shape, 'ro') / 100.0
    rot = fget(shape, 'rot')
    drill = fget(shape, 'drill')
    drill_dx = fget(shape, 'drill_dx')
    drill_dy = -fget(shape, 'drill_dy')
    if rot not in [0, 90, 180, 270]:
      raise Exception("only 0, 90, 180, 270 rotation supported for now")
    if rot in [90, 270]:
      (dx, dy) = (dy, dx)
    if rot == 90:
      (drill_dx, drill_dy) = (drill_dy, drill_dx)
    if rot == 180:
      (drill_dx, drill_dy) = (-drill_dx, drill_dy)
    if rot == 270:
      (drill_dx, drill_dy) = (-drill_dy, -drill_dx)
    res = []
    res.append(svgfig.Rect(x-dx/2,y-dy/2,x+dx/2,y+dy/2, stroke=None, fill=self.color).SVG(trans=self.trans))
    res += self._hole(x,y, drill/2, drill/2)
    if 'name' in shape:
      m = min(dx, dy)/1.5
      self.set_color('name')
      res += self._txt(shape['name'], x, y, m)
    return res

  def polygon(self, shape):
    w = fget(shape, 'w')
    vert= shape['v']
    res = []
    for x in vert:
      x['w'] = w
      res += self.vertex(x)
    return res

  def hole(self, shape):
    x = fget(shape,'x')
    y = fget(shape,'y')
    drill = fget(shape,'drill')
    if drill > 0.0:
      return self._hole(x,y, drill/2, drill/2)
    return []

  def draw_shapes(self):
    # really ugly redraw everything
    self.scene.clear()
    self.webview = QGraphicsWebView()
    self.webview.setZoomFactor(3.0)
    self.scene.setBackgroundBrush(Qt.black)
    self.scene.addItem(self.webview)
    w = self.width()*.5
    h = self.height()*.5
    width = "%spx" % (w)
    height = "%spx" % (h)
    dx = (int(self.parent.gl_dx + 1)/2)*2
    dy = (int(self.parent.gl_dy + 1)/2)*2
    vx = dx
    dy = dy
    self.dx = dx
    self.dy = dy
    print dx, dy
    # TODO: clever viewbox calculation     
    viewbox = "%d %d %d %d" % (-self.q*dx/2, -self.q*dy/2, self.q*dx, self.q*dy)
    rect = svgfig.Rect(-dx/2,-dy/2,dx/2,dy/2, fill='black', stroke=None).SVG(trans=self.trans)
    dot_field = self.draw_dot_field()
    #print self.box.contentsRect()
    print width, height, viewbox
    svg_g = svgfig.SVG("g")
    svg_g.append(rect)
    for x in dot_field:
      svg_g.append(x)
    for shape in self.shapes:
      self.set_color(shape['type'])
      if 'shape' in shape:
        dispatch = {
          'circle': self.circle,
          'disc': self.disc,
          'label': self.label,
          'line': self.vertex,
          'vertex': self.vertex,
          'octagon': self.octagon,
          'rect': self.rect,
          'polygon': self.polygon,
          'hole': self.hole,
        }
        shape_svg = dispatch.get(shape['shape'], self.skip)(shape)
        #print shape_svg
        for x in shape_svg:
          svg_g.append(x)
    
    #print subs
    canvas = svgfig.canvas(svg_g, width=width, height=height, viewBox=viewbox)
    xml = canvas.standalone_xml()
    #print xml
    self.webview.setContent(QtCore.QByteArray(xml))
Example #6
0
class JYDSVGWidget(QtGui.QGraphicsView):

  def __init__(self, parent, box):
    self.scene = QtGui.QGraphicsScene()
    super(JYDSVGWidget, self).__init__(self.scene, parent)
    self.parent = parent
    self.box = box
    self.webview = QGraphicsWebView()
    self.webview.setZoomFactor(3.0)
    self.scene.setBackgroundBrush(Qt.black)
    self.scene.addItem(self.webview)
    #self.scene.addText('Hello, world')
    self.zoomfactor = 42
    self.is_gl = False
    self.color_scheme = color_schemes[str(parent.setting('gl/colorscheme'))]
    self.trans = trans
    self.q = Q

  def _line(self, x1, y1, x2, y2, w):
    return [svgfig.Line(x1, y1, x2, y2, stroke_width=w*self.q, stroke=self.color).SVG(trans=self.trans)]

  def _ellipse(self, x, y, rx, ry, brush, w=0.05):
    stroke_width=None
    stroke=None
    fill=self.color
    if not brush:
      stroke = self.color
      stroke_width = w*self.q
      fill=None
    if rx-ry < 0.0001:
      (cx, cy) = self.trans(x,y)
      return [svgfig.SVG("circle",cx=cx,cy=cy,r=rx*self.q, stroke=stroke,stroke_width=stroke_width,fill=fill)]
    else:
      return [svgfig.Ellipse(x,y,rx,0,ry,stroke=stroke,stroke_width=stroke_width,fill=fill).SVG(trans=self.trans)]

  def draw_dot_field(self):
    self.dot_field_data = np.array(
      [[x,y] for x in range(-self.dx/2, self.dx/2+1) for y in range(-self.dy/2, self.dy/2+1)],
      dtype=np.float32)
    #grid drawing is really slow
    #re-enable when it is not redrawn every time
    self.set_color('grid')
    #for (x,y) in self.dot_field_data:
    #  self.scene.addEllipse(x, y, 0.001, 0.001, self.pen, self.brush)
    r = 0.05
    rpx = "%spx" % (r)
    dots = svgfig.Dots(self.dot_field_data, svgfig.make_symbol("dot_field", stroke=None, fill=self.color, r=r*self.q)).SVG(trans=self.trans)
    self.set_color('axes')
    res = [dots]
    res += self._line(-self.dx/2,0,self.dx/2,0, r)
    res += self._line(0,-self.dy/2, 0, self.dy/2, r)
    print res
    return res

  def set_shapes(self, shapes):
    self.shapes = shapes
    self.update()

  def update(self):
    self.draw_shapes()

  def set_color(self, t):
    if t == 'cu':
      t = 'smd'
    (r,g,b,a) = self.color_scheme.get(t, self.color_scheme['unknown'])
    self.color = svgfig.rgb(r,g,b)
    self.opacity = a

  # todo use itemgroups?
  def _hole(self, x, y, rx, ry):
    self.set_color('hole')
    res = []
    res += self._ellipse(x, y, rx, ry, False)
    rxa = rx/sqrt(2.0)
    rya = ry/sqrt(2.0)
    res += self._line(x-rxa, y-rya, x+rxa ,y+rya, 0.05)
    res += self._line(x+rxa, y-rya, x-rxa ,y+rya, 0.05)
    return res

  def _disc(self, x, y, rx, ry, drill, drill_dx, drill_dy, irx = 0.0, iry = 0.0):
    res = []
    res += self._ellipse(x, y, rx, ry, True)
    self.color = '#000000'
    res += self._ellipse(x+drill_dx, y+drill_dy, drill/2, drill/2, True)
    # label?
    return res

  def _txt(self, s, x, y, dy):
    txt = svgfig.Text(x, y-dy/2.5, s, font_size=dy*self.q, fill=self.color).SVG(trans=self.trans)
    return [txt]

  def skip(self, shape):
    pass

  def circle(self, shape):
    r = fget(shape, 'r')
    rx = fget(shape, 'rx', r)
    ry = fget(shape, 'ry', r)
    x = fget(shape,'x')
    y = fget(shape,'y')
    w = fget(shape,'w')
    # TODO irx/iry handling
    # TODO a1/a2 handling
    return self._ellipse(x, y, rx, ry, False, w)

  def disc(self, shape):
    r = fget(shape, 'r')
    rx = fget(shape, 'rx', r)
    ry = fget(shape, 'ry', r)
    x = fget(shape,'x')
    y = fget(shape,'y')
    drill = fget(shape,'drill')
    drill_dx = fget(shape,'drill_dx')
    drill_dy = fget(shape,'drill_dy')
    res = []
    res += self._disc(x, y, rx, ry, drill, drill_dx, drill_dy)
    res += self._hole(x,y, drill/2, drill/2)
    if 'name' in shape:
      self.set_color('name')
      res += self._txt(shape['name'], x, y, max(ry, drill))
    return res

  def label(self, shape):
    x = fget(shape,'x')
    y = fget(shape,'y')
    dy = fget(shape,'dy', 1)
    dx = fget(shape,'dx', 100.0) # arbitrary large number
    if 'name' in shape:
      s = str(shape['name'])
    elif 'value' in shape:
      s = str(shape['value'])
    else: return
    return self._txt(s, x, y, dy)

  def vertex(self, shape):
    x1 = fget(shape, 'x1')
    y1 = fget(shape, 'y1')
    x2 = fget(shape, 'x2')
    y2 = fget(shape, 'y2')
    w = fget(shape, 'w')
    # TODO curves
    res = []
    res += self._line(x1, y1, x2, y2, w)
    res += self._ellipse(x1,y1,w/2,w/2,True)
    res += self._ellipse(x2,y2,w/2,w/2,True)
    return res

  def octagon(self, shape):
    pass

  def rect(self, shape):
    x = fget(shape, 'x')
    y = fget(shape, 'y')
    dx = fget(shape, 'dx')
    dy = fget(shape, 'dy')
    ro = fget(shape, 'ro') / 100.0
    rot = fget(shape, 'rot')
    drill = fget(shape, 'drill')
    drill_dx = fget(shape, 'drill_dx')
    drill_dy = -fget(shape, 'drill_dy')
    if rot not in [0, 90, 180, 270]:
      raise Exception("only 0, 90, 180, 270 rotation supported for now")
    if rot in [90, 270]:
      (dx, dy) = (dy, dx)
    if rot == 90:
      (drill_dx, drill_dy) = (drill_dy, drill_dx)
    if rot == 180:
      (drill_dx, drill_dy) = (-drill_dx, drill_dy)
    if rot == 270:
      (drill_dx, drill_dy) = (-drill_dy, -drill_dx)
    res = []
    res.append(svgfig.Rect(x-dx/2,y-dy/2,x+dx/2,y+dy/2, stroke=None, fill=self.color).SVG(trans=self.trans))
    res += self._hole(x,y, drill/2, drill/2)
    if 'name' in shape:
      m = min(dx, dy)/1.5
      self.set_color('name')
      res += self._txt(shape['name'], x, y, m)
    return res

  def polygon(self, shape):
    w = fget(shape, 'w')
    vert= shape['v']
    res = []
    for x in vert:
      x['w'] = w
      res += self.vertex(x)
    return res

  def hole(self, shape):
    x = fget(shape,'x')
    y = fget(shape,'y')
    drill = fget(shape,'drill')
    if drill > 0.0:
      return self._hole(x,y, drill/2, drill/2)
    return []

  def draw_shapes(self):
    # really ugly redraw everything
    self.scene.clear()
    self.webview = QGraphicsWebView()
    self.webview.setZoomFactor(3.0)
    self.scene.setBackgroundBrush(Qt.black)
    self.scene.addItem(self.webview)
    w = self.width()*.5
    h = self.height()*.5
    width = "%spx" % (w)
    height = "%spx" % (h)
    dx = (int(self.parent.gl_dx + 1)/2)*2
    dy = (int(self.parent.gl_dy + 1)/2)*2
    vx = dx
    dy = dy
    self.dx = dx
    self.dy = dy
    print dx, dy
    # TODO: clever viewbox calculation     
    viewbox = "%d %d %d %d" % (-self.q*dx/2, -self.q*dy/2, self.q*dx, self.q*dy)
    rect = svgfig.Rect(-dx/2,-dy/2,dx/2,dy/2, fill='black', stroke=None).SVG(trans=self.trans)
    dot_field = self.draw_dot_field()
    print self.box.contentsRect()
    print width, height, viewbox
    svg_g = svgfig.SVG("g")
    svg_g.append(rect)
    for x in dot_field:
      svg_g.append(x)
    for shape in self.shapes:
      self.set_color(shape['type'])
      if 'shape' in shape:
        dispatch = {
          'circle': self.circle,
          'disc': self.disc,
          'label': self.label,
          'line': self.vertex,
          'vertex': self.vertex,
          'octagon': self.octagon,
          'rect': self.rect,
          'polygon': self.polygon,
          'hole': self.hole,
        }
        shape_svg = dispatch.get(shape['shape'], self.skip)(shape)
        print shape_svg
        for x in shape_svg:
          svg_g.append(x)
    
    #print subs
    canvas = svgfig.canvas(svg_g, width=width, height=height, viewBox=viewbox)
    xml = canvas.standalone_xml()
    print xml
    self.webview.setContent(QtCore.QByteArray(xml))