const wxPoint& pos, const wxSize& size,
int min_dim,
int max_dim,
- int out_dim,
int number_of_threads)
: wxPanel(parent,id,pos,size),
- GimmickView(gimmick),
- mProgressDialog(0)
+ GimmickView(gimmick, number_of_threads),
+ mProgressDialog(0),
+ mConstructed(false)
{
GimmickDebugMessage(1,"WxGimmickView::WxGimmickView"
<<std::endl);
//Gimmick
mGimmick=gimmick;
+ mViewer=new WxViewer(this, wxID_ANY, wxT("Gimmick! Viewer"),wxDefaultPosition, wxDefaultSize );
- mSelectionMaxDimension=max_dim;
- mSelectionMinDimension=min_dim;
- mOutputDimension=out_dim;
+
+ mSelectionMaxDimension= max_dim;
+ mSelectionMinDimension= min_dim;
// Create the views
CreateTreeViews();
// Bottom panel
mBottomPanel = new wxPanel(mSplitter,-1);
-
+ mText = new wxStaticText(mBottomPanel, wxID_ANY, wxT("Status: Welcome to Gimmick!"));
+
// Splitting
int hsize = size.GetHeight();
- int bottom_minsize = 200;
+ int bottom_minsize = 15;
mSplitter->SetMinimumPaneSize( bottom_minsize );
mSplitter->SplitHorizontally( mNotebook, mBottomPanel,
SetSizer( sizer );
SetAutoLayout(true);
Layout();
-
+
+ mConstructed = true;
}
//======================================================================
GimmickMessage(2,"Creating the tree view for '"<<
name<<"'"<<std::endl);
// Create the WxTreeView
- WxTreeView* view = new WxTreeView(h,mNotebook,-1);
-
- view->SetMaxDimension(mSelectionMaxDimension);
- view->SetMinDimension(mSelectionMinDimension);
- view->SetOutputDimension(mOutputDimension);
+ WxTreeView* view = new WxTreeView(h,this,mNotebook,-1);
// TO DO : TEST THAT A VIEW WITH SAME NAME IS NOT
// ALREADY IN THE MAP
}
//======================================================================
- /// Returns the selected Images so that they comply with the given parameter(<4D)
+ /// Returns the selected Image so that it complies with the given parameter(<4D)
vtkImageData* WxGimmickView::GetSelectedImage(int dim)
{
return NULL;
+ //GetTreeViewMap()["Local database"]->GetSelectedImage(dim);
}
//======================================================================
/// Returns the selected Images so that they comply with the given parameter(4D)
void WxGimmickView::GetSelectedImages(std::vector<vtkImageData*>& s, int dim)
{
-
- //GetTreeViewMap()["Local database"]->GetImageData()
- //return NULL ;
-
+ int level=GetTreeViewMap()["Local database"]->GetNumberOfLevels();
+ std::vector<tree::Node*> im=GetTreeViewMap()["Local database"]->GetSelected(level+1);
+ ReadImagesNotThreaded(s,im,dim);
+ }
+ //======================================================================
+ /// Returns the selected Images so that they comply with the given parameter(4D)
+ void WxGimmickView::GetSelectedFiles(std::vector<std::string>& s)
+ {
+ GetTreeViewMap()["Local database"]->GetSelectedAsString(s);
}
-
//=================================================
void WxGimmickView::CreateIconList()
{
}
//=================================================
- //=================================================
+ //=================================================
+ void WxGimmickView::OnSelectionChange(std::vector<tree::Node*>& sel)
+ {
+ GimmickDebugMessage(5,
+ "WxGimmickView::OnSelectionChange"
+ <<std::endl);
+ wxBusyCursor busy;
+ bool valid = ValidateSelected(sel,
+ mSelectionMinDimension,
+ mSelectionMaxDimension );
+ mText->SetLabel(_T("Status: ")+crea::std2wx(GetMessage()));
+ if(valid)
+ {
+ ReadImageThreaded(sel);
+ }
+ else
+ {
+ mViewer->Hide();
+ }
+
+
+ }
+
+ //==================================================
+
+ //==================================================
+ ///Reads Images (Threaded)
+ void WxGimmickView::ReadImageThreaded(std::vector<tree::Node*> sel)
+ {
+ GimmickDebugMessage(5,
+ "ReadImageThreaded"
+ <<std::endl);
+ int maxprio = GetMaximalPriority();
+ int prio = maxprio + 2000;
+
+ //First load the selected images
+ mCurImageItemToShow = sel.front();
+ std::vector<tree::Node*>::iterator selected;
+ for(selected=sel.begin();selected!=sel.end();++selected)
+ {
+ GimmickDebugMessage(5,
+ "Requesting image from selected "
+ <<(*selected)->GetAttribute("FullFileName")
+ <<std::endl);
+ RequestReading(*selected,prio);
+ AddEntryToMap(*selected);
+ prio--;
+ }
+
+ //Going up
+ prio = maxprio + 1000;
+ std::vector<tree::Node*> up;
+ GetTreeViewMap()["Local database"]->GetNodes(up,true);
+ std::vector<tree::Node*>::iterator iterUp;
+ for(iterUp=up.begin();iterUp!=up.end();++iterUp)
+ {
+ GimmickDebugMessage(5,
+ "Requesting image from neighbors up "
+ <<(*iterUp)->GetAttribute("FullFileName")
+ <<std::endl);
+ RequestReading(*iterUp,prio);
+ AddEntryToMap(*iterUp);
+ prio--;
+ }
+
+ //Going down
+ prio = maxprio + 999;
+ std::vector<tree::Node*> down;
+ GetTreeViewMap()["Local database"]->GetNodes(down,false);
+ std::vector<tree::Node*>::iterator iterDown;
+ for(iterDown=down.begin();iterDown!=down.end();++iterDown)
+ {
+ GimmickDebugMessage(5,
+ "Requesting image from neighbors down "
+ <<(*iterDown)->GetAttribute("FullFileName")
+ <<std::endl);
+ RequestReading(*iterDown,prio);
+ AddEntryToMap(*iterDown);
+ prio--;
+ }
+ }
+
+ //==================================================
+
+ //==================================================
+ /// Processes the queue of image events
+ void WxGimmickView::ProcessImageEvents()
+ {
+ if (!mConstructed) return;
+
+ int level=GetTreeViewMap()["Local database"]->GetNumberOfLevels();
+ std::vector<tree::Node*> sel=GetTreeViewMap()["Local database"]->GetSelected(level+1);
+ GimmickDebugMessage(5,
+ "Processing Images. Lock Started"
+ <<std::endl);
+ MultiThreadImageReaderEventLock();
+
+ mViewer->ClearImages();
+ while (!IsQueueEmpty())
+ {
+ GimmickDebugMessage(5,
+ "Queue not empty"
+ <<std::endl);
+
+ vtkImageData* image=GetNextImageQueued();
+ if( image!=0 )
+ {
+ tree::Node* node=GetNextNodeQueued();
+
+ bool found=false;
+ std::vector<tree::Node*>::iterator i;
+ for(i=sel.begin();i!=sel.end()&&!found;++i)
+ {
+ if((*i)==node)
+ {
+ mViewer->AddImage(image);
+ found=true;
+ }
+ }
+ }
+ UnqueueNext();
+ }
+ if(!(mViewer->ImagesEmpty()))
+ {
+ GimmickDebugMessage(5,
+ "Showing images"
+ <<std::endl);
+ mViewer->ShowImages();
+ mViewer->Show();
+ }
+ ClearQueue();
+
+
+ MultiThreadImageReaderEventUnlock();
+ GimmickDebugMessage(5,
+ "Processing Images. Lock Ended"
+ <<std::endl);
+ }
+
+ //==================================================
+
+ //==================================================
+ void WxGimmickView::OnInternalIdle()
+ {
+ ProcessImageEvents();
+ }
+
+ //=================================================
+
+ //=================================================
void WxGimmickView::OnRemove(wxCommandEvent& event)
{
//TODO Select current tree handler
*/
wxMessageBox(std2wx(mess.str()),_T("Addition result"),wxOK,this);
}
+
//=================================================
//=================================================
EVT_TOOL(TOOL_ADDFILES_ID, WxGimmickView::OnAddFiles)
EVT_TOOL(TOOL_ADDDIR_ID, WxGimmickView::OnAddDir)
EVT_TOOL(TOOL_REMOVE_ID, WxGimmickView::OnRemove)
- END_EVENT_TABLE()
+ END_EVENT_TABLE()
//=================================================
} // EO namespace creaImageIO