summaryrefslogtreecommitdiff
path: root/lib/stitches
diff options
context:
space:
mode:
Diffstat (limited to 'lib/stitches')
-rw-r--r--lib/stitches/auto_fill.py34
-rw-r--r--lib/stitches/fill.py9
2 files changed, 22 insertions, 21 deletions
diff --git a/lib/stitches/auto_fill.py b/lib/stitches/auto_fill.py
index 097ab1d9..e732c940 100644
--- a/lib/stitches/auto_fill.py
+++ b/lib/stitches/auto_fill.py
@@ -1,20 +1,19 @@
import sys
import shapely
import networkx
-import math
from itertools import groupby, izip
from collections import deque
from .fill import intersect_region_with_grating, row_num, stitch_row
from .running_stitch import running_stitch
from ..i18n import _
-from ..svg import PIXELS_PER_MM
from ..utils.geometry import Point as InkstitchPoint, cut
class MaxQueueLengthExceeded(Exception):
pass
+
class PathEdge(object):
OUTLINE_KEYS = ("outline", "extra", "initial")
SEGMENT_KEY = "segment"
@@ -39,6 +38,7 @@ class PathEdge(object):
def is_segment(self):
return self.key == self.SEGMENT_KEY
+
def auto_fill(shape, angle, row_spacing, end_row_spacing, max_stitch_length, running_stitch_length, staggers, starting_point, ending_point=None):
stitches = []
@@ -65,7 +65,7 @@ def which_outline(shape, coords):
point = shapely.geometry.Point(*coords)
outlines = enumerate(list(shape.boundary))
- closest = min(outlines, key=lambda (index, outline): outline.distance(point))
+ closest = min(outlines, key=lambda index_outline: index_outline[1].distance(point))
return closest[0]
@@ -129,11 +129,11 @@ def build_graph(shape, segments, angle, row_spacing):
# Tag each node with its index and projection.
graph.add_node(node, index=outline_index, projection=outline_projection)
- nodes = list(graph.nodes(data=True)) # returns a list of tuples: [(node, {data}), (node, {data}) ...]
+ nodes = list(graph.nodes(data=True)) # returns a list of tuples: [(node, {data}), (node, {data}) ...]
nodes.sort(key=lambda node: (node[1]['index'], node[1]['projection']))
for outline_index, nodes in groupby(nodes, key=lambda node: node[1]['index']):
- nodes = [ node for node, data in nodes ]
+ nodes = [node for node, data in nodes]
# heuristic: change the order I visit the nodes in the outline if necessary.
# If the start and endpoints are in the same row, I can't tell which row
@@ -163,7 +163,6 @@ def build_graph(shape, segments, angle, row_spacing):
if i % 2 == edge_set:
graph.add_edge(node1, node2, key="extra")
-
if not networkx.is_eulerian(graph):
raise Exception(_("Unable to autofill. This most often happens because your shape is made up of multiple sections that aren't connected."))
@@ -193,13 +192,13 @@ def bfs_for_loop(graph, starting_node, max_queue_length=2000):
# get a list of neighbors paired with the key of the edge I can follow to get there
neighbors = [
- (node, key)
- for node, adj in graph.adj[ending_node].iteritems()
- for key in adj
- ]
+ (node, key)
+ for node, adj in graph.adj[ending_node].iteritems()
+ for key in adj
+ ]
# heuristic: try grating segments first
- neighbors.sort(key=lambda (dest, key): key == "segment", reverse=True)
+ neighbors.sort(key=lambda dest_key: dest_key[1] == "segment", reverse=True)
for next_node, key in neighbors:
# skip if I've already followed this edge
@@ -295,6 +294,7 @@ def insert_loop(path, loop):
path[i:i] = loop
+
def nearest_node_on_outline(graph, point, outline_index=0):
point = shapely.geometry.Point(*point)
outline_nodes = [node for node, data in graph.nodes(data=True) if data['index'] == outline_index]
@@ -302,16 +302,18 @@ def nearest_node_on_outline(graph, point, outline_index=0):
return nearest
+
def get_outline_nodes(graph, outline_index=0):
- outline_nodes = [(node, data['projection']) \
- for node, data \
- in graph.nodes(data=True) \
+ outline_nodes = [(node, data['projection'])
+ for node, data
+ in graph.nodes(data=True)
if data['index'] == outline_index]
- outline_nodes.sort(key=lambda (node, projection): projection)
+ outline_nodes.sort(key=lambda node_projection: node_projection[1])
outline_nodes = [node for node, data in outline_nodes]
return outline_nodes
+
def find_initial_path(graph, starting_point, ending_point=None):
starting_node = nearest_node_on_outline(graph, starting_point)
@@ -340,6 +342,7 @@ def find_initial_path(graph, starting_point, ending_point=None):
return path
+
def find_stitch_path(graph, segments, starting_point=None, ending_point=None):
"""find a path that visits every grating segment exactly once
@@ -362,7 +365,6 @@ def find_stitch_path(graph, segments, starting_point=None, ending_point=None):
the order of most-recently-visited first.
"""
- original_graph = graph
graph = graph.copy()
num_segments = len(segments)
segments_visited = 0
diff --git a/lib/stitches/fill.py b/lib/stitches/fill.py
index 14971cb4..af0a8403 100644
--- a/lib/stitches/fill.py
+++ b/lib/stitches/fill.py
@@ -1,6 +1,5 @@
import shapely
import math
-import sys
from ..svg import PIXELS_PER_MM
from ..utils import cache, Point as InkstitchPoint
@@ -37,6 +36,7 @@ def adjust_stagger(stitch, angle, row_spacing, max_stitch_length, staggers):
return stitch - offset * east(angle)
+
def stitch_row(stitches, beg, end, angle, row_spacing, max_stitch_length, staggers):
# We want our stitches to look like this:
#
@@ -119,7 +119,7 @@ def intersect_region_with_grating(shape, angle, row_spacing, end_row_spacing=Non
height = abs(end - start)
- #print >> dbg, "grating:", start, end, height, row_spacing, end_row_spacing
+ # print >> dbg, "grating:", start, end, height, row_spacing, end_row_spacing
# offset start slightly so that rows are always an even multiple of
# row_spacing_px from the origin. This makes it so that abutting
@@ -163,11 +163,10 @@ def intersect_region_with_grating(shape, angle, row_spacing, end_row_spacing=Non
return rows
+
def section_to_stitches(group_of_segments, angle, row_spacing, max_stitch_length, staggers):
stitches = []
- first_segment = True
swap = False
- last_end = None
for segment in group_of_segments:
(beg, end) = segment
@@ -238,7 +237,7 @@ def pull_runs(rows, shape, row_spacing):
# print >> sys.stderr, len(run)
runs.append(run)
- rows = [row for row in rows if len(row) > 0]
+ rows = [r for r in rows if len(r) > 0]
count += 1