# HG changeset patch # User Thinker K.F. Li # Date 1294033891 -28800 # Node ID 213f03dbfc411533b7fc26f8201e95c24228b754 # Parent 25e1579ed3d17ebd7866185516a5393f3310482e Fix issue of removing a scene diff -r 25e1579ed3d1 -r 213f03dbfc41 pyink/MBScene.py --- a/pyink/MBScene.py Mon Jan 03 12:23:36 2011 +0800 +++ b/pyink/MBScene.py Mon Jan 03 13:51:31 2011 +0800 @@ -636,40 +636,23 @@ self.window.add(vbox) pass - def removeKeyScene(self): - nth = self.last_frame - y = self.last_line - rdoc = self.document - i = 0 - layer = self.last_line - while i < len(layer._keys): - s = layer._keys[i] - print "nth:%d idx %d" % (nth,s.idx) - if nth > s.idx: - if i == len(layer._keys)-1: - return - if nth == s.idx: - if s.left_tween: - # This is left tween, we move the keyframe one frame ahead - if s.idx == layer._keys[i-1].idx: - layer._keys[i].ref.parent().removeChild(layer._keys[i].ref) - self.last_line.rm_keyframe(nth) - self.last_line.rm_keyframe(nth-1) - else: - s.idx = s.idx-1 - else: - layer._keys[i].ref.parent().removeChild(layer._keys[i].ref) - if s.right_tween: - self.last_line.rm_keyframe(layer._keys[i+1].idx) - self.last_line.rm_keyframe(nth) - else: - self.last_line.rm_keyframe(nth) + def removeKeyScene(self, frameline, frame_idx): + start, end, scene_type = frameline.get_frame_block(frame_idx) + scene_node = frameline.get_frame_data(start) + + frameline.rm_keyframe(start) + if start != end: + frameline.rm_keyframe(end) + pass + + scene_group_id = scene_node.getAttribute('ref') + scene_group = self.get_node(scene_group_id) + scene_group.parent().removeChild(scene_group) + scene_node.parent().removeChild(scene_node) - self.update_scenes_of_dom() - self.last_line._draw_all_frames() - self.last_line.update() - return - i = i + 1 + try: + frameline.duplicateGroup.setAttribute('style', 'display: none') + except AttributeError: pass pass @@ -1024,7 +1007,7 @@ def doRemoveScene(self,w): self._lockui = True - self.removeKeyScene() + self.removeKeyScene(self.last_line, self.last_frame) self._lockui = False return @@ -1078,13 +1061,8 @@ self.last_line.insert_frame(self.last_frame) self.update_scenes_of_dom() self._lockui=False + pass - def doRemoveScene(self,w): - self._lockui=True - self.last_line.remove_frame(self.last_frame) - self.update_scenes_of_dom() - self._lockui=False - def addButtons(self,hbox): btn = gtk.Button('Insert Key') btn.connect('clicked',self.doInsertKeyScene) diff -r 25e1579ed3d1 -r 213f03dbfc41 pyink/frameline.py --- a/pyink/frameline.py Mon Jan 03 12:23:36 2011 +0800 +++ b/pyink/frameline.py Mon Jan 03 13:51:31 2011 +0800 @@ -716,14 +716,16 @@ if key.right_tween: right_key = self._keys[key_pos] right_key.left_tween = False - redraw_range = (right_key.idx, idx + 1) + redraw_range = (key.idx, right_key.idx + 1) else: left_key = self._keys[key_pos - 1] left_key.right_tween = False - redraw_range = (idx, left_key.idx + 1) + redraw_range = (left_key.idx, key.idx + 1) pass - self._draw_frame(i) - pass + for i in range(*redraw_range): + self._draw_frame(i) + pass + pass else: self._draw_frame(idx) pass