[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [15954] branches/harmonic-skeleton/source/ blender: Option to hide embedding dots on display
Martin Poirier
theeth at yahoo.com
Mon Aug 4 21:12:42 CEST 2008
Revision: 15954
http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=15954
Author: theeth
Date: 2008-08-04 21:12:42 +0200 (Mon, 04 Aug 2008)
Log Message:
-----------
Option to hide embedding dots on display
Merge internal and external filtering in a single loop (solve problems caused by order of filtering)
Made graph length calculations work on cyclic graphs (it unrolls them)
Modified Paths:
--------------
branches/harmonic-skeleton/source/blender/blenlib/BLI_graph.h
branches/harmonic-skeleton/source/blender/blenlib/intern/graph.c
branches/harmonic-skeleton/source/blender/makesdna/DNA_scene_types.h
branches/harmonic-skeleton/source/blender/src/buttons_editing.c
branches/harmonic-skeleton/source/blender/src/reeb.c
Modified: branches/harmonic-skeleton/source/blender/blenlib/BLI_graph.h
===================================================================
--- branches/harmonic-skeleton/source/blender/blenlib/BLI_graph.h 2008-08-04 17:24:11 UTC (rev 15953)
+++ branches/harmonic-skeleton/source/blender/blenlib/BLI_graph.h 2008-08-04 19:12:42 UTC (rev 15954)
@@ -85,7 +85,7 @@
#define SHAPE_RADIX 10 /* each shape level is encoded this base */
int BLI_subtreeShape(BNode *node, BArc *rootArc, int include_root);
-float BLI_subtreeLength(BNode *node, BArc *rootArc);
+float BLI_subtreeLength(BNode *node);
void BLI_calcGraphLength(BGraph *graph);
void BLI_replaceNode(BGraph *graph, BNode *node_src, BNode *node_replaced);
Modified: branches/harmonic-skeleton/source/blender/blenlib/intern/graph.c
===================================================================
--- branches/harmonic-skeleton/source/blender/blenlib/intern/graph.c 2008-08-04 17:24:11 UTC (rev 15953)
+++ branches/harmonic-skeleton/source/blender/blenlib/intern/graph.c 2008-08-04 19:12:42 UTC (rev 15954)
@@ -397,57 +397,53 @@
}
}
-float BLI_subtreeLength(BNode *node, BArc *rootArc)
+float BLI_subtreeLength(BNode *node)
{
float length = 0;
int i;
+ node->flag = 0; /* flag node as visited */
+
for(i = 0; i < node->degree; i++)
{
BArc *arc = node->arcs[i];
+ BNode *other_node = BLI_otherNode(arc, node);
- /* don't go back on the root arc */
- if (arc != rootArc)
+ if (other_node->flag != 0)
{
- length = MAX2(length, BLI_subtreeLength(BLI_otherNode(arc, node), arc));
+ float subgraph_length = arc->length + BLI_subtreeLength(other_node);
+ length = MAX2(length, subgraph_length);
}
}
- if (rootArc)
- {
- length += rootArc->length;
- }
-
return length;
}
void BLI_calcGraphLength(BGraph *graph)
{
- if (BLI_isGraphCyclic(graph) == 0)
+ float length = 0;
+ int nb_subgraphs;
+ int i;
+
+ nb_subgraphs = BLI_FlagSubgraphs(graph);
+
+ for (i = 1; i <= nb_subgraphs; i++)
{
- float length = 0;
- int nb_subgraphs;
- int i;
+ BNode *node;
- nb_subgraphs = BLI_FlagSubgraphs(graph);
-
- for (i = 1; i <= nb_subgraphs; i++)
+ for (node = graph->nodes.first; node; node = node->next)
{
- BNode *node;
-
- for (node = graph->nodes.first; node; node = node->next)
+ /* start on an external node of the subgraph */
+ if (node->flag == i && node->degree == 1)
{
- /* start on an external node of the subgraph */
- if (node->flag == i && node->degree == 1)
- {
- length = MAX2(length, BLI_subtreeLength(node, NULL));
- break;
- }
+ float subgraph_length = BLI_subtreeLength(node);
+ length = MAX2(length, subgraph_length);
+ break;
}
}
-
- graph->length = length;
}
+
+ graph->length = length;
}
/********************************* SYMMETRY DETECTION **************************************************/
Modified: branches/harmonic-skeleton/source/blender/makesdna/DNA_scene_types.h
===================================================================
--- branches/harmonic-skeleton/source/blender/makesdna/DNA_scene_types.h 2008-08-04 17:24:11 UTC (rev 15953)
+++ branches/harmonic-skeleton/source/blender/makesdna/DNA_scene_types.h 2008-08-04 19:12:42 UTC (rev 15954)
@@ -849,6 +849,7 @@
#define SKGEN_DISP_LENGTH (1 << 10)
#define SKGEN_DISP_WEIGHT (1 << 11)
#define SKGEN_DISP_ORIG (1 << 12)
+#define SKGEN_DISP_EMBED (1 << 13)
#define SKGEN_SUB_LENGTH 0
#define SKGEN_SUB_ANGLE 1
Modified: branches/harmonic-skeleton/source/blender/src/buttons_editing.c
===================================================================
--- branches/harmonic-skeleton/source/blender/src/buttons_editing.c 2008-08-04 17:24:11 UTC (rev 15953)
+++ branches/harmonic-skeleton/source/blender/src/buttons_editing.c 2008-08-04 19:12:42 UTC (rev 15954)
@@ -5046,9 +5046,12 @@
skgen_graph_block(block);
- uiDefButBitS(block, TOG, SKGEN_DISP_LENGTH, REDRAWVIEW3D, "Length", 1025, 40, 83,19, &G.scene->toolsettings->skgen_options, 0, 0, 0, 0, "Show Length");
- uiDefButBitS(block, TOG, SKGEN_DISP_WEIGHT, REDRAWVIEW3D, "Weight", 1108, 40, 83,19, &G.scene->toolsettings->skgen_options, 0, 0, 0, 0, "Show Weight");
- uiDefButBitS(block, TOG, SKGEN_DISP_ORIG, REDRAWVIEW3D, "Original", 1191, 40, 84,19, &G.scene->toolsettings->skgen_options, 0, 0, 0, 0, "Show Original Graph");
+ uiBlockBeginAlign(block);
+ uiDefButBitS(block, TOG, SKGEN_DISP_LENGTH, REDRAWVIEW3D, "Length", 1025, 40, 63,19, &G.scene->toolsettings->skgen_options, 0, 0, 0, 0, "Show Length");
+ uiDefButBitS(block, TOG, SKGEN_DISP_WEIGHT, REDRAWVIEW3D, "Weight", 1088, 40, 63,19, &G.scene->toolsettings->skgen_options, 0, 0, 0, 0, "Show Weight");
+ uiDefButBitS(block, TOG, SKGEN_DISP_EMBED, REDRAWVIEW3D, "Embed", 1151, 40, 62,19, &G.scene->toolsettings->skgen_options, 0, 0, 0, 0, "Show Arc Embedings");
+ uiDefButBitS(block, TOG, SKGEN_DISP_ORIG, REDRAWVIEW3D, "Original", 1213, 40, 62,19, &G.scene->toolsettings->skgen_options, 0, 0, 0, 0, "Show Original Graph");
+ uiBlockEndAlign(block);
uiDefButC(block, NUM, REDRAWVIEW3D, "Level:", 1025, 20, 125,19, &G.scene->toolsettings->skgen_multi_level, 0, REEB_MAX_MULTI_LEVEL, 1, 0,"Specify the level to draw");
}
Modified: branches/harmonic-skeleton/source/blender/src/reeb.c
===================================================================
--- branches/harmonic-skeleton/source/blender/src/reeb.c 2008-08-04 17:24:11 UTC (rev 15953)
+++ branches/harmonic-skeleton/source/blender/src/reeb.c 2008-08-04 19:12:42 UTC (rev 15954)
@@ -744,6 +744,11 @@
float average_length = 0, length;
int padding_head = 0, padding_tail = 0;
+ if (arc->bcount == 0)
+ {
+ return; /* failsafe, shouldn't happen */
+ }
+
initArcIterator(&iter, arc, arc->head);
for ( previous = nextBucket(&iter), bucket = nextBucket(&iter);
@@ -778,6 +783,8 @@
memcpy(arc->buckets + padding_head, old_buckets, arc->bcount * sizeof(EmbedBucket));
arc->bcount = padding_head + arc->bcount + padding_tail;
+
+ MEM_freeN(old_buckets);
}
if (padding_head > 0)
@@ -1437,41 +1444,27 @@
}
}
-int filterInternalReebGraph(ReebGraph *rg, float threshold)
+int filterInternalExternalReebGraph(ReebGraph *rg, float threshold_internal, float threshold_external)
{
ReebArc *arc = NULL, *nextArc = NULL;
int value = 0;
BLI_sortlist(&rg->arcs, compareArcs);
- arc = rg->arcs.first;
- while(arc)
+
+ for (arc = rg->arcs.first; arc; arc = nextArc)
{
nextArc = arc->next;
// Only collapse non-terminal arcs that are shorter than threshold
- if (arc->head->degree > 1 && arc->tail->degree > 1 && (lengthArc(arc) < threshold))
+ if (threshold_internal > 0 && arc->head->degree > 1 && arc->tail->degree > 1 && (lengthArc(arc) < threshold_internal))
{
ReebNode *newNode = NULL;
ReebNode *removedNode = NULL;
-#if 0 // Old method
- /* Keep the node with the highestn number of connected arcs */
- if (arc->head->degree >= arc->tail->degree)
- {
- newNode = arc->head;
- removedNode = arc->tail;
- }
- else
- {
- newNode = arc->tail;
- removedNode = arc->head;
- }
-#else
/* Always remove lower node, so arcs don't flip */
newNode = arc->head;
removedNode = arc->tail;
-#endif
filterArc(rg, newNode, removedNode, arc, 1);
@@ -1485,26 +1478,8 @@
value = 1;
}
- arc = nextArc;
- }
-
- return value;
-}
-
-int filterExternalReebGraph(ReebGraph *rg, float threshold)
-{
- ReebArc *arc = NULL, *nextArc = NULL;
- int value = 0;
-
- BLI_sortlist(&rg->arcs, compareArcs);
-
-
- for (arc = rg->arcs.first; arc; arc = nextArc)
- {
- nextArc = arc->next;
-
// Only collapse terminal arcs that are shorter than threshold
- if ((arc->head->degree == 1 || arc->tail->degree == 1) && (lengthArc(arc) < threshold))
+ else if (threshold_external > 0 && (arc->head->degree == 1 || arc->tail->degree == 1) && (lengthArc(arc) < threshold_external))
{
ReebNode *terminalNode = NULL;
ReebNode *middleNode = NULL;
@@ -1552,32 +1527,28 @@
int filterCyclesReebGraph(ReebGraph *rg, float distance_threshold)
{
+ ReebArc *arc1, *arc2;
+ ReebArc *next2;
int filtered = 0;
- if (BLI_isGraphCyclic((BGraph*)rg))
+ for (arc1 = rg->arcs.first; arc1; arc1 = arc1->next)
{
- ReebArc *arc1, *arc2;
- ReebArc *next2;
-
- for (arc1 = rg->arcs.first; arc1; arc1 = arc1->next)
+ for (arc2 = arc1->next; arc2; arc2 = next2)
{
- for (arc2 = rg->arcs.first; arc2; arc2 = next2)
+ next2 = arc2->next;
+ if (arc1 != arc2 && arc1->head == arc2->head && arc1->tail == arc2->tail)
{
- next2 = arc2->next;
- if (arc1 != arc2 && arc1->head == arc2->head && arc1->tail == arc2->tail)
- {
- mergeArcEdges(rg, arc1, arc2, MERGE_APPEND);
- mergeArcFaces(rg, arc1, arc2);
- mergeArcBuckets(arc1, arc2, arc1->head->weight, arc1->tail->weight);
+ mergeArcEdges(rg, arc1, arc2, MERGE_APPEND);
+ mergeArcFaces(rg, arc1, arc2);
+ mergeArcBuckets(arc1, arc2, arc1->head->weight, arc1->tail->weight);
- NodeDegreeDecrement(rg, arc1->head);
- NodeDegreeDecrement(rg, arc1->tail);
+ NodeDegreeDecrement(rg, arc1->head);
+ NodeDegreeDecrement(rg, arc1->tail);
- BLI_remlink(&rg->arcs, arc2);
- REEB_freeArc((BArc*)arc2);
-
- filtered = 1;
- }
+ BLI_remlink(&rg->arcs, arc2);
+ REEB_freeArc((BArc*)arc2);
+
+ filtered = 1;
}
}
}
@@ -1765,22 +1736,24 @@
verifyNodeDegree(rg);
- /* filter until there's nothing more to do */
- while (done == 1)
+ if ((options & SKGEN_FILTER_EXTERNAL) == 0)
{
- done = 0; /* no work done yet */
-
- if (options & SKGEN_FILTER_INTERNAL)
- {
-// done |= filterInternalReebGraph(rg, threshold_internal * rg->resolution);
- done |= filterInternalReebGraph(rg, threshold_internal);
- verifyNodeDegree(rg);
- }
+ threshold_external = 0;
+ }
- if (options & SKGEN_FILTER_EXTERNAL)
+ if ((options & SKGEN_FILTER_INTERNAL) == 0)
+ {
+ threshold_internal = 0;
+ }
+
+ if (threshold_internal > 0 || threshold_external > 0)
+ {
+ /* filter until there's nothing more to do */
+ while (done == 1)
{
-// done |= filterExternalReebGraph(rg, threshold_external * rg->resolution);
- done |= filterExternalReebGraph(rg, threshold_external);
+ done = 0; /* no work done yet */
+
+ done = filterInternalExternalReebGraph(rg, threshold_internal, threshold_external);
verifyNodeDegree(rg);
}
}
@@ -1788,7 +1761,6 @@
if (options & SKGEN_FILTER_SMART)
{
filterSmartReebGraph(rg, 0.5);
@@ Diff output truncated at 10240 characters. @@
More information about the Bf-blender-cvs
mailing list