Mercurial > MadButterfly
diff pyink/MBScene.py @ 1242:1b1eb8f9a866
Rename *_dom to *_domview and *_framelines to *_frameline_stack
author | Thinker K.F. Li <thinker@codemud.net> |
---|---|
date | Mon, 10 Jan 2011 16:09:18 +0800 |
parents | e64f5bd2270c |
children | d5f70928e9f1 |
line wrap: on
line diff
--- a/pyink/MBScene.py Mon Jan 10 13:37:33 2011 +0800 +++ b/pyink/MBScene.py Mon Jan 10 16:09:18 2011 +0800 @@ -96,9 +96,9 @@ # # This class monitors DOM-tree to maintain _maxframe and maps for node ID to # node and scene group ID to scene node. -class MBScene_dom_monitor(object): +class MBScene_domview_monitor(object): def __init__(self, *args, **kws): - super(MBScene_dom_monitor, self).__init__() + super(MBScene_domview_monitor, self).__init__() self._maxframe = 0 self._id2node = {} # map ID to the node in the DOM tree. @@ -348,19 +348,19 @@ pass -## \brief Layer of MBScene to manipulate DOM tree. +## \brief This layer provide a data view to the DOM-tree. # # This class maintains layers information, and provides functions to create, # change and destroy scene node and scene group. A scene node is a 'ns0:scene' # in 'ns0:scenes' tag. A scene group is respective 'svg:g' for a scene. # -class MBScene_dom(MBScene_dom_monitor): +class MBScene_domview(MBScene_domview_monitor): # Declare variables, here, for keeping tracking _doc = None _root = None def __init__(self, *args, **kws): - super(MBScene_dom, self).__init__() + super(MBScene_domview, self).__init__() pass ## \brief Create a scenes node if not existed. @@ -409,7 +409,7 @@ self._root = root self._layers = [] - self._start_monitor() # start MBScene_dom_monitor + self._start_monitor() # start MBScene_domview_monitor self._init_metadata() self._parse_all_layers() pass @@ -647,9 +647,15 @@ return self._maxframe pass -## \brief Maintain frameline list for MBScene. +## \brief Maintain a stack of frameline UI component. # -class MBScene_framelines(object): +# Every layer is assocated with a frameline. Framelines are showed/stacked in +# virtical. Framelines of lower layers are placed at lower position on the +# screen. This class provide a set of API to access framelines with layer and +# frame index number. You access/set content of frameline by specifing layer +# index and frame index. +# +class MBScene_frameline_stack(object): _frameline_tween_types = (frameline.TWEEN_TYPE_NONE, frameline.TWEEN_TYPE_SHAPE) _num_frames_of_line = 100 @@ -657,7 +663,7 @@ _framelines = None def __init__(self, *args, **kws): - super(MBScene_framelines, self).__init__(*args, **kws) + super(MBScene_frameline_stack, self).__init__(*args, **kws) self._last_mouse_over_frameline = None self._last_active_frameline = None @@ -988,29 +994,29 @@ ## \brief Bridge of DOM-tree to syncrhonize data-model and UI. # # This class is a wrapper -class MBDOM_UI(object): +class MBScene_domview_ui(object): _tween_type_names = ('normal', 'scale') def __init__(self): - super(MBDOM_UI, self).__init__() - self._fl_mgr = MBScene_framelines() - self._dom = MBScene_dom() + super(MBScene_domview_ui, self).__init__() + self._fl_stack = MBScene_frameline_stack() + self._dom = MBScene_domview() pass ## \brief Update content of a frameline from scenes of respective layer. # def _update_frameline_content(self, layer_idx): - fl_mgr = self._fl_mgr + fl_stack = self._fl_stack scene_nodes = self._dom.get_all_scene_node_of_layer(layer_idx) for scene_node in scene_nodes: start, end, tween_name = self._dom._parse_one_scene(scene_node) - fl_mgr.mark_keyframe(layer_idx, start) - fl_mgr.set_keyframe_data(layer_idx, start, scene_node) + fl_stack.mark_keyframe(layer_idx, start) + fl_stack.set_keyframe_data(layer_idx, start, scene_node) if start != end: tween_type = self._tween_type_names.index(tween_name) tween_len = end - start + 1 - fl_mgr.tween(layer_idx, start, tween_len, tween_type) + fl_stack.tween(layer_idx, start, tween_len, tween_type) pass pass pass @@ -1025,8 +1031,8 @@ layer_group_node = self._dom.get_layer_group(layer_idx) label = layer_group_node.getAttribute('inkscape:label') - self._fl_mgr._add_frameline(layer_idx) - self._fl_mgr.set_layer_label(layer_idx, label) + self._fl_stack._add_frameline(layer_idx) + self._fl_stack.set_layer_label(layer_idx, label) self._update_frameline_content(layer_idx) pass @@ -1036,9 +1042,9 @@ # def handle_doc_root(self, doc, root): self._dom.handle_doc_root(doc, root) - self._fl_mgr._init_framelines() + self._fl_stack._init_framelines() self._add_frameline_for_every_layer() - self._fl_mgr._show_framelines() + self._fl_stack._show_framelines() pass ## \brief Mark given frame as a key frame. @@ -1050,8 +1056,8 @@ scene_node = self._dom.add_scene_node(key_idx, key_idx) self._dom.chg_scene_node(scene_node, ref=scene_group_id) - self._fl_mgr.mark_keyframe(layer_idx, key_idx) - self._fl_mgr.set_keyframe_data(layer_idx, key_idx, scene_node) + self._fl_stack.mark_keyframe(layer_idx, key_idx) + self._fl_stack.set_keyframe_data(layer_idx, key_idx, scene_node) pass ## \brief Tweening a key frame. @@ -1061,10 +1067,10 @@ # def tween(self, layer_idx, key_frame_idx, tween_len, tween_type=TweenObject.TWEEN_TYPE_NORMAL): - self._fl_mgr.tween(layer_idx, key_frame_idx, tween_len, tween_type) + self._fl_stack.tween(layer_idx, key_frame_idx, tween_len, tween_type) end_frame_idx = key_frame_idx + tween_len - 1 - scene_node = self._fl_mgr.get_keyframe_data(layer_idx, key_frame_idx) + scene_node = self._fl_stack.get_keyframe_data(layer_idx, key_frame_idx) tween_name = self._tween_type_names[tween_type] self._dom.chg_scene_node(scene_node, end=end_frame_idx, tween_type=tween_name) @@ -1074,9 +1080,9 @@ # def chg_tween(self, layer_idx, key_frame_idx, tween_len=None, tween_type=None): - scene_node = self._fl_mgr.get_keyframe_data(layer_idx, key_frame_idx) + scene_node = self._fl_stack.get_keyframe_data(layer_idx, key_frame_idx) start, end, old_tween_type = \ - self._fl_mgr.get_key_tween(layer_idx, key_frame_idx) + self._fl_stack.get_key_tween(layer_idx, key_frame_idx) if tween_len is not None: end = start + tween_len - 1 @@ -1092,16 +1098,16 @@ pass tween_len = end - start + 1 - self._fl_mgr.tween(layer_idx, start, tween_len, tween_type) + self._fl_stack.tween(layer_idx, start, tween_len, tween_type) pass ## \brief Unmark a frame from a key frame. # def unmark_key(self, layer_idx, key_frame_idx): - scene_node = self._fl_mgr.get_keyframe_data(layer_idx, key_frame_idx) + scene_node = self._fl_stack.get_keyframe_data(layer_idx, key_frame_idx) self._dom.rm_scene_node_n_group(scene_node) - self._fl_mgr.unmark_keyframe(layer_idx, key_frame_idx) + self._fl_stack.unmark_keyframe(layer_idx, key_frame_idx) pass ## \brief Insert frames at specified position. @@ -1109,7 +1115,7 @@ # All frame at and after given position will shift right. # def insert_frames(self, layer_idx, frame_idx, num): - self._fl_mgr.insert_frames(layer_idx, frame_idx, num) + self._fl_stack.insert_frames(layer_idx, frame_idx, num) self._dom.insert_frames(layer_idx, frame_idx, num) pass @@ -1119,7 +1125,7 @@ # \ref num frames are removed. # def rm_frames(self, layer_idx, frame_idx, num): - self._fl_mgr.insert_frames(layer_idx, frame_idx, num) + self._fl_stack.insert_frames(layer_idx, frame_idx, num) self._dom.rm_frames(layer_idx, frame_idx, num) pass @@ -1130,20 +1136,20 @@ # def insert_layer(self, layer_idx): self._dom.insert_layer(layer_idx) - self._fl_mgr._add_frameline(layer_idx) - self._fl_mgr._show_framelines() + self._fl_stack._add_frameline(layer_idx) + self._fl_stack._show_framelines() pass ## \brief Remove given layer. # def rm_layer(self, layer_idx): self._dom.rm_layer(layer_idx) - self._fl_mgr._remove_frameline(layer_idx) - self._fl_mgr._show_framelines() + self._fl_stack._remove_frameline(layer_idx) + self._fl_stack._show_framelines() pass def set_active_layer_frame(self, layer_idx, frame_idx): - self._fl_mgr.active_frame(layer_idx, frame_idx) + self._fl_stack.active_frame(layer_idx, frame_idx) pass ## \bref Return current active frame and its layer. @@ -1151,7 +1157,7 @@ # \return (layer_idx, frame_idx) of active frame, or (-1, -1) when no # active one. def get_active_layer_frame(self): - layer_idx, frame_idx = self._fl_mgr.get_active_layer_frame() + layer_idx, frame_idx = self._fl_stack.get_active_layer_frame() return layer_idx, frame_idx def get_layer_num(self): @@ -1162,7 +1168,7 @@ # The given frame index must be exactly a key frame. # def get_key_group(self, layer_idx, frame_idx): - scene_node = self._fl_mgr.get_keyframe_data(layer_idx, frame_idx) + scene_node = self._fl_stack.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 @@ -1182,31 +1188,31 @@ # def get_key(self, layer_idx, frame_idx): start, end, tween_type = \ - self._fl_mgr.get_key_tween(layer_idx, frame_idx) + self._fl_stack.get_key_tween(layer_idx, frame_idx) return start, end, tween_type def get_left_key(self, layer_idx, frame_idx): start, end, tween_type = \ - self._fl_mgr.get_left_key_tween(layer_idx, frame_idx) + self._fl_stack.get_left_key_tween(layer_idx, frame_idx) return start, end, tween_type ## \brief Return information of key frames in the given layer. # def get_layer_keys(self, layer_idx): - key_tweens = self._fl_mgr.get_all_key_tween_of_layer(layer_idx) + key_tweens = self._fl_stack.get_all_key_tween_of_layer(layer_idx) return key_tweens ## \brief Return widget showing frames and layers. # def get_frame_ui_widget(self): - return self._fl_mgr._frameline_box + return self._fl_stack._frameline_box ## \brief Register a callback for activating a frame event. # # The callback function is called when a frame is activated. # def register_active_frame_callback(self, cb): - self._fl_mgr.register_active_frame_callback(cb) + self._fl_stack.register_active_frame_callback(cb) pass ## \brief Get duplicate group of a layer. @@ -1255,9 +1261,8 @@ ## \brief MBScene connect GUI and DOM-tree # -# This class connect behavior of GUI to the DOM-tree. All about GUI is -# implemented by this class. It use API provided by MBScene_dom to reflect -# actions to the DOM-tree. +# This method accepts user actions and involves MBScene_domview_ui to update +# data on the document. # class MBScene(object): _tween_obj_tween_types = (TweenObject.TWEEN_TYPE_NORMAL, @@ -1283,7 +1288,7 @@ self._disable_tween_type_selector = False self.current = 0 - self._dom = MBDOM_UI() + self._domview = MBScene_domview_ui() pass def change_active_frame(self, node): @@ -1300,11 +1305,11 @@ try: layer_idx, (start, end, tween_type) = \ - self._dom.find_key_from_group(node_id) + self._domview.find_key_from_group(node_id) except: pass else: - self._dom.set_active_layer_frame(layer_idx, start) + self._domview.set_active_layer_frame(layer_idx, start) break node = node.parent() @@ -1321,24 +1326,24 @@ """ try: - self._dom.mark_key(layer_idx, frame_idx) + self._domview.mark_key(layer_idx, frame_idx) except ValueError: # existed key frame pass pass def removeKeyScene(self, layer_idx, frame_idx): - self._dom.unmark_key(layer_idx, frame_idx) + self._domview.unmark_key(layer_idx, frame_idx) self.setCurrentScene(frame_idx) pass def extendScene(self): - layer_idx, frame_idx = self._dom.get_active_layer_frame() + layer_idx, frame_idx = self._domview.get_active_layer_frame() start, end, tween_type = \ - self._dom.get_left_key(layer_idx, frame_idx) + self._domview.get_left_key(layer_idx, frame_idx) tween_len = frame_idx - start + 1 - self._dom.tween(layer_idx, start, tween_len, tween_type) + self._domview.tween(layer_idx, start, tween_len, tween_type) - scene_group = self._dom.get_key_group(layer_idx, start) + scene_group = self._domview.get_key_group(layer_idx, start) self._enterGroup(scene_group) pass @@ -1363,25 +1368,25 @@ """ self.current = idx self.tween.updateMapping() - for layer_idx in range(self._dom.get_layer_num()): - dup_group = self._dom.get_layer_dup_group(layer_idx) + for layer_idx in range(self._domview.get_layer_num()): + dup_group = self._domview.get_layer_dup_group(layer_idx) dup_group.setAttribute('style', 'display: none') - all_key_tweens = self._dom.get_layer_keys(layer_idx) + all_key_tweens = self._domview.get_layer_keys(layer_idx) for start, end, tween_type in all_key_tweens: if start == idx: # at key frame scene_group = \ - self._dom.get_key_group(layer_idx, start) + self._domview.get_key_group(layer_idx, start) scene_group.setAttribute('style', '') elif start < idx and end >= idx: # in Tween dup_group.setAttribute('style', '') scene_group = \ - self._dom.get_key_group(layer_idx, start) + self._domview.get_key_group(layer_idx, start) scene_group.setAttribute('style', 'display: none') try: next_scene_group = \ - self._dom.get_key_group(layer_idx, end + 1) + self._domview.get_key_group(layer_idx, end + 1) except: # no next key frame next_scene_group = scene_group pass @@ -1397,7 +1402,7 @@ pass else: # this scene should not be showed. scene_group = \ - self._dom.get_key_group(layer_idx, start) + self._domview.get_key_group(layer_idx, start) scene_group.setAttribute('style', 'display: none') pass pass @@ -1416,32 +1421,33 @@ def selectSceneObject(self, layer_idx, frame_idx): try: - start, stop, tween_type = self._dom.get_key(layer_idx, frame_idx) + start, stop, tween_type = \ + self._domview.get_key(layer_idx, frame_idx) except: return - scene_group = self._dom.get_key_group(layer_idx, start) + scene_group = self._domview.get_key_group(layer_idx, start) self._enterGroup(scene_group) self.setTweenType(tween_type) pass def duplicateKeyScene(self): # Search for the current scene - layer_idx, frame_idx = self._dom.get_active_layer_frame() + layer_idx, frame_idx = self._domview.get_active_layer_frame() try: left_start, left_end, left_tween_type = \ - self._dom.get_left_key(layer_idx, frame_idx) + self._domview.get_left_key(layer_idx, frame_idx) except: return if left_end >= frame_idx: return - self._dom.mark_key(layer_idx, frame_idx) + self._domview.mark_key(layer_idx, frame_idx) - scene_group = self._dom.get_key_group(layer_idx, frame_idx) + scene_group = self._domview.get_key_group(layer_idx, frame_idx) left_scene_group = \ - self._dom.get_key_group(layer_idx, left_start) + self._domview.get_key_group(layer_idx, left_start) dup_group = self._duplicate_group(left_scene_group, scene_group) @@ -1532,7 +1538,7 @@ def doInsertKeyScene(self,w): self._lockui=True - layer_idx, frame_idx = self._dom.get_active_layer_frame() + layer_idx, frame_idx = self._domview.get_active_layer_frame() self.insertKeyScene(layer_idx, frame_idx) self.selectSceneObject(layer_idx, frame_idx) self._lockui=False @@ -1545,7 +1551,7 @@ def doRemoveScene(self,w): self._lockui = True - layer_idx, frame_idx = self._dom.get_active_layer_frame() + layer_idx, frame_idx = self._domview.get_active_layer_frame() self.removeKeyScene(layer_idx, frame_idx) self._lockui = False return @@ -1574,7 +1580,7 @@ pass def doRunNext(self): - if self.current > self._dom.get_max_frame(): + if self.current > self._domview.get_max_frame(): self.current = 0 pass try: @@ -1589,28 +1595,28 @@ def doInsertFrame(self, w): self.lockui=True - layer_idx, frame_idx = self._dom.get_active_layer_frame() - self._dom.insert_frames(layer_idx, frame_idx, 1) + layer_idx, frame_idx = self._domview.get_active_layer_frame() + self._domview.insert_frames(layer_idx, frame_idx, 1) self.lockui=False def doRemoveFrame(self, w): self.lockui=True - layer_idx, frame_idx = self._dom.get_active_layer_frame() - self._dom.rm_frames(layer_idx, frame_idx, 1) + layer_idx, frame_idx = self._domview.get_active_layer_frame() + self._domview.rm_frames(layer_idx, frame_idx, 1) self.lockui=False def onTweenTypeChange(self, w): if self._disable_tween_type_selector: return - layer_idx, frame_idx = self._dom.get_active_layer_frame() + layer_idx, frame_idx = self._domview.get_active_layer_frame() tween_type = self.tweenTypeSelector.get_active() start, end, old_tween_type = \ - self._dom.get_left_key(layer_idx, frame_idx) + self._domview.get_left_key(layer_idx, frame_idx) if end >= frame_idx and start != end: # Length of tween > 1 and cover this frame - self._dom.chg_tween(layer_idx, start, tween_type=tween_type) + self._domview.chg_tween(layer_idx, start, tween_type=tween_type) pass pass @@ -1667,8 +1673,8 @@ 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_callback(self.onCellClick) + self._domview.handle_doc_root(self.document, self._root) + self._domview.register_active_frame_callback(self.onCellClick) if self.top == None: self.top = gtk.VBox(False, 0) @@ -1681,7 +1687,7 @@ vbox = gtk.VBox(False, 0) self.startWindow = vbox self.top.pack_start(vbox, expand=False) - frame_ui = self._dom.get_frame_ui_widget() + frame_ui = self._domview.get_frame_ui_widget() vbox.pack_start(frame_ui, expand=False) hbox=gtk.HBox(False, 0) self._add_buttons(hbox)