-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathtagFileItem.cpp
executable file
·107 lines (80 loc) · 3 KB
/
tagFileItem.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#include "tagFileItem.h"
#include "tagPointItem.h"
tagFileItem::tagFileItem(SoSeparator *root,
const QVector<QVariant> &data,
ResourceForm *rf,
TreeItem *parent)
: TreeItem(data, rf, parent) {
// no property form yet
haveProps = false;
// the root separator from calling function onto which
// all new bits will be attached.
this->root = root;
//this->root=viewer->getRootSeparator();
//qDebug() << "Woohooo!" ;
// create all the necessary nodes
tagSeparator = new SoSeparator;
scale = new SoScale;
material = new SoMaterial;
pickStyle = new SoPickStyle;
// set the tags to be unpickable for the moment.
pickStyle->style = SoPickStyle::UNPICKABLE;
// // initialize some properties - make tags red for the moment
//material->diffuseColor.setValue(1.0, 0.0, 0.0);
// attach bits to the scenegraph.
tagSeparator->addChild(pickStyle);
tagSeparator->addChild(material);
tagSeparator->addChild(scale);
root->addChild(tagSeparator);
// inittagsize=0.05; //initialize to the initial value of the tagSize QWidget
}
tagFileItem::~tagFileItem() {
}
bool tagFileItem::loadFile(QFile &file, double tagsize, float r, float g, float b) {
int n_volumes, n_tag_points;
double *weights;
int *structure_ids;
int *patient_ids;
// set the name of this tree item
setData(0, QFileInfo(file).baseName());
if (input_tag_file((char *)file.fileName().toLatin1().data(),
&n_volumes,
&n_tag_points,
&tags1,
&tags2,
&weights,
&structure_ids,
&patient_ids,
&labels) != VIO_OK) {
return false;
}
// iterate over tags and create tagPointItems
for (int i=0; i < n_tag_points; i++) {
//Get the tag size and color from the ui
//double tagsize = 0.1;
// if ( (weights[0] > 0) && (weights[0] < 1.0))
// tagsize = weights[0];
tagPointItem *newTag = new tagPointItem(tagSeparator,
itemData,
form,
this, tagsize,/*0.0,255.0,255.0*/r,g,b);
newTag->setLocation(tags1[i][0],
tags1[i][1],
tags1[i][2]);
childItems.insert(childCount(), newTag);
}
return true;
}
bool tagFileItem::showTag(float *tagpoint, double tagsize, float r, float g, float b){
tagPointItem *newTag = new tagPointItem(tagSeparator,
itemData,
form,
this, tagsize,/*0.0,255.0,0.0*/r,g,b);
newTag->setLocation(tagpoint[0],
tagpoint[1],
tagpoint[2]);
/* newTagVect.append(newTag);
qDebug() <<"size of newTagVect in create tag: " << newTagVect.size() ;*/
// childItems.insert(childCount(), newTag);
return true;
}