changeset 1220:9425733a677e

Merge
author wycc
date Wed, 05 Jan 2011 22:58:03 +0800
parents b5e648a317eb (diff) 35c552f33f77 (current diff)
children 33aa2d63e240 03daff2d939c
files pyink/MBScene.py
diffstat 1 files changed, 98 insertions(+), 4 deletions(-) [+]
line wrap: on
line diff
--- a/pyink/MBScene.py	Wed Jan 05 22:00:15 2011 +0800
+++ b/pyink/MBScene.py	Wed Jan 05 22:58:03 2011 +0800
@@ -793,10 +793,13 @@
 		layer_idx = frameline.layer_idx
 		layer = self._layers[layer_idx]
 		for child in layer.group.childList():
-		    label = child.getAttribute('inkscape:label')
-		    if label == 'dup':
-			frameline.duplicateGroup = child
-			break
+		    try:
+		        label = child.getAttribute('inkscape:label')
+		        if label == 'dup':
+			    frameline.duplicateGroup = child
+			    break
+		    except:
+		        pass
 		    pass
 		else:
 		    duplicateGroup = self.document.createElement("svg:g")
@@ -1169,6 +1172,89 @@
         self.last_update = glib.timeout_add(tmout, self.doRunNext)
 	pass
 
+    def remove_frame(self,line,frame):
+        for start, end, tween_type in line.get_frame_blocks():
+	    if frame > end: 
+		# Don't change the tween before the select frame
+	        continue
+	    elif frame == start: 
+	        # Please use remove key frame ro remove the key frame instead
+	        return
+	    elif frame < start:
+		# For all tweens after the frame, shift both key frames by one
+		scene_node = line.get_frame_data(start)
+		self.chg_scene_node(scene_node, start=start-1,end=end-1)
+		line.rm_keyframe(start)
+
+		if start != end:
+		    line.rm_keyframe(end)
+		line.add_keyframe(start-1)
+		line.set_frame_data(start-1,scene_node)
+		if start != end:
+		    line.add_keyframe(end-1)
+		    line.tween(start-1,tween_type)
+		pass
+	    else:
+		# For the tween contain the frame, remove the end keyframe
+		# and put it back one frame before. The tween is removed
+		# if the tween has one frame only. In this case, keep only
+		# the start key frame and remove the second one.
+		scene_node = line.get_frame_data(start)
+		self.chg_scene_node(scene_node,end=end-1)
+	        line.rm_keyframe(end)
+	        if start != end-1:
+		    line.add_keyframe(end-1)
+		    line.tween(start,tween_type)
+		pass
+	    pass
+	pass
+
+    def insert_frame(self,line,frame):
+        for start, end, tween_type in line.get_frame_blocks():
+	    print "start=",start
+	    print "end=",end
+	    if frame > end: 
+		# Don't change the tween before the select frame
+	        continue
+	    elif frame <= start:
+		# For all tweens after the frame, shift both key frames by one
+		scene_node = line.get_frame_data(start)
+		if scene_node==None: continue
+		self.chg_scene_node(scene_node,start=start+1,end=end+1)
+		line.rm_keyframe(start)
+		if start != end:
+		    line.rm_keyframe(end)
+		line.add_keyframe(start+1)
+		line.set_frame_data(start+1,scene_node)
+		if start != end:
+		    line.add_keyframe(end+1)
+		    line.tween(start+1,tween_type)
+		pass
+	    else:
+		# For the tween contain the frame, remove the end keyframe
+		# and put it back one frame before. The tween is removed
+		# if the tween has one frame only. In this case, keep only
+		# the start key frame and remove the second one.
+		scene_node = line.get_frame_data(start)
+		self.chg_scene_node(scene_node,end=end+1)
+	        line.rm_keyframe(end)
+		line.add_keyframe(end+1)
+		line.tween(start,tween_type)
+		pass
+	    pass
+	pass
+
+
+    def doInsertFrame(self,w):
+	self.lockui=True
+	self.insert_frame(self.last_line,self.last_frame)
+	self.lockui=False
+
+    def doRemoveFrame(self,w):
+        self.lockui=True
+	self.remove_frame(self.last_line,self.last_frame)
+	self.lockui=False
+
     def addButtons(self,hbox):
 	btn = gtk.Button('Insert Key')
 	btn.connect('clicked',self.doInsertKeyScene)
@@ -1186,6 +1272,14 @@
 	btn.connect('clicked', self.doDuplicateKeyScene)
 	hbox.pack_start(btn,expand=False,fill=False)
 
+	btn=gtk.Button('insert')
+	btn.connect('clicked', self.doInsertFrame)
+	hbox.pack_start(btn,expand=False,fill=False)
+	
+	btn=gtk.Button('remove')
+	btn.connect('clicked', self.doRemoveFrame)
+	hbox.pack_start(btn,expand=False,fill=False)
+	
 	btn=gtk.Button('Run')
 	btn.connect('clicked', self.doRun)
 	self.btnRun = btn