#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 { //===================================================================== // CTor WxTreeView::WxTreeView(TreeHandler* handler, wxWindow* parent, const wxWindowID id) : wxPanel(parent,id), TreeView(handler) { GimmickDebugMessage(1,"WxTreeView::WxTreeView" < 0 (not for Root level) for (int i = 1; i < handler->GetTree().GetNumberOfLevels(); ++i) { GimmickDebugMessage(5,"Creating view for level "<1) sparent = mLevelList[i-2].wxSplitter; level.wxSplitter = new wxSplitterWindow( sparent , -1); // level.wxSplitter->SetMinimumPaneSize(100); wxListCtrl* ctrl = new wxListCtrl(level.wxSplitter, i, wxDefaultPosition, wxDefaultSize, ctrl_style); level.wxCtrl = ctrl; level.wxSplitter->Initialize(ctrl); // Create the columns : one for each attribute of the level int col = 0; //ctrl->InsertItem(0, "1"); tree::LevelDescriptor::AttributeDescriptorListType::const_iterator a; for (a = handler->GetTree().GetAttributeDescriptorList(i).begin(); a != handler->GetTree().GetAttributeDescriptorList(i).end(); ++a) { if(col==0) { wxListItem it; it.SetTextColour(*wxRED); it.SetText(_T("#C")); it.SetColumn(col); // ctrl->InsertColumn(col, _("Children"), col_style); ctrl->InsertColumn(col,it); //ctrl->InsertItem(0, "1"); //level.key.push_back(_("Children")); //level.key.push_back(handler->GetTree().GetChildrenList().size()); col++; } GimmickDebugMessage(5,"Creating column "<GetName() <InsertColumn(col, crea::std2wx(a->GetName()), col_style); level.key.push_back(a->GetKey()); // ctrl->SetColumnWidth(col, wxLIST_AUTOSIZE ); col++; } mLevelList.push_back(level); } /// Initialize the first level splitter sizer->Add( mLevelList[0].wxSplitter ,1, wxGROW ,0); UpdateLevel(1); SetSizer( sizer ); SetAutoLayout(true); Layout(); } //===================================================================== //===================================================================== /// Destructor WxTreeView::~WxTreeView() { GimmickDebugMessage(1,"WxTreeView::~WxTreeView" < WxTreeView::GetSelected(int level) { int l = level - 1; // the selection of upper level std::vector sel; if (level == 1) { sel.push_back(GetTreeHandler()->GetTree().GetTree()); } else { int n = GetCtrl(l-1)->GetItemCount(); for (int i = 0; i < n; i++) { if ( GetCtrl(l-1)->GetItemState(i,wxLIST_STATE_SELECTED)) { long adr = GetCtrl(l-1)->GetItemData(i); tree::Node* n = ((ItemData*)adr)->node; sel.push_back(n); } } } return sel; } //===================================================================== ///Removes selected nodes on given level void WxTreeView::RemoveSelected( int level ) { std::vector sel=GetSelected(level+1); bool erase=false; if (wxMessageBox(_T("Delete file(s) ?"), _T("Remove Files"), wxYES_NO,this ) == wxYES) { erase = true; } if(erase) { std::vector::iterator i; for (i=sel.begin(); i!=sel.end(); ++i) { GimmickDebugMessage(2, "deleting '" <<(*i)->GetLabel() <<"'"<Remove(*i); } UpdateLevel(level); } } //===================================================================== //===================================================================== /// void WxTreeView::UpdateLevel( int level ) { GimmickDebugMessage(1, GetTreeHandler()->GetTree().GetLabel() <<" view : updating level "<IsSplit()) GetSplitter(i)->SplitVertically( GetCtrl(i), GetSplitter(i+1), 100 ); } if (GetSplitter(i)->IsSplit()) GetSplitter(i)->Unsplit(); } //===================================================================== /// void WxTreeView::RecursiveUpdateLevel( int level ) { GimmickDebugMessage(2, GetTreeHandler()->GetTree().GetLabel() <<" view : updating level (recursive)"< sel=GetSelected(level); int l = level - 1; // to speed up inserting we hide the control temporarily GetCtrl(l)->Hide(); GetCtrl(l)->DeleteAllItems(); std::vector::iterator i; for (i=sel.begin(); i!=sel.end(); ++i) { GimmickDebugMessage(2, "adding children of '" <<(*i)->GetLabel() <<"'"<LoadChildren(*i,1); tree::Node::ChildrenListType::reverse_iterator j; for (j = (*i)->GetChildrenList().rbegin(); j!= (*i)->GetChildrenList().rend(); ++j) { wxListItem item; item.SetMask(wxLIST_MASK_STATE | wxLIST_MASK_TEXT | // wxLIST_MASK_IMAGE | wxLIST_MASK_DATA | // wxLIST_MASK_WIDTH | wxLIST_MASK_FORMAT ); ItemData* data = new ItemData; data->node = *j; item.SetData(data); long id = GetCtrl(l)->InsertItem(item); std::ostringstream oss; int n= GetTreeHandler()->GetNumberOfChildren(*j); oss << n; std::string s(oss.str()); item.SetText( crea::std2wx(s)); // item.SetTextColour(*wxRED); // item.SetBackgroundColour(*wxBLACK); item.SetColumn(0); GetCtrl(l)->SetItem(item); // GetCtrl(l)->SetItem(id,0, crea::std2wx(s)); // GetCtrl(l)->SetColumnWidth(0, wxLIST_AUTOSIZE ); for (int k=1; kGetColumnCount(); k++) { std::string val = (*j)->GetAttribute(mLevelList[l].key[k-1]); if (val.size()==0) val = "?"; item.SetText( crea::std2wx(val)); // item.SetTextColour(*wxBLACK); // item.SetBackgroundColour(*wxWHITE); item.SetColumn(k); GetCtrl(l)->SetItem(item); // GetCtrl(l)->SetItem(id,k, crea::std2wx(val)); // GetCtrl(l)->SetColumnWidth(k, wxLIST_AUTOSIZE ); } } } GetCtrl(l)->Show(); if (levelGetTree().GetLabel() <<" view : item selected " < 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); bool valid=true; std::string mess; if(sel.size()>0) { std::vector::iterator i; 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) { mess="The selected images are not compatible."; valid=false; } } } //Dimention validation //Compatibility with maximum if(valid) { int rows; int cols; int planes; std::string s; std::istringstream t(s); s=row; t >> 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) { mess="Unknown image dimension : cannot select !"; valid= false; } else if (dim>GetMaxDimension()) { mess="Selecting "; mess+=dim; mess+="D images is not allowed !"; valid= false; } if ( dim == GetMaxDimension() ) { mess="Cannot add this image to selection : would result in a "; mess+=(dim+1); mess+="D image!"; valid= false; } if ( dim < GetMinDimension() && sel.size()<2 ) { mess="Cannot build the selection as it would result in a "; mess+=dim; mess+="D image, and the minimum is "; mess+=GetMinDimension(); mess+="D!"; valid= false; } } } else { mess="Cannot have 0 images selected"; GimmickMessage(1,"Cannot have 0 images selected"<< std::endl); valid=false; } //Send an event telling wether the selection is valid or not wxCommandEvent event( 0, GetId() ); event.SetEventObject( this ); if(valid) { mess="Selection OK !"; event.SetInt(0); } else {event.SetInt(1);} event.SetString(crea::std2wx(mess)); GetEventHandler()->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="<