123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- from UM.Scene.Iterator import Iterator
- from UM.Scene.SceneNode import SceneNode
- from functools import cmp_to_key
- from UM.Application import Application
- class OneAtATimeIterator(Iterator.Iterator):
- def __init__(self, scene_node):
- super().__init__(scene_node)
- self._hit_map = [[]]
- self._original_node_list = []
-
- def _fillStack(self):
- node_list = []
- for node in self._scene_node.getChildren():
- if not type(node) is SceneNode:
- continue
- if node.callDecoration("getConvexHull"):
- node_list.append(node)
- if len(node_list) < 2:
- self._node_stack = node_list[:]
- return
-
- self._original_node_list = node_list[:]
-
- self._hit_map = [[self._checkHit(i,j) for i in node_list] for j in node_list]
-
- for a in range(0,len(node_list)):
- for b in range(0,len(node_list)):
- if a != b and self._hit_map[a][b] and self._hit_map[b][a]:
- return
-
-
- sorted(node_list, key = cmp_to_key(self._calculateScore))
- todo_node_list = [_ObjectOrder([], node_list)]
- while len(todo_node_list) > 0:
- current = todo_node_list.pop()
- for node in current.todo:
-
- if not self._checkHitMultiple(node, current.order) and not self._checkBlockMultiple(node, current.todo):
-
- new_todo_list = current.todo[:]
- new_todo_list.remove(node)
- new_order = current.order[:] + [node]
- if len(new_todo_list) == 0:
-
- todo_node_list = None
- self._node_stack = new_order
- return
- todo_node_list.append(_ObjectOrder(new_order, new_todo_list))
- self._node_stack = []
-
- def _checkHitMultiple(self, node, other_nodes):
- node_index = self._original_node_list.index(node)
- for other_node in other_nodes:
- other_node_index = self._original_node_list.index(other_node)
- if self._hit_map[node_index][other_node_index]:
- return True
- return False
- def _checkBlockMultiple(self, node, other_nodes):
- node_index = self._original_node_list.index(node)
- for other_node in other_nodes:
- other_node_index = self._original_node_list.index(other_node)
- if self._hit_map[other_node_index][node_index] and node_index != other_node_index:
- return True
- return False
-
- def _calculateScore(self, a, b):
- score_a = sum(self._hit_map[self._original_node_list.index(a)])
- score_b = sum(self._hit_map[self._original_node_list.index(b)])
- return score_a - score_b
-
- def _checkHit(self, a, b):
- if a == b:
- return False
- overlap = a.callDecoration("getConvexHullBoundary").intersectsPolygon(b.callDecoration("getConvexHullHeadFull"))
- if overlap:
- return True
- else:
- return False
- class _ObjectOrder():
- def __init__(self, order, todo):
- """
- :param order: List of indexes in which to print objects, ordered by printing order.
- :param todo: List of indexes which are not yet inserted into the order list.
- """
- self.order = order
- self.todo = todo
|