COIN-OR::LEMON - Graph Library

Changeset 1884:9c061834b33b in lemon-0.x


Ignore:
Timestamp:
01/06/06 17:07:08 (19 years ago)
Author:
Hegyi Péter
Branch:
default
Phase:
public
Convert:
svn:c9d7d8f5-90d6-0310-b91f-818b3a526b0e/lemon/trunk@2459
Message:

In algorithm window maps can be selected and reated through MapSelector? widget.

Location:
gui
Files:
10 edited

Legend:

Unmodified
Added
Removed
  • gui/algobox.cc

    r1879 r1884  
    7474  for(int i=0;i<(int)nodemapcbts.size();i++)
    7575    {
    76       update_cbt(nml, *(nodemapcbts[i]));
     76      (nodemapcbts[i])->update_list(nml);
     77      //update_cbt(nml, *(nodemapcbts[i]));
    7778    }
    7879  for(int i=0;i<(int)edgemapcbts.size();i++)
    7980    {
    80       update_cbt(eml, *(edgemapcbts[i]));
     81      (edgemapcbts[i])->update_list(eml);
     82      //update_cbt(eml, *(edgemapcbts[i]));
    8183    }
    8284}
     
    107109  pack_start(*(new Gtk::HSeparator()));
    108110
    109   label=new Gtk::Label("Specific part for each algorithm.");
     111  Gtk::Label * label=new Gtk::Label("Specific part for each algorithm.");
    110112     
    111113  pack_start(*label);
     
    119121  for(int i=0;i<(int)nodemapcbts.size();i++)
    120122    {
    121       Gtk::HBox * hbox=new Gtk::HBox();
     123      std::vector<std::string> empty_vector;
    122124
    123125      std::ostringstream o;
    124126      o << "NodeInput " << i+1 << ":";
    125       label=new Gtk::Label(o.str());
    126127
    127       nodemapcbts[i]=new Gtk::ComboBoxText();
     128      nodemapcbts[i]=new MapSelector(empty_vector,"",o.str(),false, false);
     129      nodemapcbts[i]->signal_newmapwin_needed().connect(sigc::mem_fun(*this, &AlgoBox::emit_new_map_signal));
    128130
    129       hbox->pack_start(*label);
    130       hbox->pack_start(*(nodemapcbts[i]));
    131       pack_start(*hbox);
     131      pack_start(*(nodemapcbts[i]));
    132132    }
    133133
     
    137137  for(int i=0;i<(int)edgemapcbts.size();i++)
    138138    {
    139       Gtk::HBox * hbox=new Gtk::HBox();
     139      std::vector<std::string> empty_vector;
    140140
    141141      std::ostringstream o;
    142142      o << "EdgeInput " << i+1 << ":";
    143       label=new Gtk::Label(o.str());
    144143
    145       edgemapcbts[i]=new Gtk::ComboBoxText();
     144      edgemapcbts[i]=new MapSelector(empty_vector,"",o.str(),true, false);
     145      edgemapcbts[i]->signal_newmapwin_needed().connect(sigc::mem_fun(*this, &AlgoBox::emit_new_map_signal));
    146146
    147       hbox->pack_start(*label);
    148       hbox->pack_start(*(edgemapcbts[i]));
    149       pack_start(*hbox);
     147      pack_start(*(edgemapcbts[i]));
    150148    }
    151149
     
    171169    }
    172170}
     171
     172void AlgoBox::emit_new_map_signal(bool itisedge)
     173{
     174  signal_newmapwin_need.emit(tabcbt.get_active_text(), itisedge);
     175}
  • gui/algobox.h

    r1879 r1884  
    88#include <all_include.h>
    99#include <mapstorage.h>
     10#include <mapselector.h>
    1011#include <libgnomecanvasmm.h>
    1112#include <libgnomecanvasmm/polygon.h>
     
    1415{
    1516  sigc::signal<void, std::string> signal_maplist_need; 
    16  
    17   Gtk::ComboBoxText tabcbt;
     17  sigc::signal<void, std::string, bool> signal_newmapwin_need; 
    1818
    1919protected:
    20   Gtk::Label * label;
    21   std::vector<Gtk::ComboBoxText *> nodemapcbts;
    22   std::vector<Gtk::ComboBoxText *> edgemapcbts;
     20  Gtk::ComboBoxText tabcbt;
     21  std::vector<MapSelector *> nodemapcbts;
     22  std::vector<MapSelector *> edgemapcbts;
    2323
    2424  MapStorage * mapstorage;
     
    3131
    3232  sigc::signal<void, std::string> signal_maplist_needed(); 
     33  sigc::signal<void, std::string, bool> signal_newmapwin_needed(){return signal_newmapwin_need;}; 
    3334  void emit_tab_change();
    3435
     
    4445 
    4546  virtual void build_box();
     47
     48  virtual void emit_new_map_signal(bool);
    4649};
    4750#endif //ALGOBOX_H
  • gui/algowin.cc

    r1879 r1884  
    4444    }
    4545  ab->signal_maplist_needed().connect(sigc::mem_fun(*this, &AlgoWin::emit_tab_change));
     46  ab->signal_newmapwin_needed().connect(sigc::mem_fun(*this, &AlgoWin::emit_new_map_signal));
    4647
    4748  runbutton=new Gtk::Button("Run");
  • gui/algowin.h

    r1879 r1884  
    2626  sigc::signal<void, AlgoWin *> signal_closed; 
    2727  sigc::signal<void, AlgoWin *, std::string> signal_maplist_need; 
     28  sigc::signal<void, std::string, bool> signal_newmapwin_need; 
    2829
    2930public:
     
    3233  sigc::signal<void, AlgoWin *> signal_closing();
    3334  sigc::signal<void, AlgoWin *, std::string> signal_maplist_needed();
     35  sigc::signal<void, std::string, bool> signal_newmapwin_needed(){return signal_newmapwin_need;}; 
    3436
    3537  void emit_tab_change(std::string);
     38  void emit_new_map_signal(std::string tabname, bool itisedge){signal_newmapwin_need.emit(tabname, itisedge);};
    3639
    3740  AlgoWin(int, std::vector<std::string>);
  • gui/kruskalbox.cc

    r1881 r1884  
    1010void KruskalBox::run()
    1111{
    12   Graph g=mapstorage->graph;
    13   Graph::EdgeMap<double> * inputmap=
    14     ((mapstorage->edgemap_storage)[(edgemapcbts[INPUT])->get_active_text()]);
    15   Graph::EdgeMap<bool> outputmap(g);
    16   double res=kruskal(g, *inputmap, outputmap);
     12  if(
     13     tabcbt.get_active_text()!="" &&
     14     (edgemapcbts[INPUT])->get_active_text()!="" &&
     15     (edgemapcbts[OUTPUT])->get_active_text()!=""
     16     )
     17    {
    1718
    18   for (EdgeIt i(g); i!=INVALID; ++i)
    19   {
    20     if(outputmap[i])
    21       {
    22         (*((mapstorage->edgemap_storage)[(edgemapcbts[OUTPUT])->
    23                                          get_active_text()]))[i]=1;
    24       }
    25     else
    26       {
    27         (*((mapstorage->edgemap_storage)[(edgemapcbts[OUTPUT])->
    28                                          get_active_text()]))[i]=0;
    29       }
    30   }
     19      Graph g=mapstorage->graph;
     20      Graph::EdgeMap<double> * inputmap=
     21        ((mapstorage->edgemap_storage)[(edgemapcbts[INPUT])->get_active_text()]);
     22      Graph::EdgeMap<bool> outputmap(g);
     23      double res=kruskal(g, *inputmap, outputmap);
    3124
    32   std::ostringstream o;
    33   o << "Result: " << res;
    34   resultlabel.set_text(o.str());
     25      for (EdgeIt i(g); i!=INVALID; ++i)
     26        {
     27          if(outputmap[i])
     28            {
     29              (*((mapstorage->edgemap_storage)[(edgemapcbts[OUTPUT])->
     30                                               get_active_text()]))[i]=1;
     31            }
     32          else
     33            {
     34              (*((mapstorage->edgemap_storage)[(edgemapcbts[OUTPUT])->
     35                                               get_active_text()]))[i]=0;
     36            }
     37        }
    3538
    36   mapstorage->mapChanged(true, (edgemapcbts[OUTPUT])->get_active_text());
    37   //   mapstorage->changeActiveMap(true, E_COLOR,
    38   //                          (edgemapcbts[OUTPUT])->get_active_text());
    39   //   mapstorage->changeActiveMap(true, E_TEXT,
    40   //                          (edgemapcbts[INPUT])->get_active_text());
     39      std::ostringstream o;
     40      o << "Result: " << res;
     41      resultlabel.set_text(o.str());
     42
     43      mapstorage->mapChanged(true, (edgemapcbts[OUTPUT])->get_active_text());
     44      //   mapstorage->changeActiveMap(true, E_COLOR,
     45      //                              (edgemapcbts[OUTPUT])->get_active_text());
     46      //   mapstorage->changeActiveMap(true, E_TEXT,
     47      //                              (edgemapcbts[INPUT])->get_active_text());
    4148 
     49    }
    4250}
    4351   
    4452void KruskalBox::build_box()
    4553{
     54  std::vector<std::string> empty_vector;
     55
    4656  edgemapcbts.resize(MAP_NUM);
    47   Gtk::HBox * hbox;
    4857
    49   hbox=new Gtk::HBox();
     58  edgemapcbts[0]=new MapSelector(empty_vector,"","Edgecosts: ",true, false);
     59  edgemapcbts[0]->signal_newmapwin_needed().connect(sigc::mem_fun(*this, &AlgoBox::emit_new_map_signal));
    5060
    51   label=new Gtk::Label("Edgecosts: ");
     61  pack_start(*(edgemapcbts[INPUT]));
    5262
    53   edgemapcbts[0]=new Gtk::ComboBoxText();
     63  edgemapcbts[1]=new MapSelector(empty_vector,"","Edges of tree here: ",true, false);
     64  edgemapcbts[1]->signal_newmapwin_needed().connect(sigc::mem_fun(*this, &AlgoBox::emit_new_map_signal));
    5465
    55   hbox->pack_start(*label);
    56   hbox->pack_start(*(edgemapcbts[INPUT]));
    57   pack_start(*hbox);
    58 
    59   hbox=new Gtk::HBox();
    60 
    61   label=new Gtk::Label("Edges of tree here: ");
    62 
    63   edgemapcbts[1]=new Gtk::ComboBoxText();
    64 
    65   hbox->pack_start(*label);
    66   hbox->pack_start(*(edgemapcbts[OUTPUT]));
    67   pack_start(*hbox);
     66  pack_start(*(edgemapcbts[OUTPUT]));
    6867
    6968  resultlabel.set_text("Result: algorithm is not run yet.");
  • gui/main_win.cc

    r1878 r1884  
    413413  aw->signal_closing().connect(sigc::mem_fun(*this, &MainWin::deRegisterAlgoWin));
    414414  aw->signal_maplist_needed().connect(sigc::mem_fun(*this, &MainWin::updateAlgoWinMaps));
     415  aw->signal_newmapwin_needed().connect(sigc::mem_fun(*this, &MainWin::createNewMapWinTabString));
    415416  aws.insert(aw);
    416417  aw->show();
     
    457458      nmw->show();
    458459    }
     460}
     461
     462void MainWin::createNewMapWinTabString(std::string tabname, bool itisedge)
     463{
     464  int i=0;
     465  for(;((i<tabnames.size())&&(tabnames[i]!=tabname));i++)
     466    {
     467    }
     468  createNewMapWinAfterSignal(tabs[i], itisedge);
    459469}
    460470
  • gui/main_win.h

    r1876 r1884  
    8080
    8181  virtual void createNewMapWinAfterSignal(NoteBookTab *, bool);
     82  virtual void createNewMapWinTabString(std::string, bool);
    8283  virtual void createNewMapWin();
    8384
  • gui/map_win.cc

    r1849 r1884  
    2525  for(int i=0;i<EDGE_PROPERTY_NUM;i++)
    2626  {
    27     e_combo_array[i]=new MapSelector(eml, mytab.getActiveEdgeMap(i), i, true);
     27    e_combo_array[i]=new MapSelector(eml, mytab.getActiveEdgeMap(i), edge_property_strings[i], true);
    2828
    2929    (*table).attach((*(e_combo_array[i])),0,1,i,i+1,Gtk::SHRINK,Gtk::SHRINK,10,3);
     
    4545  for(int i=0;i<NODE_PROPERTY_NUM;i++)
    4646  {
    47     n_combo_array[i]=new MapSelector(nml, mytab.getActiveNodeMap(i), i, false);
     47    n_combo_array[i]=new MapSelector(nml, mytab.getActiveNodeMap(i), node_property_strings[i], false);
    4848
    4949    (*table).attach((*(n_combo_array[i])),0,1,i,i+1,Gtk::SHRINK,Gtk::SHRINK,10,3);
  • gui/mapselector.cc

    r1882 r1884  
    11#include "mapselector.h"
    22
    3 MapSelector::MapSelector(std::vector<std::string> ml, std::string act, int identifier, bool edge):id(identifier),itisedge(edge),set_new_map(false)
     3MapSelector::MapSelector(std::vector<std::string> ml, std::string act, std::string labeltext, bool edge, bool d):def(d),itisedge(edge),set_new_map(false)
    44{
    55  update_list(ml);
     
    2323     );
    2424 
    25   if(itisedge)
    26     {
    27       label=new Gtk::Label(edge_property_strings[id]);
    28     }
    29   else
    30     {
    31       label=new Gtk::Label(node_property_strings[id]);
    32     }
     25  label=new Gtk::Label(labeltext);
    3326
    3427  label->set_width_chars(longest_property_string_length);
     
    7265      cbt.append_text(*emsi);
    7366    }
    74   cbt.prepend_text("Default values");
     67  if(def)
     68    {
     69      cbt.prepend_text("Default values");
     70    }
    7571  if(prev_act!=-1)
    7672    {
  • gui/new_map_win.cc

    r1879 r1884  
    115115                          else
    116116                            {
    117                               char * def_val_ch=new char [(int)(ch2var[ polishform[i] ].length())];
    118                               for(int j=0;j<(int)(ch2var[ polishform[i] ].length());j++)
    119                                 {
    120                                   def_val_ch[j]=ch2var[ polishform[i] ][j];
    121                                 }
    122                               polishstack.push(atof(def_val_ch));
    123                               delete def_val_ch;
     117                              polishstack.push(atof(ch2var[ polishform[i] ].c_str()));
    124118                            }
    125119                          operation=false;
     
    202196                          else
    203197                            {
    204                               char * def_val_ch=new char [(int)(ch2var[ polishform[i] ].length())];
    205                               for(int j=0;j<(int)(ch2var[ polishform[i] ].length());j++)
    206                                 {
    207                                   def_val_ch[j]=ch2var[ polishform[i] ][j];
    208                                 }
    209                               polishstack.push(atof(def_val_ch));
    210                               delete def_val_ch;
     198                              polishstack.push(atof(ch2var[ polishform[i] ].c_str()));
    211199                            }
    212200                          operation=false;
Note: See TracChangeset for help on using the changeset viewer.