Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xsprite_factory.py846
1 files changed, 0 insertions, 846 deletions
diff --git a/sprite_factory.py b/sprite_factory.py
deleted file mode 100755
index 1e8c157..0000000
--- a/sprite_factory.py
+++ /dev/null
@@ -1,846 +0,0 @@
-#!/usr/bin/env python
-# -*- coding: utf-8 -*-
-#Copyright (c) 2009,10 Walter Bender
-
-#Permission is hereby granted, free of charge, to any person obtaining a copy
-#of this software and associated documentation files (the "Software"), to deal
-#in the Software without restriction, including without limitation the rights
-#to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-#copies of the Software, and to permit persons to whom the Software is
-#furnished to do so, subject to the following conditions:
-
-#The above copyright notice and this permission notice shall be included in
-#all copies or substantial portions of the Software.
-
-#THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-#IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-#FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-#AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-#LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-#OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
-#THE SOFTWARE.
-
-import pygtk
-pygtk.require('2.0')
-import gtk
-import os
-from gettext import gettext as _
-
-class SVG:
- def __init__(self):
- self._x = 0
- self._y = 0
- self._min_x = 0
- self._min_y = 0
- self._max_x = 0
- self._max_y = 0
- self._width = 0
- self._height = 0
- self.docks = []
- self._scale = 1
- self._orientation = 0
- self._radius = 8
- self._stroke_width = 1
- self._innie = [False]
- self._outie = False
- self._innie_x1 = (9-self._stroke_width)/2
- self._innie_y1 = 3
- self._innie_x2 = (9-self._stroke_width)/2
- self._innie_y2 = (9-self._stroke_width)/2
- self._innie_spacer = 9
- self._slot = True
- self._cap = False
- self._tab = True
- self._bool = False
- self._slot_x = 10
- self._slot_y = 2
- self._porch = False
- self._porch_x = self._innie_x1+self._innie_x2+4*self._stroke_width
- self._porch_y = self._innie_y1+self._innie_y2+4*self._stroke_width
- self._expand_x = 0
- self._expand_y = 0
- self._else = False
- self._draw_innies = True
- self._hide = False
- self._show = False
- self._dot_radius = 8
- self._fill = "#00FF00"
- self._stroke = "#00A000"
- self._gradiant = False
-
- def basic_block(self):
- (x, y) = self._calculate_x_y()
- svg = self._new_path(x, y)
- svg += self._corner(1, -1)
- svg += self._do_slot()
- svg += self._rline_to(self._expand_x, 0)
- xx = self._x
- svg += self._corner(1, 1)
- for i in range(len(self._innie)):
- if self._innie[i] is True:
- svg += self._do_innie()
- if i==0 and self._porch is True:
- svg += self._do_porch()
- elif len(self._innie)-1 > i:
- svg += self._rline_to(0, 2*self._innie_y2+self._innie_spacer)
- svg += self._rline_to(0, self._expand_y)
- svg += self._corner(-1, 1)
- svg += self._line_to(xx, self._y)
- svg += self._rline_to(-self._expand_x, 0)
- if self._tab:
- svg += self._do_tab()
- else:
- svg += self._do_tail()
- svg += self._corner(-1, -1)
- svg += self._rline_to(0, -self._expand_y)
- if True in self._innie:
- svg += self._line_to(x, self._radius+self._innie_y2+\
- self._stroke_width/2.0)
- svg += self._do_outie()
- self._calculate_w_h()
- svg += self._close_path()
- svg += self._style()
- if self._show is True:
- if self._outie is True:
- x = self._innie_x1 + 2*self._innie_x2 + 2*self._dot_radius
- else:
- x = 12
- svg += self._show_dot(x,self._height-12-self._innie_y2-self._slot_y)
- if self._hide is True:
- if True in self._innie:
- x = self._width - (self._innie_x1 + 2*self._innie_x2 +\
- 2*self._dot_radius)
- else:
- x = self._width-12
- svg += self._hide_dot(x,self._height-12-self._innie_y2-self._slot_y)
-
- svg += self._footer()
- return self._header() + svg
-
- def basic_flow(self):
- (x, y) = self._calculate_x_y()
- svg = self._new_path(x, y)
- svg += self._corner(1, -1)
- svg += self._do_slot()
- svg += self._rline_to(self._expand_x, 0)
- xx = self._x
- svg += self._corner(1, 1)
- for i in range(len(self._innie)):
- if self._innie[i] is True:
- svg += self._do_innie()
- svg += self._rline_to(0, 2*self._innie_y2+self._innie_spacer)
- if self._bool is True:
- svg += self._rline_to(0,self._radius/2.0)
- svg += self._do_boolean()
- svg += self._rline_to(0,self._radius/2.0)
- if self._else:
- svg += self._rline_to(self._radius*3+self._slot_x*2, 0)
- else:
- svg += self._rline_to(self._radius+self._slot_x, 0)
- hh = self._x
- svg += self._corner(1, 1)
- svg += self._rline_to(-self._radius,0)
- if self._else:
- svg += self._do_tab()
- svg += self._rline_to(-self._radius*2, 0)
- svg += self._do_tab()
- svg += self._rline_to(-self._radius, 0)
- svg += self._rline_to(0, self._expand_y)
- svg += self._corner(-1, 1)
- svg += self._line_to(xx, self._y)
- svg += self._rline_to(-self._expand_x, 0)
- if self._tab:
- svg += self._do_tab()
- else:
- svg += self._do_tail()
- svg += self._corner(-1, -1)
- svg += self._rline_to(0, -self._expand_y)
- if True in self._innie:
- svg += self._line_to(x, self._radius+self._innie_y2+\
- self._stroke_width)
- svg += self._close_path()
- self._calculate_w_h()
- svg += self._style()
- if self._hide is True:
- svg += self._hide_dot(hh,
- self._height-12-self._innie_y2-self._slot_y)
- if self._show is True:
- svg += self._show_dot(hh-24,
- self._height-12-self._innie_y2-self._slot_y)
- svg += self._footer()
- return self._header() + svg
-
- def portfolio(self):
- (x, y) = self._calculate_x_y()
- x += self._innie_x1+self._innie_x2
- svg = self._new_path(x, y)
- svg += self._corner(1, -1)
- svg += self._do_slot()
- xx = self._x
- svg += self._rline_to(self._expand_x, 0)
- svg += self._corner(1, 1)
- svg += self._rline_to(0, self._expand_y)
- for i in range(len(self._innie)):
- if self._innie[i] is True and i > 0 and self._draw_innies:
- svg += self._do_innie()
- svg += self._rline_to(0, 2*self._innie_y2+self._innie_spacer)
- else:
- svg += self._rline_to(0, 2*self._innie_y2+self._innie_spacer)
- svg += self._corner(-1, 1)
- svg += self._line_to(xx, self._y)
- svg += self._do_tab()
- svg += self._corner(-1, -1)
- for i in range(len(self._innie)):
- if self._innie[len(self._innie)-i-1] is True:
- svg += self._rline_to(0, -2*self._innie_y2-self._innie_spacer)
- svg += self._do_reverse_innie()
- else:
- svg += self._rline_to(0, -2*self._innie_y2-self._innie_spacer)
- svg += self._close_path()
- self._calculate_w_h()
- svg += self._style()
- svg += self._footer()
- return self._header() + svg
-
- def basic_box(self):
- self.set_outie(True)
- x = self._stroke_width/2.0+self._innie_x1+self._innie_x2
- svg = self._new_path(x, self._stroke_width/2.0)
- svg += self._rline_to(self._expand_x, 0)
- svg += self._rline_to(0, 2*self._radius+self._innie_y2+self._expand_y)
- svg += self._rline_to(-self._expand_x, 0)
- svg += self._line_to(x, self._radius+self._innie_y2+\
- self._stroke_width/2.0)
- svg += self._do_outie()
- svg += self._close_path()
- self._calculate_w_h()
- svg += self._style()
- svg += self._footer()
- return self._header() + svg
-
- def boolean_and_or(self):
- svg = self._start_boolean(self._stroke_width/2.0,
- self._radius*5.5+self._stroke_width/2.0+\
- self._innie_y2+self._innie_spacer)
- svg += self._rline_to(0,-self._radius*3.5-self._innie_y2-\
- self._innie_spacer-self._stroke_width)
- svg += self._rarc_to(1, -1)
- svg += self._rline_to(self._radius/2.0+self._expand_x, 0)
- xx = self._x
- svg += self._rline_to(0,self._radius/2.0)
- svg += self._do_boolean()
- svg += self._rline_to(0,self._radius*1.5+self._innie_y2+\
- self._innie_spacer)
- svg += self._do_boolean()
- svg += self._rline_to(0,self._radius/2.0)
- svg += self._line_to(xx, self._y)
- svg += self._rline_to(-self._expand_x, 0)
- svg += self._end_boolean()
- return self._header() + svg
-
- def boolean_not(self):
- svg = self._start_boolean(self._stroke_width/2.0,
- self._radius*2.0+self._stroke_width/2.0)
- svg += self._rline_to(0,-self._stroke_width)
- svg += self._rarc_to(1, -1)
- svg += self._rline_to(self._radius/2.0+self._expand_x, 0)
- xx = self._x
- svg += self._rline_to(0,self._radius/2.0)
- svg += self._do_boolean()
- svg += self._rline_to(0,self._radius/2.0)
- svg += self._line_to(xx, self._y)
- svg += self._rline_to(-self._expand_x, 0)
- svg += self._end_boolean()
- return self._header() + svg
-
- def boolean_compare(self):
- yoffset = self._radius*2+2*self._innie_y2+\
- self._innie_spacer+self._stroke_width/2.0
- if self._porch is True:
- yoffset += self._porch_y
- svg = self._start_boolean(self._stroke_width/2.0, yoffset)
- yoffset = -2*self._innie_y2-self._innie_spacer-self._stroke_width
- if self._porch is True:
- yoffset -= self._porch_y
- svg += self._rline_to(0, yoffset)
- svg += self._rarc_to(1, -1)
- svg += self._rline_to(self._radius/2.0+self._expand_x, 0)
- svg += self._rline_to(0,self._radius)
- xx = self._x
- svg += self._do_innie()
- if self._porch is True:
- svg += self._do_porch()
- else:
- svg += self._rline_to(0, 2*self._innie_y2+self._innie_spacer)
- svg += self._do_innie()
- svg += self._rline_to(0, self._radius)
- svg += self._line_to(xx, self._y)
- svg += self._rline_to(-self._expand_x, 0)
- svg += self._end_boolean()
- return self._header() + svg
-
- def turtle(self, colors):
- self._fill, self._stroke = colors[2], "none"
- svg = self._rect(21, 21, 19.5, 18)
- self._fill = colors[3]
- svg += self._rect(3, 3, 30, 24)
- svg += self._rect(3, 3, 24, 24)
- svg += self._rect(3, 3, 30, 30)
- svg += self._rect(3, 3, 24, 30)
- svg += self._rect(3, 3, 27, 27)
- svg += self._rect(3, 3, 21, 27)
- svg += self._rect(3, 3, 33, 27)
- svg += self._rect(3, 3, 27, 21)
- svg += self._rect(3, 3, 21, 21)
- svg += self._rect(3, 3, 33, 21)
- svg += self._rect(3, 3, 27, 33)
- svg += self._rect(3, 3, 21, 33)
- svg += self._rect(3, 3, 33, 33)
- svg += self._rect(3, 3, 30, 36)
- svg += self._rect(3, 3, 24, 36)
- svg += self._rect(3, 3, 30, 18)
- svg += self._rect(3, 3, 24, 18)
- svg += self._rect(3, 3, 36, 24)
- svg += self._rect(3, 3, 36, 30)
- svg += self._rect(3, 3, 36, 18)
- svg += self._rect(3, 3, 36, 36)
- self._fill, self._stroke = colors[0], colors[0]
- svg += self._turtle_body()
- self._fill, self._stroke = colors[1], colors[1]
- svg += self._turtle_shell()
- self._fill, self._stroke = "#000000", "#000000"
- svg += self._circle(1.25,32.5,8)
- svg += self._circle(1.25,27.5,8)
- svg += self._footer()
- self._width, self._height = 60, 60
- return self._header() + svg
-
- def palette(self, width, height):
- self._width, self._height = width, height
- self._fill, self._stroke = "#FFD000", "none"
- svg = self._rect(width, height, 0, 0)
- svg += self._hide_dot(width-12, height-12)
- svg += self._footer()
- return self._header() + svg
-
- def toolbar(self, width, height):
- self._width, self._height = width, height
- self._fill, self._stroke = "#282828", "none"
- svg = self._rect(width, height, 0, 0)
- svg += self._footer()
- return self._header() + svg
-
- def from_file(self, pathname):
- f = file(pathname, 'r')
- svg = f.read()
- f.close()
- return(svg)
-
- #
- # Utility methods
- #
- def set_draw_innies(self, flag=True):
- self._draw_innies = flag
-
- def set_hide(self, flag=False):
- self._hide = flag
-
- def set_show(self, flag=False):
- self._show = flag
-
- def get_width(self):
- return self._width
-
- def get_height(self):
- return self._height
-
- def get_innie_width(self):
- return (self._innie_x1+self._innie_x2)*self._scale
-
- def get_slot_depth(self):
- return self._slot_y*self._scale
-
- def clear_docks(self):
- self.docks = []
-
- def set_scale(self, scale=1):
- self._scale = scale
-
- def set_orientation(self, orientation=0):
- self._orientation = orientation
-
- def expand(self, w=0, h=0):
- self._expand_x = w
- self._expand_y = h
-
- def set_stroke_width(self, stroke_width=1.5):
- self._stroke_width = stroke_width
- self._calc_porch_params()
-
- def set_colors(self, colors=["#00FF00","#00A000"]):
- self._fill = colors[0]
- self._stroke = colors[1]
-
- def set_fill_color(self, color="#00FF00"):
- self._fill = color
-
- def set_stroke_color(self, color="#00A000"):
- self._stroke = color
-
- def set_gradiant(self, flag=False):
- self._gradiant = flag
-
- def set_innie(self, innie_array=[False]):
- self._innie = innie_array
-
- def set_outie(self, flag=False):
- self._outie = flag
-
- def set_slot(self, flag=True):
- self._slot = flag
- if self._slot is True:
- self._cap = False
-
- def set_cap(self, flag=False):
- self._cap = flag
- if self._cap is True:
- self._slot = False
-
- def set_tab(self, flag=True):
- self._tab = flag
-
- def set_porch(self, flag=False):
- self._porch = flag
-
- def set_boolean(self, flag=False):
- self._bool = flag
-
- def set_else(self, flag=False):
- self._else = flag
-
- #
- # Exotic methods
- #
-
- def set_radius(self, radius=8):
- self._radius = radius
-
- def set_innie_params(self, x1=4, y1=3, x2=4, y2=4):
- self._innie_x1 = x1
- self._innie_y1 = y1
- self._innie_x2 = x2
- self._innie_y2 = y2
- self._calc_porch_params()
-
- def set_innie_spacer(self, innie_spacer = 0):
- self._innie_spacer = innie_spacer
-
- def set_slot_params(self, x=12, y=4):
- self._slot_x = x
- self._slot_y = y
-
- def _calc_porch_params(self):
- self._porch_x = self._innie_x1+self._innie_x2+4*self._stroke_width
- self._porch_y = self._innie_y1+self._innie_y2+4*self._stroke_width
-
- #
- # SVG helper methods
- #
-
- def _header(self):
- return "%s%s%s%s%s%s%s%s%.1f%s%s%.1f%s%s%s" % (
- "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\n",
- "<!-- Created with Python -->\n",
- "<svg\n",
- " xmlns:svg=\"http://www.w3.org/2000/svg\"\n",
- " xmlns=\"http://www.w3.org/2000/svg\"\n",
- " xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n",
- " version=\"1.1\"\n",
- " width=\"", self._width, "\"\n",
- " height=\"", self._height, "\">\n",
- self._defs(),
- self._transform())
-
- def _defs(self):
- if self._gradiant is True:
- return "%s%s%s%s%s%s%s%s%s%s%s%s%.1f%s%s%.1f%s%s%.1f%s%s" % (
- " <defs>\n <linearGradient\n id=\"linearGradient1234\">\n",
- " <stop\n style=\"stop-color:#ffffff;stop-opacity:1;\"\n",
- " offset=\"0\" />\n",
- " <stop\n style=\"stop-color:", self._fill,
- ";stop-opacity:1;\"\n",
- " offset=\"1\" />\n",
- " </linearGradient>\n",
- " <linearGradient\n xlink:href=\"#linearGradient1234\"\n",
- " id=\"linearGradient5678\"\n",
- " x1=\"0\"\n",
- " y1=\"", self._height/2.0, "\"\n",
- " x2=\"", self._width, "\"\n",
- " y2=\"", self._height/2.0, "\"\n",
- " gradientUnits=\"userSpaceOnUse\" />\n </defs>\n")
- else:
- return ""
-
- def _transform(self):
- if self._orientation != 0:
- orientation = "<g\ntransform = \"rotate(%.1f %.1f %.1f)\">\n" % (
- self._orientation, self._width/2.0, self._height/2.0)
- else:
- orientation = ""
- return "<g\ntransform=\"scale(%.1f, %.1f)\">\n%s" % (
- self._scale, self._scale, orientation )
-
- def _footer(self):
- if self._orientation != 0:
- return " </g>\n</g>\n</svg>\n"
- else:
- return " </g>\n</svg>\n"
-
- def _style(self):
- if self._gradiant is True:
- fill = "url(#linearGradient5678)"
- else:
- fill = self._fill
- return "%s%s;%s%s;%s%.1f;%s%s" % (
- " style=\"fill:",fill,
- "fill-opacity:1;stroke:",self._stroke,
- "stroke-width:",self._stroke_width,
- "stroke-linecap:square;",
- "stroke-opacity:1;\" />\n")
-
- def _circle(self, r, cx, cy):
- return "%s%s%s%s%s%f%s%f%s%f%s" % ("<circle style=\"fill:",
- self._fill, ";stroke:", self._stroke, ";\" r=\"", r, "\" cx=\"",
- cx, "\" cy=\"", cy, "\" />\n")
-
- def _rect(self, w, h, x, y):
- return "%s%s%s%s%s%f%s%f%s%f%s%f%s" % ("<rect style=\"fill:",
- self._fill, ";stroke:", self._stroke, ";\" width=\"", w,
- "\" height=\"", h,"\" x=\"", x, "\" y=\"", y, "\" />\n")
-
- def _turtle_body(self):
- return "%s%s%s%s%s" % ("<path style=\"", self._fill, ";stroke:",
- self._stroke, "\" d=\"M 20,42 C 21,41 23,40 24,40 C 24,39 24,40 26,41 C 28,43 31,43 34,41 C 35,40 35,39 36,40 C 36,40 38,41 39,42 C 41,42 45,43 46,43 C 47,43 46,41 43,39 L 39,36 L 42,34 C 44,30 45,28 43,25 L 41,22 L 46,18 C 48,16 47.5,13.5 47,13 C 46.5,12.5 46,13 45,13 C 44,13 43.5,14 42.5,15 C 39.5,17 40,18 37,17 C 32,16 31.5,15 34.5,12 C 36.5,10 36,7 34,6 C 32,3 28,4 26,6 C 24,8 23,10 25,12 C 28,15 27,16 22,17 C 18,18 19,17 17,15 C 16,14 16,13 15,13 C 14,13 13,13 13,13 C 12,13 11,16 14,18 L 19,22 L 17,25 C 15,28 16,30 18,34 L 20,36 L 16,39 C 13,41 12,43 13,43 C 14,43 18,42 20,42 z M 30,18 C 32,18 36,19 38,20 C 40,22 39.5,25 39.5,28 C 39.5,30 40,32.5 38.5,35 C 37,36.5 36.5,37.5 35,38 C 33.5,38.5 31,39 30,39 C 28,39 26,39 25,38 C 23,37 22.5,37 21.5,35 C 20.5,33 20.5,30 20.5,28 C 20.5,25 20,22 22,20 C 24,19 27,18 30,18 z\" />\n")
-
- def _turtle_shell(self):
- return "%s%s%s%s%s" % ("<path style=\"", self._fill, ";stroke:",
- self._stroke, "\" d=\"M 33,10 C 33,11 31.5,12 30,12 C 28,12 27,11 27,10 C 27,9 28,8 30,8 C 31.5,8 33,9 33,10 z\" />\n")
-
- def _check_min_max(self):
- if self._x < self._min_x:
- self._min_x = self._x
- if self._y < self._min_y:
- self._min_y = self._y
- if self._x > self._max_x:
- self._max_x = self._x
- if self._y > self._max_y:
- self._max_y = self._y
-
- def _line_to(self, x, y):
- if self._x == x and self._y == y:
- return ""
- else:
- self._x = x
- self._y = y
- self._check_min_max()
- return "L %.1f %.1f " % (x, y)
-
- def _rline_to(self, dx, dy):
- if dx == 0 and dy == 0:
- return ""
- else:
- return self._line_to(self._x+dx, self._y+dy)
-
- def _arc_to(self, x, y, r, a=90, l=0, s=1):
- if r == 0:
- return self._line_to(x, y)
- else:
- self._x = x
- self._y = y
- self._check_min_max()
- return "A %.1f %.1f %.1f %d %d %.1f %.1f " % (
- r, r, a, l, s, x, y)
-
- def _rarc_to(self, sign_x, sign_y, a=90, l=0, s=1):
- if self._radius == 0:
- return ""
- else:
- x = self._x + sign_x*self._radius
- y = self._y + sign_y*self._radius
- return self._arc_to(x, y, self._radius, a, l, s)
-
- def _corner(self, sign_x, sign_y, a=90, l=0, s=1):
- svg_str = ""
- if self._radius > 0:
- r2 = self._radius/2.0
- if sign_x*sign_y == 1:
- svg_str +=self._rline_to(sign_x*r2, 0)
- else:
- svg_str +=self._rline_to(0, sign_y*r2)
- x = self._x + sign_x*r2
- y = self._y + sign_y*r2
- svg_str += self._arc_to(x, y, r2, a, l, s)
- if sign_x*sign_y == 1:
- svg_str +=self._rline_to(0, sign_y*r2)
- else:
- svg_str +=self._rline_to(sign_x*r2, 0)
- return svg_str
-
- def _new_path(self, x, y):
- self._min_x = x
- self._min_y = y
- self._max_x = x
- self._max_y = y
- self._x = x
- self._y = y
- return " <path d=\"m%.1f %.1f " % (x, y)
-
- def _close_path(self):
- return "z\"\n"
-
- def _hide_dot(self, x, y):
- _saved_fill, _saved_stroke = self._fill, self._stroke
- self._fill, self._stroke = "#FF0000", "#FF0000"
- svg = "</g>/n<g>/n"
- svg += self._circle(self._dot_radius, x, y)
- self._fill, self._stroke = "#FFFFFF", "#FFFFFF"
- svg += self._rect(10, 2, x-5, y-1)
- self._fill, self._stroke = _saved_fill, _saved_stroke
- return svg
-
- def _show_dot(self, x, y):
- _saved_fill, _saved_stroke = self._fill, self._stroke
- self._fill, self._stroke = "#00FE00", "#00FE00"
- svg = "</g>/n<g>/n"
- svg += self._circle(self._dot_radius, x, y)
- self._fill, self._stroke = "#FEFEFE", "#FEFEFE"
- svg += self._rect(10, 2, x-5, y-1)
- svg += self._rect(2, 10, x-1, y-5)
- self._fill, self._stroke = _saved_fill, _saved_stroke
- return svg
-
- def _do_slot(self):
- if self._slot is True:
- self.docks.append((int(self._x*self._scale),
- int(self._y*self._scale)))
- return "%s%s%s" % (
- self._rline_to(0, self._slot_y),
- self._rline_to(self._slot_x, 0),
- self._rline_to(0, -self._slot_y))
- elif self._cap is True:
- return "%s%s" % (
- self._rline_to(self._slot_x/2.0, -self._slot_y*2.0),
- self._rline_to(self._slot_x/2.0, self._slot_y*2.0))
- else:
- return self._rline_to(self._slot_x, 0)
-
- def _do_tail(self):
- if self._outie is True:
- return self._rline_to(-self._slot_x, 0)
- else:
- return "%s%s" % (
- self._rline_to(-self._slot_x/2.0, self._slot_y*2.0),
- self._rline_to(-self._slot_x/2.0, -self._slot_y*2.0))
-
- def _do_tab(self):
- s = "%s%s%s%s%s" % (
- self._rline_to(-self._stroke_width, 0),
- self._rline_to(0, self._slot_y),
- self._rline_to(-self._slot_x+2*self._stroke_width, 0),
- self._rline_to(0, -self._slot_y),
- self._rline_to(-self._stroke_width, 0))
- self.docks.append((int(self._x*self._scale),
- int((self._y+self._stroke_width)*self._scale)))
- return s
-
- def _do_innie(self):
- self.docks.append((int((self._x+self._stroke_width)*self._scale),
- int((self._y+self._innie_y2)*self._scale)))
- return "%s%s%s%s%s%s%s" % (
- self._rline_to(-self._innie_x1, 0),
- self._rline_to(0, -self._innie_y1),
- self._rline_to(-self._innie_x2, 0),
- self._rline_to(0, self._innie_y2+2*self._innie_y1),
- self._rline_to(self._innie_x2, 0),
- self._rline_to(0, -self._innie_y1),
- self._rline_to(self._innie_x1, 0))
-
- def _do_reverse_innie(self):
- self.docks.append((int((self._x+self._stroke_width)*self._scale),
- int((self._y)*self._scale)))
- return "%s%s%s%s%s%s%s" % (
- self._rline_to(-self._innie_x1, 0),
- self._rline_to(0, self._innie_y1),
- self._rline_to(-self._innie_x2, 0),
- self._rline_to(0, -self._innie_y2-2*self._innie_y1),
- self._rline_to(self._innie_x2, 0),
- self._rline_to(0, self._innie_y1),
- self._rline_to(self._innie_x1, 0))
-
- def _do_outie(self):
- if self._outie is not True:
- return self._rline_to(0, -self._innie_y2)
- self.docks.append((int(self._x*self._scale), int(self._y*self._scale)))
- return "%s%s%s%s%s%s%s%s%s" % (
- self._rline_to(0, -self._stroke_width),
- self._rline_to(-self._innie_x1-2*self._stroke_width, 0),
- self._rline_to(0, self._innie_y1),
- self._rline_to(-self._innie_x2+2*self._stroke_width, 0),
- self._rline_to(0,
- -self._innie_y2-2*self._innie_y1+2*self._stroke_width),
- self._rline_to(self._innie_x2-2*self._stroke_width, 0),
- self._rline_to(0, self._innie_y1),
- self._rline_to(self._innie_x1+2*self._stroke_width, 0),
- self._rline_to(0, -self._stroke_width))
-
- def _do_porch(self):
- return "%s%s%s" % (
- self._rline_to(0, self._porch_y),
- self._rline_to(self._porch_x-self._radius, 0),
- self._corner(1, 1))
-
- def _start_boolean(self, xoffset, yoffset):
- svg = self._new_path(xoffset, yoffset)
- self._radius -= self._stroke_width
- self.docks.append((int(self._x*self._scale), int(self._y*self._scale)))
- svg += self._rarc_to(1, -1)
- self._radius += self._stroke_width
- return svg + self._rline_to(self._stroke_width, 0)
-
- def _do_boolean(self):
- self.docks.append(
- (int((self._x-self._radius+self._stroke_width)*self._scale),
- int((self._y+self._radius)*self._scale)))
- return self._rarc_to(-1, 1, 90, 0, 0) + self._rarc_to(1, 1, 90, 0, 0)
-
- def _end_boolean(self):
- svg = self._rline_to(-self._radius*1.5,0)
- svg += self._rline_to(0, -self._stroke_width)
- svg += self._rline_to(-self._stroke_width, 0)
- self._radius -= self._stroke_width
- svg += self._rarc_to(-1, -1)
- self._radius += self._stroke_width
- svg += self._close_path()
- self._calculate_w_h()
- svg += self._style()
- return svg + self._footer()
-
- def _calculate_w_h(self):
- self._width = (self._max_x-self._min_x+self._stroke_width)*\
- self._scale
- self._height = (self._max_y-self._min_y+self._stroke_width)*\
- self._scale
-
- def _calculate_x_y(self):
- x = self._stroke_width/2.0
- y = self._stroke_width/2.0+self._radius
- if self._outie is True:
- x += self._innie_x1+self._innie_x2
- if self._cap is True:
- y += self._slot_y*2.0
- return(x, y)
-
-#
-# Command-line tools for testing
-#
-
-def open_file(datapath, filename):
- return file(os.path.join(datapath, filename), "w")
-
-def close_file(f):
- f.close()
-
-def generator(datapath):
-
- """
- svgt = SVG()
- svgt.set_orientation(180)
- f = open_file(datapath, "turtle180.svg")
- svg_str = svgt.turtle()
- f.write(svg_str)
- close_file(f)
- """
-
- svg0 = SVG()
- f = open_file(datapath, "portfolio-test.svg")
- svg0.set_scale(1)
- svg0.expand(25,15)
- svg0.set_slot(True)
- svg0.set_innie([True, True, False, True])
- svg0.set_tab(True)
- svg0.set_gradiant(True)
- svg0.set_draw_innies(False)
- svg_str = svg0.portfolio()
- f.write(svg_str)
- close_file(f)
-
- """
- svg1 = SVG()
- f = open_file(datapath, "blob-test.svg")
- svg1.set_scale(2)
- svg1.expand(0,20)
- svg1.set_tab(True)
- svg1.set_slot(True)
- svg1.set_gradiant(True)
- svg1.set_hide(True)
- svg_str = svg1.basic_block()
- f.write(svg_str)
- close_file(f)
-
- svg2 = SVG()
- f = open_file(datapath, "box-test.svg")
- svg2.set_scale(1)
- svg2.expand(40,0)
- svg2.set_colors(["#FFA000","#A08000"])
- svg2.set_gradiant(True)
- svg_str = svg2.basic_box()
- f.write(svg_str)
- close_file(f)
-
- svg3 = SVG()
- f = open_file(datapath, "compare-text.svg")
- svg3.set_scale(1)
- svg3.set_colors(["#0000FF","#0000A0"])
- svg3.set_gradiant(True)
- # svg3.set_porch(True)
- svg_str = svg3.boolean_compare()
- f.write(svg_str)
- close_file(f)
-
- svg4 = SVG()
- f = open_file(datapath, "and-or-test.svg")
- svg4.set_scale(1)
- svg4.set_colors(["#00FFFF","#00A0A0"])
- svg4.set_gradiant(True)
- svg_str = svg4.boolean_and_or()
- f.write(svg_str)
- close_file(f)
-
- svg5 = SVG()
- f = open_file(datapath, "nor-test.svg")
- svg5.set_scale(1)
- svg5.set_colors(["#FF00FF","#A000A0"])
- svg5.set_gradiant(True)
- svg_str = svg5.boolean_not()
- f.write(svg_str)
- close_file(f)
- """
-
-def main():
- return 0
-
-if __name__ == "__main__":
- generator(os.path.abspath('.'))
- main()
-
-
-#
-# Load pixbuf from SVG string
-#
-def svg_str_to_pixbuf(svg_string):
- pl = gtk.gdk.PixbufLoader('svg')
- pl.write(svg_string)
- pl.close()
- pixbuf = pl.get_pixbuf()
- return pixbuf
-