diff pyink/MBScene.py @ 1236:2eeac97853eb

Running animation successful
author Thinker K.F. Li <thinker@codemud.net>
date Mon, 10 Jan 2011 11:45:13 +0800
parents 84e7b1c1892b
children b5cceb2b87bb
line wrap: on
line diff
--- a/pyink/MBScene.py	Mon Jan 10 11:45:12 2011 +0800
+++ b/pyink/MBScene.py	Mon Jan 10 11:45:13 2011 +0800
@@ -116,6 +116,10 @@
 	pass
 
     def _on_insert_node(self, node, child):
+	for cchild in child.childList():
+	    self._on_insert_node(child, cchild)
+	    pass
+	
 	try:
 	    child_id = child.getAttribute('id')
 	except:
@@ -170,6 +174,10 @@
 	return maxframe
 
     def _on_remove_node(self, node, child):
+	for cchild in child.childList():
+	    self._on_remove_node(child, cchild)
+	    pass
+	
 	try:
 	    child_id = child.getAttribute('id')
 	except:
@@ -634,6 +642,9 @@
 		pass
 	    pass
 	pass
+
+    def get_max_frame(self):
+	return self._maxframe
     pass
 
 ## \brief Maintain frameline list for MBScene.
@@ -641,7 +652,8 @@
 class MBScene_framelines(object):
     _frameline_tween_types = (frameline.TWEEN_TYPE_NONE,
 			      frameline.TWEEN_TYPE_SHAPE)
-
+    _num_frames_of_line = 100
+    
     _framelines = None
     
     def __init__(self, *args, **kws):
@@ -826,7 +838,10 @@
     def get_all_key_tween_of_layer(self, layer_idx):
 	frameline = self._framelines[layer_idx]
 	info = frameline.get_frame_blocks()
-	return info
+	tweens = [(tween[0], tween[1],
+		   self._frameline_tween_types.index(tween[2]))
+		  for tween in info]
+	return tweens
     
     ## \brief Tweening key frame to a give size
     #
@@ -838,7 +853,8 @@
 	right_frame_idx = key_frame_idx + tween_len - 1
 	fl_tween_type = self._frameline_tween_types[tween_type]
 
-	start, end, fl_tween_type = frameline.get_frame_block(frame_idx)
+	start, end, old_fl_tween_type = \
+	    frameline.get_frame_block(key_frame_idx)
 	if start != key_frame_idx:
 	    ValueError, 'invalid key frame (%d)' % (key_frame_idx)
 	if start < end:
@@ -966,15 +982,16 @@
     #
     def _update_frameline_content(self, layer_idx):
 	fl_mgr = self._fl_mgr
-	scene_nodes = fl_mgr.get_all_scene_node_of_layer(layer_idx)
+	scene_nodes = self._dom.get_all_scene_node_of_layer(layer_idx)
 	for scene_node in scene_nodes:
-	    start, end, tween_name = self._parse_one_scene(scene_node)
+	    start, end, tween_name = self._dom._parse_one_scene(scene_node)
 
 	    fl_mgr.add_keyframe(layer_idx, start)
 	    fl_mgr.set_keyframe_data(layer_idx, start, scene_node)
 	    if start != end:
 		tween_type = self._tween_type_names.index(tween_name)
-		fl_mgr.tween(start, end, tween_type)
+		tween_len = end - start + 1
+		fl_mgr.tween(layer_idx, start, tween_len, tween_type)
 		pass
 	    pass
 	pass
@@ -1101,7 +1118,7 @@
     # The given frame index must be exactly a key frame.
     #
     def get_keyframe_group(self, layer_idx, frame_idx):
-	scene_node = self._fl_mgr.get_keyframe_data(frame_idx)
+	scene_node = self._fl_mgr.get_keyframe_data(layer_idx, frame_idx)
 	scene_group_id = scene_node.getAttribute('ref')
 	scene_group_node = self._dom.get_node(scene_group_id)
 	return scene_group_node
@@ -1129,13 +1146,17 @@
 	    self._fl_mgr.get_left_key_tween(layer_idx, frame_idx)
 	return start, end, tween_type
 
+    def get_layer_keys(self, layer_idx):
+	tweens = self._fl_mgr.get_all_key_tween_of_layer(layer_idx)
+	return tweens
+
     ## \brief Return widget showing frames and layers.
     #
     def get_frame_ui_widget(self):
 	return self._fl_mgr._frameline_box
 
-    def register_active_frame_cb(self, cb):
-	self._fl_mgr.register_active_frame_cb(cb)
+    def register_active_frame_callback(self, cb):
+	self._fl_mgr.register_active_frame_callback(cb)
 	pass
 
     def set_layer_label(self, txt):
@@ -1147,24 +1168,43 @@
     def get_layer_dup_group(self, layer_idx):
 	data = self._dom.get_layer_data(layer_idx)
 	if not data:
-	    data = object()
+	    data = dict()
 	    self._dom.set_layer_data(layer_idx, data)
 	    pass
 
-	if hasattr(data, 'dup_group_id'):
+	dup_group = None
+	if data.has_key('dup_group_id'):
 	    try:
-		dup_group = self._dom.get_node(data.dup_group_id)
+		dup_group = self._dom.get_node(data['dup_group_id'])
 	    except KeyError:
-		dup_group = None
 		pass
 	    pass
 	
 	if not dup_group:
+	    # Search dup group from children of the layer group
+	    layer_group = self._dom.get_layer_group(layer_idx)
+	    for child in layer_group.childList():
+		try:
+		    label = child.getAttribute('inkscape:label')
+		except:
+		    pass
+		else:
+		    if label == 'dup':
+			data['dup_group_id'] = child
+			return child
+		    pass
+		pass
+	    
+	    # Or create a new dup group for the layer
 	    dup_group = self._dom.add_layer_dup_group(layer_idx)
-	    data.dup_group_id = dup_group.getAttribute('id')
+	    data['dup_group_id'] = dup_group.getAttribute('id')
 	    pass
 
 	return dup_group
+
+    def get_max_frame(self):
+	max_frame = self._dom.get_max_frame()
+	return max_frame
     pass
 
 ## \brief MBScene connect GUI and DOM-tree
@@ -1195,6 +1235,7 @@
 	self.root = root
 	self.framerate = 12
 	self._disable_tween_type_selector = False
+	self.current = 0
 
 	self._dom = MBDOM_UI()
 	pass
@@ -1252,7 +1293,7 @@
 	layer_idx, frame_idx = self._dom.get_active_layer_frame()
 	start, end, tween_type = \
 	    self._dom.get_left_key(layer_idx, frame_idx)
-	tween_len = frame_idx - start
+	tween_len = frame_idx - start + 1
 	self._dom.tween(layer_idx, start, tween_len, tween_type)
 	
 	scene_group = self._dom.get_keyframe_group(layer_idx, start)
@@ -1282,17 +1323,19 @@
 	self.tween.updateMapping()
 	for layer_idx in range(self._dom.get_layer_num()):
 	    dup_group = self._dom.get_layer_dup_group(layer_idx)
+	    dup_group.setAttribute('style', 'display: none')
 
-	    all_key_tweens = self._dom.get_all_key_tween_of_layer(layer_idx)
-	    for start, stop, tween_type in all_key_tweens:
+	    all_key_tweens = self._dom.get_layer_keys(layer_idx)
+	    for start, end, tween_type in all_key_tweens:
 		if start == idx: # at key frame
-		    dup_group.setAttribute('style', 'display: none')
 		    scene_group = \
-			self._dom.get_keyframe_group(layer_idx, idx)
+			self._dom.get_keyframe_group(layer_idx, start)
 		    scene_group.setAttribute('style', '')
-		elif start < idx and end  >= idx: # in Tween
+		elif start < idx and end >= idx: # in Tween
+		    dup_group.setAttribute('style', '')
 		    scene_group = \
-			self._dom.get_keyframe_group(layer_idx, idx)
+			self._dom.get_keyframe_group(layer_idx, start)
+		    scene_group.setAttribute('style', 'display: none')
 		    
 		    try:
 			next_scene_group = \
@@ -1302,7 +1345,7 @@
 			pass
 
 		    tween_obj_type = self._tween_obj_tween_types[tween_type]
-		    nframes = stop - start + 1
+		    nframes = end - start + 1
 		    percent = float(idx - start) / nframes
 		    self.tween.updateTweenContent(dup_group,
 						  tween_obj_type,
@@ -1312,8 +1355,8 @@
 		    pass
 		else:		# this scene should not be showed.
 		    scene_group = \
-			self._dom.get_keyframe_group(layer_idx, idx)
-		    scene_group.setAttribute('style', '')
+			self._dom.get_keyframe_group(layer_idx, start)
+		    scene_group.setAttribute('style', 'display: none')
 		    pass
 		pass
 	    pass
@@ -1491,7 +1534,7 @@
 	pass
 
     def doRunNext(self):
-	if self.current > self._maxframe:
+	if self.current > self._dom.get_max_frame():
 	    self.current = 0
 	    pass
 	try:
@@ -1584,7 +1627,7 @@
 	self.document = self.desktop.doc().rdoc
 	self.tween = TweenObject(self.document, self.root)
 	self._dom.handle_doc_root(self.document, self.root)
-	self._dom.register_active_frame_cb(self.onCellClick)
+	self._dom.register_active_frame_callback(self.onCellClick)
 
 	if self.top == None:
 	    self.top = gtk.VBox(False, 0)