diff src/redraw_man.c @ 519:7a1b17ebb3b4 Android_Skia

Change documentation for zeroing
author Thinker K.F. Li <thinker@branda.to>
date Thu, 17 Dec 2009 16:09:46 +0800
parents d186d1e24458
children f106b57b8660
line wrap: on
line diff
--- a/src/redraw_man.c	Tue Dec 01 22:55:27 2009 +0800
+++ b/src/redraw_man.c	Thu Dec 17 16:09:46 2009 +0800
@@ -229,12 +229,12 @@
  *
  * \section cache_imp Implementation of Cache
  * Both cached coords and coords that opacity != 1 need a canvas to
- * draw descendants on.  Both cases are traded in the same way.
- * Every of them own a canvas_info to describe canvas and related
+ * draw descendants on.  Both cases are traded in the same way.  Every
+ * of them own a canvas_info to describe canvas and related
  * information.  aggr_matrix of descendants must be adjusted to make
- * left-top of range just at origin of canvas.  It can save space by setting
- * just large enough to hold rendering result of descendants.  The process
- * of adjusting is zeroing.
+ * left-top of bounding box just at origin (0, 0) of canvas.  It saves
+ * space to give a canvas just enough for rending descadants.  The
+ * process of adjusting left-top of bounding box is zeroing.
  *
  * Following is rules.
  * - zeroing on a cached coord is performed by adjust coord_t::aggr_matrix 
@@ -242,18 +242,20 @@
  * - Clean coords works just like before without change.
  *   - in preorder
  * - never perform zeroing on root_coord.
- * - zeroing on cached coords marked with \ref COF_MUST_ZEROING.
+ * - do zeroing on cached coords marked with \ref COF_MUST_ZEROING.
  *   - when clean a descendant that moves out-side of it's canvas,
  *     respective cached coord is marked with \ref COF_MUST_ZEROING.
  *   - zeroing is performed immediately after clean coords.
- *   - zeroing will not propagate acrossing boundary of cached coord.
- *     - It will be stopped at descendants which are cached coords.
+ *   - zeroing will not be propagated to ancestors of a cached coord.
+ *     - It will be stopped once a cached coord being found.
  *     - coord_t::cur_area and coord_t::aggr_matrix of cached coords
  *       must be ajdusted.
  * - the area of a cached coord is defined in parent space.
  *   - areas of descendants are defined in space defined by aggr_matrix of
  *     cached coord.
- *   - parent know the area in where cached coord and descendnats will
+ *     - coord_t::aggr_matrix of cached coord defines coordination of
+ *       descendants.
+ *   - the parent knows the area in where cached coord and descendnats will
  *     be draw.
  * - cached coords keep their private dirty area list.
  *   - private dirty areas of a cached coord are transformed and added to
@@ -1492,7 +1494,7 @@
     add_dirty_area(rdman, coord, area);
 }
 
-/*! \brief Add canvas owner of dirty geos to coord_t::zeroing_coords.
+/*! \brief Add canvas owner of dirty geos to redraw_man_t::zeroing_coords.
  *
  * All possible coords that need a zeroing have at least one dirty geo.
  */
@@ -1503,6 +1505,7 @@
     int n_dirty_coords;
     coord_t **dirty_coords, *coord;
 
+    /* Mark all cached ancestor coords of dirty geos */
     n_dirty_geos = rdman->dirty_geos.num;
     dirty_geos = rdman->dirty_geos.ds;
     for(i = 0; i < n_dirty_geos; i++) {
@@ -1516,6 +1519,7 @@
 	}
     }
     
+    /* Mark all cached ancestor coords of dirty coords */
     n_dirty_coords = rdman->dirty_coords.num;
     dirty_coords = rdman->dirty_coords.ds;
     for(i = 0; i < n_dirty_coords; i++) {
@@ -1528,12 +1532,14 @@
 	}
     }
     
+    /* Add all marked coords into redraw_man_t::zeroing_coords list */
     FOR_COORDS_PREORDER(rdman->root_coord, coord) {
 	if(!coord_get_flags(coord, COF_TEMP_MARK)) {
 	    preorder_coord_skip_subtree(coord);
 	    continue;
 	}
 	add_zeroing_coord(rdman, coord);
+	
 	coord_clear_flags(coord, COF_TEMP_MARK);
     }
     
@@ -2110,6 +2116,7 @@
 	rdman->n_dirty_areas = 0;
     }
 
+    /* clear COF_MUST_ZEROING flag for coords */
     coords = rdman->zeroing_coords.ds;
     for(i = 0; i < rdman->zeroing_coords.num; i++) {
 	coord = coords[i];