Revision: 37164
          
http://projects.blender.org/scm/viewvc.php?view=rev&root=bf-blender&revision=37164
Author:   jwilkins
Date:     2011-06-04 05:45:05 +0000 (Sat, 04 Jun 2011)
Log Message:
-----------
Revision: 29536
Author: nicholasbishop
Date: 10:28:27 PM, Thursday, June 17, 2010
Message:
* Changed gridkey to be a struct rather than an int. Has fields for the total 
number of each type it contains (types currently being coords, masks, normals.)
* This is a step towards having multiple layers of coords or masks.
* Should be no visible change in behavior from this commit.

Modified Paths:
--------------
    
branches/soc-2011-onion/release/scripts/startup/bl_ui/space_view3d_toolbar.py
    branches/soc-2011-onion/source/blender/blenkernel/BKE_DerivedMesh.h
    branches/soc-2011-onion/source/blender/blenkernel/BKE_subsurf.h
    branches/soc-2011-onion/source/blender/blenkernel/intern/CCGSubSurf.c
    branches/soc-2011-onion/source/blender/blenkernel/intern/CCGSubSurf.h
    branches/soc-2011-onion/source/blender/blenkernel/intern/multires.c
    branches/soc-2011-onion/source/blender/blenkernel/intern/subsurf_ccg.c
    branches/soc-2011-onion/source/blender/blenlib/BLI_pbvh.h
    branches/soc-2011-onion/source/blender/blenlib/intern/pbvh.c
    branches/soc-2011-onion/source/blender/editors/sculpt_paint/sculpt.c
    branches/soc-2011-onion/source/blender/editors/sculpt_paint/sculpt_undo.c
    branches/soc-2011-onion/source/blender/gpu/GPU_buffers.h
    branches/soc-2011-onion/source/blender/gpu/intern/gpu_buffers.c

Property Changed:
----------------
    branches/soc-2011-onion/


Property changes on: branches/soc-2011-onion
___________________________________________________________________
Modified: svn:mergeinfo
   - /branches/soc-2010-jwilkins:28499-37009
/branches/soc-2010-nicolasbishop:28448-29483,29503,29514
/trunk/blender:36833-37054
   + /branches/soc-2010-jwilkins:28499-37009
/branches/soc-2010-nicolasbishop:28448-29483,29503,29514,29536
/trunk/blender:36833-37054

Modified: 
branches/soc-2011-onion/release/scripts/startup/bl_ui/space_view3d_toolbar.py
===================================================================
--- 
branches/soc-2011-onion/release/scripts/startup/bl_ui/space_view3d_toolbar.py   
    2011-06-04 04:46:55 UTC (rev 37163)
+++ 
branches/soc-2011-onion/release/scripts/startup/bl_ui/space_view3d_toolbar.py   
    2011-06-04 05:45:05 UTC (rev 37164)
@@ -721,7 +721,7 @@
         col.operator("paint.mask_set", text="Clear").mode = 'CLEAR'
         col.operator("paint.mask_set", text="Fill").mode = 'FILL'
         col.operator("paint.mask_set", text="Invert").mode = 'INVERT'
-        col.operator("paint.mask_set", text="Random").mode = 'RANDOM'
+        #col.operator("paint.mask_set", text="Random").mode = 'RANDOM'
 
         if context.sculpt_object:
             layout.separator()

Modified: branches/soc-2011-onion/source/blender/blenkernel/BKE_DerivedMesh.h
===================================================================
--- branches/soc-2011-onion/source/blender/blenkernel/BKE_DerivedMesh.h 
2011-06-04 04:46:55 UTC (rev 37163)
+++ branches/soc-2011-onion/source/blender/blenkernel/BKE_DerivedMesh.h 
2011-06-04 05:45:05 UTC (rev 37164)
@@ -71,6 +71,7 @@
 #define SUB_ELEMS_FACE 4
 
 typedef struct DMGridData DMGridData;
+typedef struct GridKey GridKey;
 
 typedef struct DMGridAdjacency {
        int index[4];
@@ -157,7 +158,7 @@
        DMGridData **(*getGridData)(DerivedMesh *dm);
        DMGridAdjacency *(*getGridAdjacency)(DerivedMesh *dm);
        int *(*getGridOffset)(DerivedMesh *dm);
-       int (*getGridKey)(DerivedMesh *dm);
+       struct GridKey *(*getGridKey)(DerivedMesh *dm);
 
        /* Iterate over each mapped vertex in the derived mesh, calling the
         * given function with the original vert and the mapped vert's new

Modified: branches/soc-2011-onion/source/blender/blenkernel/BKE_subsurf.h
===================================================================
--- branches/soc-2011-onion/source/blender/blenkernel/BKE_subsurf.h     
2011-06-04 04:46:55 UTC (rev 37163)
+++ branches/soc-2011-onion/source/blender/blenkernel/BKE_subsurf.h     
2011-06-04 05:45:05 UTC (rev 37164)
@@ -52,29 +52,25 @@
 
 /* Grids */
 
-/* Format of the data in a grid element */
-typedef enum {
-       GRID_ELEM_KEY_CO_NO = 0,
-       GRID_ELEM_KEY_CO_MASK_NO,
-       GRID_ELEM_KEY_TOTAL
-} DMGridElemKey;
+/* Each grid element can contain zero or more layers of coordinates,
+   paint masks, and normals; these numbers are stored in the GridKey
 
-/* Information about the data stored by each type of key */
-typedef struct {
-       int size;
-       int has_mask;
-       int no_offset;
-       int mask_offset;
-       int interp_count;
-} DMGridElemKeyInfo;
+   For now, co and no can have only zero or one layers, only mask is
+   really variable.
+*/
+struct GridKey {
+       int co;
+       int mask;
+       int no;
+};
 
-extern DMGridElemKeyInfo GridElemKeyInfo[GRID_ELEM_KEY_TOTAL];
+#define GRIDELEM_KEY_INIT(_gridkey, _totco, _totmask, _totno)  \
+       (_gridkey->co = _totco, _gridkey->mask = _totmask, _gridkey->no = 
_totno)
 
-#define GRIDELEM_SIZE(_key) GridElemKeyInfo[_key].size
-#define GRIDELEM_HAS_MASK(_key) GridElemKeyInfo[_key].has_mask
-#define GRIDELEM_NO_OFFSET(_key) GridElemKeyInfo[_key].no_offset
-#define GRIDELEM_MASK_OFFSET(_key) GridElemKeyInfo[_key].mask_offset
-#define GRIDELEM_INTERP_COUNT(_key) GridElemKeyInfo[_key].interp_count
+#define GRIDELEM_SIZE(_key) ((3*_key->co + _key->mask + 3*_key->no) * 
sizeof(float))
+#define GRIDELEM_MASK_OFFSET(_key) (_key->mask ? 3*_key->co*sizeof(float) : -1)
+#define GRIDELEM_NO_OFFSET(_key) (_key->no ? (3*_key->co + _key->mask) * 
sizeof(float) : -1)
+#define GRIDELEM_INTERP_COUNT(_key) (3*_key->co + _key->mask)
 
 #define GRIDELEM_AT(_grid, _elem, _key) (struct DMGridData*)(((char*)(_grid)) 
+ (_elem) * GRIDELEM_SIZE(_key))
 #define GRIDELEM_INC(_grid, _inc, _key) ((_grid) = GRIDELEM_AT(_grid, _inc, 
_key))

Modified: branches/soc-2011-onion/source/blender/blenkernel/intern/CCGSubSurf.c
===================================================================
--- branches/soc-2011-onion/source/blender/blenkernel/intern/CCGSubSurf.c       
2011-06-04 04:46:55 UTC (rev 37163)
+++ branches/soc-2011-onion/source/blender/blenkernel/intern/CCGSubSurf.c       
2011-06-04 05:45:05 UTC (rev 37164)
@@ -759,6 +759,8 @@
        _ehash_free(ss->eMap, (EHEntryFreeFP) _edge_free, ss);
        _ehash_free(ss->vMap, (EHEntryFreeFP) _vert_free, ss);
 
+       MEM_freeN(ss->meshIFC.gridkey);
+
        CCGSUBSURF_free(ss, ss);
 
        if (allocatorIFC.release) {
@@ -2576,7 +2578,7 @@
        }
 }
 
-int ccgSubSurf_getGridKey(CCGSubSurf *ss) {
+struct GridKey *ccgSubSurf_getGridKey(CCGSubSurf *ss) {
        return ss->meshIFC.gridkey;
 }
 

Modified: branches/soc-2011-onion/source/blender/blenkernel/intern/CCGSubSurf.h
===================================================================
--- branches/soc-2011-onion/source/blender/blenkernel/intern/CCGSubSurf.h       
2011-06-04 04:46:55 UTC (rev 37163)
+++ branches/soc-2011-onion/source/blender/blenkernel/intern/CCGSubSurf.h       
2011-06-04 05:45:05 UTC (rev 37164)
@@ -22,7 +22,7 @@
           that would be (3+1) floats, so finterpCount would be 4. */
        int                     finterpCount;
 
-       int                     gridkey;
+       struct GridKey*         gridkey;
 };
 
 /***/
@@ -99,7 +99,7 @@
 int                    ccgSubSurf_getEdgeLevelSize                     
(CCGSubSurf *ss, int level);
 int                    ccgSubSurf_getGridSize                          
(CCGSubSurf *ss);
 int                    ccgSubSurf_getGridLevelSize                     
(CCGSubSurf *ss, int level);
-int                    ccgSubSurf_getGridKey                           
(CCGSubSurf *ss);
+struct GridKey*                ccgSubSurf_getGridKey                           
(CCGSubSurf *ss);
 
 CCGVert*       ccgSubSurf_getVert                                      
(CCGSubSurf *ss, CCGVertHDL v);
 CCGVertHDL     ccgSubSurf_getVertVertHandle            (CCGVert *v);

Modified: branches/soc-2011-onion/source/blender/blenkernel/intern/multires.c
===================================================================
--- branches/soc-2011-onion/source/blender/blenkernel/intern/multires.c 
2011-06-04 04:46:55 UTC (rev 37163)
+++ branches/soc-2011-onion/source/blender/blenkernel/intern/multires.c 
2011-06-04 05:45:05 UTC (rev 37164)
@@ -387,7 +387,7 @@
        }
 }
 
-static void multires_copy_dm_grid(DMGridData *gridA, DMGridData *gridB, int 
gridkey, int sizeA, int sizeB)
+static void multires_copy_dm_grid(DMGridData *gridA, DMGridData *gridB, 
GridKey *gridkey, int sizeA, int sizeB)
 {
        int x, y, j, skip;
        int size = sizeof(float)*GRIDELEM_INTERP_COUNT(gridkey);
@@ -629,7 +629,7 @@
        dispdm->release(dispdm);
 }
 
-static DMGridData **copy_grids(DMGridData **grids, int totgrid, int gridsize, 
int gridkey)
+static DMGridData **copy_grids(DMGridData **grids, int totgrid, int gridsize, 
GridKey *gridkey)
 {
        DMGridData **grids_copy = MEM_callocN(sizeof(DMGridData*) * totgrid, 
"subgrids");
        int i;
@@ -662,7 +662,8 @@
                DerivedMesh *lowdm, *cddm, *highdm;
                DMGridData **highGridData, **lowGridData, **subGridData;
                CCGSubSurf *ss;
-               int i, numGrids, highGridSize, lowGridSize, gridkey;
+               int i, numGrids, highGridSize, lowGridSize;
+               GridKey *gridkey;
 
                /* create subsurf DM from original mesh at high level */
                cddm = CDDM_from_mesh(me, NULL);
@@ -721,7 +722,7 @@
        multires_subdivide(mmd, ob, mmd->totlvl+1, updateblock, simple);
 }
 
-static void grid_tangent(int gridSize, int index, int x, int y, int axis, 
DMGridData **gridData, int gridkey, float t[3])
+static void grid_tangent(int gridSize, int index, int x, int y, int axis, 
DMGridData **gridData, GridKey *gridkey, float t[3])
 {
        DMGridData *grid = gridData[index];
 
@@ -773,7 +774,8 @@
        MFace *mface = me->mface;
        MDisps *mdisps = CustomData_get_layer(&me->fdata, CD_MDISPS);
        CustomData *stored_grids;
-       int *gridOffset, gridkey;
+       int *gridOffset;
+       GridKey *gridkey;
        int i, /*numGrids,*/ gridSize, dGridSize, dSkip;
 
        if(!mdisps) {
@@ -930,7 +932,8 @@
                        DerivedMesh *lowdm, *cddm, *highdm;
                        DMGridData **highGridData, **lowGridData, 
**subGridData, **gridData, *diffGrid;
                        CCGSubSurf *ss;
-                       int i, j, numGrids, highGridSize, lowGridSize, gridkey;
+                       int i, j, numGrids, highGridSize, lowGridSize;
+                       GridKey *gridkey;
 
                        /* create subsurf DM from original mesh at high level */
                        if (ob->derivedDeform) cddm = 
CDDM_copy(ob->derivedDeform);
@@ -1030,7 +1033,8 @@
        CCGDerivedMesh *ccgdm;
        DMGridData **gridData, **subGridData;
        int lvl= multires_get_level(ob, mmd, useRenderParams);
-       int i, gridSize, numGrids, gridkey;
+       int i, gridSize, numGrids;
+       GridKey *gridkey;
 
        if(lvl == 0)
                return dm;
@@ -1715,7 +1719,7 @@
        MDisps *mdisps;
        int *gridOffset;
        int i, /*numGrids,*/ gridSize, dGridSize, dSkip, totvert;
-       int gridKey, subGridKey;
+       struct GridKey *gridKey, *subGridKey;
        float (*vertCos)[3] = NULL;
        MultiresModifierData *mmd= get_multires_modifier(scene, ob, 1);
        MultiresModifierData high_mmd;

Modified: branches/soc-2011-onion/source/blender/blenkernel/intern/subsurf_ccg.c
===================================================================
--- branches/soc-2011-onion/source/blender/blenkernel/intern/subsurf_ccg.c      
2011-06-04 04:46:55 UTC (rev 37163)
+++ branches/soc-2011-onion/source/blender/blenkernel/intern/subsurf_ccg.c      
2011-06-04 05:45:05 UTC (rev 37164)
@@ -71,13 +71,6 @@
 
 #include "CCGSubSurf.h"
 
-/* Declared extern in BKE_subsurf.h */
-DMGridElemKeyInfo GridElemKeyInfo[GRID_ELEM_KEY_TOTAL] = {
-       /*size,            has_mask,  no_offset,        mask_offset,      
interp_count */
-       {sizeof(float)*6,  0,         sizeof(float)*3,  -1,               3     
       },
-       {sizeof(float)*7,  1,         sizeof(float)*4,  sizeof(float)*3,  4     
       }
-};
-
 static int ccgDM_getVertMapIndex(CCGSubSurf *ss, CCGVert *v);
 static int ccgDM_getEdgeMapIndex(CCGSubSurf *ss, CCGEdge *e);
 static int ccgDM_getFaceMapIndex(CCGSubSurf *ss, CCGFace *f);
@@ -101,7 +94,7 @@
        BLI_memarena_free(a);
 }
 
-static CCGSubSurf *_getSubSurf(CCGSubSurf *prevSS, int gridkey, int 
subdivLevels, int useAging, int useArena, int UNUSED(useFlatSubdiv)) {
+static CCGSubSurf *_getSubSurf(CCGSubSurf *prevSS, GridKey *gridkey, int 
subdivLevels, int useAging, int useArena, int UNUSED(useFlatSubdiv)) {
        CCGMeshIFC ifc;
        CCGSubSurf *ccgSS;
 
@@ -330,11 +323,14 @@
        int index, gridSize, gridFaces, /*edgeSize,*/ totface, x, y, S;

@@ Diff output truncated at 10240 characters. @@
_______________________________________________
Bf-blender-cvs mailing list
[email protected]
http://lists.blender.org/mailman/listinfo/bf-blender-cvs

Reply via email to