diff pyink/MBScene.py @ 1207:489e6e474fdf

Change names of methods and grouping methods
author Thinker K.F. Li <thinker@codemud.net>
date Tue, 04 Jan 2011 10:43:18 +0800
parents 1d476b35dc79
children 96ca8a1cf449
line wrap: on
line diff
--- a/pyink/MBScene.py	Tue Jan 04 10:08:02 2011 +0800
+++ b/pyink/MBScene.py	Tue Jan 04 10:43:18 2011 +0800
@@ -154,6 +154,8 @@
 
 ## \brief Monitor changes of DOM-tree.
 #
+# 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):
     def __init__(self, *args, **kws):
 	super(MBScene_dom_monitor, self).__init__()
@@ -400,6 +402,10 @@
 
 ## \brief Layer of MBScene to manipulate 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):
     # Declare variables, here, for keeping tracking
     _doc = None
@@ -409,31 +415,6 @@
 	super(MBScene_dom, self).__init__()
 	pass
 
-    def handle_doc_root(self, doc, root):
-	self._doc = doc
-	self._root = root
-	self._layers = []
-	
-	self._start_monitor()	# start MBScene_dom_monitor
-	self._init_metadata()
-	self._parse_all_layers()
-	pass
-   
-    def dumpattr(self, n):
-	s = ""
-	for a,v in n.attrib.items():
-	    s = s + ("%s=%s"  % (a,v))
-	    pass
-	return s
-	
-    def dump(self, node, l=0):
-	print " " * l*2,"<", node.tag, self.dumpattr(node),">"
-	for n in node:
-	    self.dump(n, l+1)
-	    pass
-	print " " * l * 2,"/>"
-	pass
-
     ## \brief Create a scenes node if not existed.
     #
     def _init_metadata(self):
@@ -459,24 +440,65 @@
 	    pass
 	pass
 
+    def _parse_all_layers(self):
+	root = self._root
+	layers = self._layers
+	
+	for child in root.childList():
+	    if child.name() != 'svg:g':
+		continue
+
+	    layer_group = child
+	    layer = Layer(layer_group)
+	    layer.idx = len(layers)
+	    layers.append(layer)
+	    self.parse_layer(layer.idx)
+	    pass
+	pass
+
+    def handle_doc_root(self, doc, root):
+	self._doc = doc
+	self._root = root
+	self._layers = []
+	
+	self._start_monitor()	# start MBScene_dom_monitor
+	self._init_metadata()
+	self._parse_all_layers()
+	pass
+   
+    def dumpattr(self, n):
+	s = ""
+	for a,v in n.attrib.items():
+	    s = s + ("%s=%s"  % (a,v))
+	    pass
+	return s
+	
+    def dump(self, node, l=0):
+	print " " * l*2,"<", node.tag, self.dumpattr(node),">"
+	for n in node:
+	    self.dump(n, l+1)
+	    pass
+	print " " * l * 2,"/>"
+	pass
+
     ## \brief Create and add a ns0:scene node under ns0:scenes subtree.
     #
-    def _add_scene_node(self, start, end,
-			frame_type=TweenObject.TWEEN_TYPE_NORMAL,
-			ref=None):
+    def add_scene_node(self, start, end,
+		       frame_type=TweenObject.TWEEN_TYPE_NORMAL,
+		       ref=None):
 	type_names = ('normal', 'scale')
 	scenes_node = self._scenes_node
 	doc = self._doc
 	
 	scene_node = doc.createElement('ns0:scene')
-	self._chg_scene_node(scene_node, start=start)
+	self.chg_scene_node(scene_node, start=start)
 	if start != end:
-	    self._chg_scene_node(scene_node, end=end)
+	    self.chg_scene_node(scene_node, end=end)
 	    pass
 	type_name = type_names[frame_type]
-	self._chg_scene_node(scene_node, tween_type=type_name)
+	self.chg_scene_node(scene_node, tween_type=type_name)
 	if ref:
-	    self._chg_scene_node(scene_node, ref=ref)
+	    self.chg_scene_node(scene_node, ref=ref)
 	    pass
 	
 	scenes_node.appendChild(scene_node)
@@ -486,7 +508,7 @@
     ## \brief Change attributes of a scene node.
     #
     # This is here to monitor changes of scene node.
-    def _chg_scene_node(self, scene_node, start=None, end=None,
+    def chg_scene_node(self, scene_node, start=None, end=None,
 			tween_type=None, ref=None):
 	if start:
 	    scene_node.setAttribute('start', str(start))
@@ -502,13 +524,13 @@
 	    pass
 	pass
 
-    def _rm_scene_node(self, scene_node):
+    def rm_scene_node(self, scene_node):
 	self._scenes_node.removeChild(scene_node)
 	pass
 
     ## \brief Create and add a svg:g for a scene under a group for a layer.
     #
-    def _add_scene_group(self, layer_idx):
+    def add_scene_group(self, layer_idx):
 	layer = self._layers[layer_idx]
 	doc = self._doc
 	
@@ -521,34 +543,6 @@
 	
 	return scene_group
     
-    def insertKeyScene(self, line, frame):
-	"""
-	Insert a new key scene into the stage. If the nth is always a
-	key scene, we will return without changing anything.  If the
-	nth is a filled scene, we will break the original scene into
-	two parts. If the nth is out of any scene, we will append a
-	new scene.
-
-	"""
-	doc = self._doc
-	layer_idx = self._framelines.index(line)
-	
-	scene_group = self._add_scene_group(layer_idx)
-	scene_group_id = scene_group.getAttribute('id')
-	scene_node = self._add_scene_node(frame, frame, ref=scene_group_id)
-	line.add_keyframe(frame, scene_node)
-
-	for node in self._layers[layer_idx].group.childList():
-	    try:
-		label = node.getAttribute('inkscape:label')
-	    except:
-		continue
-	    if label == 'dup':
-		node.setAttribute('style', 'display: none')
-		pass
-	    pass
-	pass
-
     def parse_layer(self, layer_idx):
 	layer = self._layers[layer_idx]
 	layer_group = layer.group
@@ -566,22 +560,6 @@
 	    pass
 	pass
 
-    def _parse_all_layers(self):
-	root = self._root
-	layers = self._layers
-	
-	for child in root.childList():
-	    if child.name() != 'svg:g':
-		continue
-
-	    layer_group = child
-	    layer = Layer(layer_group)
-	    layer.idx = len(layers)
-	    layers.append(layer)
-	    self.parse_layer(layer.idx)
-	    pass
-	pass
-
     ## \brief Add/insert a layer at given position.
     #
     # \param layer_idx is the position in the layer list.
@@ -656,6 +634,34 @@
 	    pass
 	pass
 
+    def insertKeyScene(self, line, frame):
+	"""
+	Insert a new key scene into the stage. If the nth is always a
+	key scene, we will return without changing anything.  If the
+	nth is a filled scene, we will break the original scene into
+	two parts. If the nth is out of any scene, we will append a
+	new scene.
+
+	"""
+	doc = self._doc
+	layer_idx = self._framelines.index(line)
+	
+	scene_group = self.add_scene_group(layer_idx)
+	scene_group_id = scene_group.getAttribute('id')
+	scene_node = self.add_scene_node(frame, frame, ref=scene_group_id)
+	line.add_keyframe(frame, scene_node)
+
+	for node in self._layers[layer_idx].group.childList():
+	    try:
+		label = node.getAttribute('inkscape:label')
+	    except:
+		continue
+	    if label == 'dup':
+		node.setAttribute('style', 'display: none')
+		pass
+	    pass
+	pass
+
     def removeKeyScene(self, frameline, frame_idx):
 	start, end, scene_type = frameline.get_frame_block(frame_idx)
 	scene_node = frameline.get_frame_data(start)
@@ -689,7 +695,7 @@
 	    pass
 	
 	scene_node = frameline.get_frame_data(start)
-	self._chg_scene_node(scene_node, end=frame_idx)
+	self.chg_scene_node(scene_node, end=frame_idx)
 	frameline.add_keyframe(frame_idx)
 	frameline.tween(start, scene_type)
 	pass
@@ -718,7 +724,8 @@
 	for frameline in self._framelines:
 	    i=0
 
-	    # Check the duplicated scene group and create it if it is not available
+	    # Check the duplicated scene group and create it if it is not
+	    # available
 	    try:
 		frameline.duplicateGroup.setAttribute("style","display:none")
 	    except:
@@ -830,19 +837,10 @@
 	self._disable_tween_type_selector = False
 	pass
 	
-    def onCellClick(self, line, frame, but):
-	self.last_line = line
-	self.last_frame = frame
-	self.last_line.active_frame(frame)
-	self._lockui = True
-        self.doEditScene(None)
-	self._lockui = False
-        pass
-        
     def _remove_active_frame(self,widget,event):
         """
-	Hide all hover frames. This is a hack. We should use the lost focus event 
-	instead in the future to reduce the overhead.
+	Hide all hover frames. This is a hack. We should use the lost focus
+	event instead in the future to reduce the overhead.
 	"""
         for f in self._framelines:
 	    if f != widget:
@@ -901,7 +899,7 @@
 	frameline = self._framelines[layer_idx]
 	for start, end, tween_type in frameline.get_frame_blocks():
 	    scene_node = frameline.get_frame_data(start)
-	    self._rm_scene_node(scene_node)
+	    self.rm_scene_node(scene_node)
 	    pass
 
 	self._remove_frameline(layer_idx) # TODO
@@ -991,17 +989,6 @@
 	    pass
 	pass
     
-    def cellSelect(self, cell, data):
-	if self.last_cell:
-	    color = self.last_cell.get_colormap().alloc_color("gray")
-	    self.last_cell.modify_bg(gtk.STATE_NORMAL, color)
-	    pass
-	
-	self.last_cell = cell
-	color = cell.get_colormap().alloc_color("green")
-	cell.modify_bg(gtk.STATE_NORMAL, color)
-	pass
-
     def duplicateKeyScene(self):
         # Search for the current scene
 	frameline = self.last_line
@@ -1019,8 +1006,8 @@
 	
 	scene_group = self.duplicateSceneGroup(prev_scene_group_id)
 	scene_group_id = scene_group.getAttribute('id')
-	scene_node = self._add_scene_node(frame_idx, frame_idx,
-					  ref=scene_group_id)
+	scene_node = self.add_scene_node(frame_idx, frame_idx,
+					 ref=scene_group_id)
 
 	frameline.add_keyframe(frame_idx, scene_node)
 
@@ -1029,23 +1016,10 @@
 
     def duplicateSceneGroup(self,gid):
 	# Search for the duplicated group
-        doc = self.root
-	rdoc = self.document
-	orig = None
-	for node in doc.childList():
-	    if node.name() == 'svg:g':
-	        for t in node.childList():
-		    if t.name() == "svg:g":
-			if t.getAttribute("id") == gid:
-			    orig = t
-			    break
-			pass
-		    pass
-		pass
-	    pass
-	if orig == None:
-	    return None
-	scene_group = orig.duplicate(rdoc)
+        root = self._root
+	doc = self._doc
+	orig = self.get_node(gid)
+	scene_group = orig.duplicate(doc)
 
 	old_nodes = _travel_DOM(orig)
 	new_nodes = _travel_DOM(scene_group)
@@ -1063,6 +1037,43 @@
 	layer.group.appendChild(scene_group)
 	return scene_group
     
+    def changeObjectLabel(self,w):
+	o = self.desktop.selection.list()[0]
+	o.setAttribute("inkscape:label", self.nameEditor.get_text())
+	pass
+
+    def addNameEditor(self,hbox):
+	self.nameEditor = gtk.Entry(max=40)
+	hbox.pack_start(self.nameEditor,expand=False,fill=False)
+	self.editDone = gtk.Button('Set')
+	hbox.pack_start(self.editDone,expand=False,fill=False)
+	self.editDone.connect('clicked', self.changeObjectLabel)
+	pass
+
+    def updateUI(self, node=None, child=None, arg=None):
+        if self._lockui: return
+	
+        if self.last_update!= None:
+            glib.source_remove(self.last_update)
+        self.last_update = glib.timeout_add(300,self._updateUI)
+	
+	pass
+    
+    def _updateUI(self,node=None,arg=None):
+	self._lockui = True
+	self._make_layers_integral()
+	self._lockui = False
+	pass
+    
+    def onCellClick(self, line, frame, but):
+	self.last_line = line
+	self.last_frame = frame
+	self.last_line.active_frame(frame)
+	self._lockui = True
+        self.doEditScene(None)
+	self._lockui = False
+        pass
+        
     def doEditScene(self, w):
 	self.setCurrentScene(self.last_frame)
 	self.selectSceneObject(self.last_line, self.last_frame)
@@ -1094,19 +1105,6 @@
 	self._lockui = False
 	pass
 
-    def changeObjectLabel(self,w):
-	o = self.desktop.selection.list()[0]
-	o.setAttribute("inkscape:label", self.nameEditor.get_text())
-	pass
-
-    def addNameEditor(self,hbox):
-	self.nameEditor = gtk.Entry(max=40)
-	hbox.pack_start(self.nameEditor,expand=False,fill=False)
-	self.editDone = gtk.Button('Set')
-	hbox.pack_start(self.editDone,expand=False,fill=False)
-	self.editDone.connect('clicked', self.changeObjectLabel)
-	pass
-
     def doRun(self,arg):
         """
 	    Execute the current animation till the last frame.
@@ -1179,7 +1177,7 @@
 	frameline.tween(start, tween_type)
 	
 	scene_node = frameline.get_frame_data(start)
-	self._chg_scene_node(scene_node, tween_type=type_name)
+	self.chg_scene_node(scene_node, tween_type=type_name)
 	pass
 
     def addTweenTypeSelector(self,hbox):
@@ -1207,21 +1205,6 @@
 	gtk.main_quit()
 	pass
 
-    def updateUI(self, node=None, child=None, arg=None):
-        if self._lockui: return
-	
-        if self.last_update!= None:
-            glib.source_remove(self.last_update)
-        self.last_update = glib.timeout_add(300,self._updateUI)
-	
-	pass
-    
-    def _updateUI(self,node=None,arg=None):
-	self._lockui = True
-	self._make_layers_integral()
-	self._lockui = False
-	pass
-    
     def show(self):
 	self.OK = True
 	if not self.root: