diff pyink/MBScene.py @ 1232:6d4de488389e

Change setCurrentScene
author Thinker K.F. Li <thinker@codemud.net>
date Mon, 10 Jan 2011 11:45:12 +0800
parents d28b1b840bfc
children 7f17a7e70d82
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:12 2011 +0800
@@ -569,6 +569,33 @@
 	layer = self._layers[layer_idx]
 	return layer.scenes
 
+    def get_layer_data(self, layer_idx):
+	layer = self._layers[layer_idx]
+	try:
+	    data = layer.data
+	except:
+	    return None
+	return data
+
+    def set_layer_data(self, layer_idx, data):
+	layer = self._layers[layer_idx]
+	layer.data = data
+	pass
+
+    def add_layer_dup_group(self, layer_idx):
+	layer = self._layers[layer_idx]
+	
+	dup_group = self._doc.createElement('svg:g')
+	gid = self.new_id()
+	dup_group.setAttribute('id', gid)
+	dup_group.setAttribute('inkscape:label', 'dup')
+	dup_group.setAttribute('sodipodi:insensitive', '1')
+	dup_group.setAttribute('style', '')
+
+	layer.group.appendChild(dup_group)
+	
+	return dup_group
+
     def add_frames(self, layer_idx, frame_idx, num):
 	layer = self._layers[layer_idx]
 	for scene_node in layer.scenes:
@@ -1110,6 +1137,30 @@
     def set_layer_label(self, txt):
 	self._fl_mgr.set_layer_label(txt)
 	pass
+
+    ## \brief Get duplicate group of a layer.
+    #
+    def get_layer_dup_group(self, layer_idx):
+	data = self._dom.get_layer_data(layer_idx)
+	if not data:
+	    data = object()
+	    self._dom.set_layer_data(layer_idx, data)
+	    pass
+
+	if hasattr(data, 'dup_group_id'):
+	    try:
+		dup_group = self._dom.get_node(data.dup_group_id)
+	    except KeyError:
+		dup_group = None
+		pass
+	    pass
+	
+	if not dup_group:
+	    dup_group = self._dom.add_layer_dup_group(layer_idx)
+	    data.dup_group_id = dup_group.getAttribute('id')
+	    pass
+
+	return dup_group
     pass
 
 ## \brief MBScene connect GUI and DOM-tree
@@ -1219,94 +1270,45 @@
 	"""
 	self.current = idx
 	self.tween.updateMapping()
-	for frameline in self._framelines:
-	    i=0
+	for layer_idx in range(self._dom.get_layer_num()):
+	    dup_group = self._dom.get_layer_dup_group(layer_idx)
 
-	    # Check the duplicated scene group and create it if it is not
-	    # available
-	    try:
-		frameline.duplicateGroup.setAttribute("style","display:none")
-	    except:
-	        print "*" * 40
-		layer_idx = frameline.layer_idx
-		layer = self._layers[layer_idx]
-		for child in layer.group.childList():
-		    try:
-		        label = child.getAttribute('inkscape:label')
-		        if label == 'dup':
-			    frameline.duplicateGroup = child
-			    break
-		    except:
-		        pass
-		    pass
-		else:
-		    duplicateGroup = self.document.createElement("svg:g")
-		    duplicateGroup.setAttribute("inkscape:label","dup")
-		    duplicateGroup.setAttribute("sodipodi:insensitive","1")
-		    duplicateGroup.setAttribute("style","")
-		    
-		    layer.group.appendChild(duplicateGroup)
-		    frameline.duplicateGroup = duplicateGroup
-		    pass
-	        pass
-	    
-	    # Create a new group
-	    for start_idx, stop_idx, tween_type in frameline.get_frame_blocks():
-		if start_idx == stop_idx:
-		    scene_node = frameline.get_frame_data(start_idx)
-		    scene_group_id = scene_node.getAttribute('ref')
-		    scene_group = self.get_node(scene_group_id)
-		    if idx == start_idx:
-			scene_group.setAttribute('style', '')
-		    else:
-			scene_group.setAttribute('style', 'display: none')
-			pass
-		elif idx == start_idx:
-		    frameline.duplicateGroup.setAttribute("style","display:none")
-		    scene_node = frameline.get_frame_data(start_idx)
-		    scene_group_id = scene_node.getAttribute('ref')
-		    scene_group = self.get_node(scene_group_id)
-		    scene_group.setAttribute("style","")
-		elif start_idx < idx and stop_idx >= idx:
-		    scene_node = frameline.get_frame_data(start_idx)
-		    scene_group_id = scene_node.getAttribute('ref')
-		    scene_group = self.get_node(scene_group_id)
-		    scene_group.setAttribute("style","display:none")
-		    frameline.duplicateGroup.setAttribute("style","")
-		    tween_type_idx = \
-			self._frameline_tween_types.index(tween_type)
-		    tween_obj_tween_type = \
-			self._tween_obj_tween_types[tween_type_idx]
+	    all_key_tweens = self._dom.get_all_key_tween_of_layer(layer_idx)
+	    for start, stop, 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)
+		    scene_group.setAttribute('style', '')
+		elif start < idx and end  >= idx: # in Tween
+		    scene_group = \
+			self._dom.get_keyframe_group(layer_idx, idx)
 		    
 		    try:
-			next_idx, next_stop_idx, next_tween_type = \
-			    frameline.get_frame_block(stop_idx + 1)
-		    except:
-			next_scene_node = scene_node
-		    else:
-			next_scene_node = frameline.get_frame_data(next_idx)
+			next_scene_group = \
+			    self._dom.get_keyframe_group(layer_idx, end + 1)
+		    except:	# no next key frame
+			next_scene_group = scene_group
 			pass
 
-		    next_scene_group_id = next_scene_node.getAttribute('ref')
-		    next_scene_group = self.get_node(next_scene_group_id)
-		    
-		    nframes = stop_idx - start_idx + 1
-		    percent = float(idx - start_idx) / nframes
-		    self.tween.updateTweenContent(frameline.duplicateGroup,
-						  tween_obj_tween_type,
+		    tween_obj_type = self._tween_obj_tween_types[tween_type]
+		    nframes = stop - start + 1
+		    percent = float(idx - start) / nframes
+		    self.tween.updateTweenContent(dup_group,
+						  tween_obj_type,
 						  scene_group,
 						  next_scene_group,
 						  percent)
-		else:
-		    scene_node = frameline.get_frame_data(start_idx)
-		    scene_group_id = scene_node.getAttribute('ref')
-		    scene_group = self.get_node(scene_group_id)
-		    scene_group.setAttribute("style","display:none")
+		    pass
+		else:		# this scene should not be showed.
+		    scene_group = \
+			self._dom.get_keyframe_group(layer_idx, idx)
+		    scene_group.setAttribute('style', '')
 		    pass
 		pass
 	    pass
 	pass
-
+    
     def enterGroup(self, obj):
         for l in self._layers:
 	    for s in l.group.childList():
@@ -1357,6 +1359,9 @@
     #
     # When DOM-tree is changed, this function make sure layer information is up
     # to date.
+    #
+    # TODO: move this to somewhere
+    #
     def _make_layers_integral(self):
 	root = self._root
 	root_id = root.getAttribute('id')