diff pyink/MBScene.py @ 1237:b5cceb2b87bb

Sucessful extend and duplicate
author Thinker K.F. Li <thinker@codemud.net>
date Mon, 10 Jan 2011 11:45:13 +0800
parents 2eeac97853eb
children 2febe4a301fa
line wrap: on
line diff
--- a/pyink/MBScene.py	Mon Jan 10 11:45:13 2011 +0800
+++ b/pyink/MBScene.py	Mon Jan 10 11:45:13 2011 +0800
@@ -804,9 +804,9 @@
     # \return (-1, -1) for no active, (layer_idx, frame_idx) for current
     #		active.
     def get_active_layer_frame(self):
-	if self._active_frameline:
-	    layer_idx = self._active_frameline.layer_idx
-	    frame_idx = self._active_frameline.get_active_frame()
+	if self._last_active_frameline:
+	    layer_idx = self._last_active_frameline.layer_idx
+	    frame_idx = self._last_active_frameline.get_active_frame()
 	    if frame_idx != -1:
 		return layer_idx, frame_idx
 	    pass
@@ -1025,7 +1025,7 @@
 	scene_group_id = scene_group.getAttribute('id')
 	
 	scene_node = self._dom.add_scene_node(key_idx, key_idx)
-	scene_node.chg_scene_node(scene_node, ref=scene_group_id)
+	self._dom.chg_scene_node(scene_node, ref=scene_group_id)
 	
 	self._fl_mgr.add_keyframe(layer_idx, key_idx)
 	self._fl_mgr.set_keyframe_data(layer_idx, key_idx, scene_node)
@@ -1232,7 +1232,7 @@
 	self._lockui = False
 	self.tween = None
 	self.document = None
-	self.root = root
+	self._root = root
 	self.framerate = 12
 	self._disable_tween_type_selector = False
 	self.current = 0
@@ -1297,7 +1297,7 @@
 	self._dom.tween(layer_idx, start, tween_len, tween_type)
 	
 	scene_group = self._dom.get_keyframe_group(layer_idx, start)
-	self._enterGroup(scene_gorup)
+	self._enterGroup(scene_group)
 	pass
     
     def setCurrentScene(self, idx):
@@ -1401,10 +1401,9 @@
 	
 	scene_group = self._dom.get_keyframe_group(layer_idx, frame_idx)
 	left_scene_group = \
-	    self._dom.get_keyframe_group(layer_idx, left_frame_idx)
+	    self._dom.get_keyframe_group(layer_idx, left_start)
 	
-	left_scene_group_id = left_scene_group.getAttribute('id')
-	dup_group = self._duplicate_group(left_scene_group_id, scene_group)
+	dup_group = self._duplicate_group(left_scene_group, scene_group)
 
 	self.setCurrentScene(frame_idx)
 	pass
@@ -1416,10 +1415,11 @@
     def _duplicate_group(self, src_group, dst_group):
 	# Search for the duplicated group
         root = self._root
-	doc = self._doc
+	doc = self.document
 	
-	dup_group = orig.duplicate(doc)
+	dup_group = src_group.duplicate(doc)
 	for child in dup_group.childList():
+	    dup_group.removeChild(child) # prvent from crash
 	    dst_group.appendChild(child)
 	    pass
 
@@ -1620,13 +1620,13 @@
 
     def show(self):
 	self.OK = True
-	if not self.root:
-	    self.root = self.desktop.doc().root().repr
+	if not self._root:
+	    self._root = self.desktop.doc().root().repr
 	    pass
 	
 	self.document = self.desktop.doc().rdoc
-	self.tween = TweenObject(self.document, self.root)
-	self._dom.handle_doc_root(self.document, self.root)
+	self.tween = TweenObject(self.document, self._root)
+	self._dom.handle_doc_root(self.document, self._root)
 	self._dom.register_active_frame_callback(self.onCellClick)
 
 	if self.top == None: