X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src2%2FcreaImageIOWxTreeView.cpp;h=bd640783e8a210ffec1bdbec9dfa76f3317fd5fe;hb=2f0e50f69eb904d629cf8db62eb9a4094db93097;hp=2a58cd393a9598dfb4af7b88fd5112efe2dd4e79;hpb=dd070f00561f17bc9ac754a7116516da5d41fbbd;p=creaImageIO.git diff --git a/src2/creaImageIOWxTreeView.cpp b/src2/creaImageIOWxTreeView.cpp index 2a58cd3..bd64078 100644 --- a/src2/creaImageIOWxTreeView.cpp +++ b/src2/creaImageIOWxTreeView.cpp @@ -1,7 +1,16 @@ #include #include #include - +int wxCALLBACK MyCompareFunction(long item1, long item2, long WXUNUSED(sortData)) +{ + // inverse the order + if (item1 < item2) + return -1; + if (item1 > item2) + return 1; + + return 0; +} namespace creaImageIO { //===================================================================== @@ -299,7 +308,7 @@ namespace creaImageIO //================================================================ - void WxTreeView::OnSelected(wxListEvent& event) + void WxTreeView::OnSelectedChanged(wxListEvent& event) { GimmickDebugMessage(1, GetTreeHandler()->GetTree().GetLabel() @@ -321,12 +330,335 @@ namespace creaImageIO " Level "< sel=GetSelected(level+1); + + tree::Node* nodes[20]; + + int l = level - 1; + + // to speed up inserting we hide the control temporarily + GetCtrl(level)->Hide(); + GetCtrl(level)->DeleteAllItems(); + + std::vector::iterator i; + int num=0; + for (i=sel.begin(); i!=sel.end(); ++i) + { + + //Adds columns + GetTreeHandler()->LoadChildren(*i,1); + tree::Node::ChildrenListType::reverse_iterator j; + + for (j = (*i)->GetChildrenList().rbegin(); + j!= (*i)->GetChildrenList().rend(); + ++j) + { + nodes[num]=*j; + num++; + } + } + + //Sorting elements + int k, m; + tree::Node* index; + + + for (k=1; kGetAttribute(mLevelList[level].key[colNum-1]) + <<"Comparison Key 2: "<<(index)->GetAttribute(mLevelList[level].key[colNum-1]) + < 0) && ((nodes[m-1])->GetAttribute(mLevelList[level].key[colNum-1]) > + (index)->GetAttribute(mLevelList[level].key[colNum-1]))) + { + nodes[m] = nodes[m-1]; + m = m - 1; + } + nodes[m] = index; + } + + for (m=0; mInsertItem(item); + int n; + if ((node)->GetChildrenLoaded()) + { + n=(node)->GetChildrenList().size(); + } + else + { + n= GetTreeHandler()->GetNumberOfChildren(node); + } + std::ostringstream oss; + + oss << n; + std::string s(oss.str()); + GetCtrl(level)->SetItem(id,0, crea::std2wx(s)); + GetCtrl(level)->SetColumnWidth(0, wxLIST_AUTOSIZE ); + + for (int k=1; kGetColumnCount(); k++) + { + std::string val = (node)->GetAttribute(mLevelList[level].key[k-1]); + if (val.size()==0) val = "?"; + GetCtrl(level)->SetItem(id,k, crea::std2wx(val)); + GetCtrl(level)->SetColumnWidth(k, wxLIST_AUTOSIZE ); + + } + + } + + GetCtrl(level)->Show(); +*/ + } + //================================================================ + + void WxTreeView::ValidateSelectedImages() + { + int level=mLevelList.size(); + std::vector sel=GetSelected(level+1); + if(sel.size()>0) + { + std::vector::iterator i; + bool valid=true; + std::string row; + std::string col; + std::string plane; + + //Validation between image sizes + for (i=sel.begin(); i!=sel.end() && valid; ++i) + { + if(i==sel.begin()) + { + row=(*i)->GetAttribute(mLevelList[level-1].key[1]); + col=(*i)->GetAttribute(mLevelList[level-1].key[2]); + plane=(*i)->GetAttribute(mLevelList[level-1].key[3]); + } + else + { + if(((*i)->GetAttribute(mLevelList[level-1].key[1]))!=row || + ((*i)->GetAttribute(mLevelList[level-1].key[2]))!=col || + ((*i)->GetAttribute(mLevelList[level-1].key[3]))!=plane) + { + valid=false; + } + } + } + + GimmickMessage(1, + "State check: Planes:" + <> rows; + if(row==""){rows=1;} + s=col; + t >> cols; + if(col==""){cols=1;} + s=plane; + t >> planes; + if(plane==""){planes=1;} + + int dim = 0; + if (planes>1) dim=3; + else if (cols>1) dim=2; + else if (rows>1) dim=1; + + if (dim == 0) + { + GimmickMessage(1, + "Unknown image dimension : cannot select !" + <GetMaxDimension()) + { + GimmickMessage(1,"Selecting "<ProcessEvent( event ); + } + + } + + //================================================================ + + + vtkImageData* WxTreeView::GetSelectedImage(int dim) + { + /* + wxArrayTreeItemIds id; + // TO DO : TEST THAT STYLE IS MULTIPLE + unsigned int nb = mTreeListCtrl->GetSelections(id); + f.clear(); + + // Collect the brute vector of Image nodes + std::vector im; + for (unsigned int i=0; iGetItemData(id[i]); + if ((data) && (data->IsDicomNode())) + { + if (data->GetDicomNode()->GetType()==DicomNode::Image) + { + im.push_back ( data->GetDicomNode() ); + + } + else if (data->GetDicomNode()->GetType()==DicomNode::Series) + { + DicomNode::ChildrenListType::iterator j; + for (j =data->GetDicomNode()->GetChildrenList().begin(); + j!=data->GetDicomNode()->GetChildrenList().end(); + j++) + { + im.push_back ( *j ); + } + } + } + } + // Create the output data + if (im.size()==1) + { + // Only one image : give it + vtkImageData* out = vtkImageData::New(); + out->ShallowCopy(mReader.GetImage(im.front()->ImageGetFullFileName())); + f.push_back( out ); + } + else if (im.size()>1) + { + vtkImageData* first = mReader.GetImage( im.front()->ImageGetFullFileName() ); + if (first->GetDataDimension()==2) + { + // n2D to 3D + vtkImageData* out = vtkImageData::New(); + out->CopyStructure(first); + out->SetScalarType(first->GetScalarType()); + int ext[6]; + first->GetExtent(ext); + ext[5] = im.size(); + out->SetExtent(ext); + // LG : TODO : Z Spacing ? + + out->AllocateScalars(); + + //first->Print(std::cout); + // out->Print(std::cout); + + int dim[3]; + first->GetDimensions(dim); + unsigned long imsize = + ( (unsigned long)first->GetScalarPointer(0,1,0) + - (unsigned long)first->GetScalarPointer(0,0,0)) + *dim[1]; + + int slice = 0; + std::vector::iterator it; + for (it=im.begin(); it!=im.end(); ++it) + { + //std::cout << "copying slice "<ImageGetFullFileName() ); + + void* src = cur->GetScalarPointer(0,0,0); + void* dst = out->GetScalarPointer(0,0,slice); + // std::cout << "src="<