EdgeMap and NodeMap creation is done, at last. Bach 4ever. gui
authorhegyi
Tue, 26 Jul 2005 21:19:41 +0000
branchgui
changeset 4106f1f9a8d51f
parent 40 cebacea4f965
child 42 f1b70894b953
EdgeMap and NodeMap creation is done, at last. Bach 4ever.
Makefile.am
graph_displayer_canvas-event.cc
graph_displayer_canvas.cc
graph_displayer_canvas.h
main_win.cc
main_win.h
map_win.cc
     1.1 --- a/Makefile.am	Tue Jul 26 18:14:23 2005 +0000
     1.2 +++ b/Makefile.am	Tue Jul 26 21:19:41 2005 +0000
     1.3 @@ -21,8 +21,9 @@
     1.4  	edit_win.cc \
     1.5  	edit_win.h \
     1.6  	broken_edge.cc \
     1.7 -	broken_edge.h
     1.8 -
     1.9 +	broken_edge.h \
    1.10 +	new_map_win.cc \
    1.11 +	new_map_win.h
    1.12  
    1.13  gd_CXXFLAGS = $(GTK_CFLAGS)
    1.14  gd_LDFLAGS = $(GTK_LIBS)
     2.1 --- a/graph_displayer_canvas-event.cc	Tue Jul 26 18:14:23 2005 +0000
     2.2 +++ b/graph_displayer_canvas-event.cc	Tue Jul 26 21:19:41 2005 +0000
     2.3 @@ -670,57 +670,78 @@
     2.4  	    case GDK_KP_Enter:
     2.5  	    case GDK_Return:
     2.6  	      {
     2.7 -		Glib::ustring mapvalue = entrywidget.get_text();
     2.8 +		bool valid_double=true;
     2.9 +		int point_num=0;
    2.10 +		Glib::ustring mapvalue_str = entrywidget.get_text();
    2.11  
    2.12 -		double double_map_fract_value=0;
    2.13 -		double double_map_value=0;
    2.14 -		int offset=0;
    2.15 -		int found_letter=0;
    2.16 -		//converting text to double
    2.17 -		for(int i=0;i<(int)(mapvalue.length());i++)
    2.18 +		char * mapvalue_ch=new char [mapvalue_str.length()];
    2.19 +		for(int i=0;i<(int)(mapvalue_str.length());i++)
    2.20  		  {
    2.21 -		    if(((mapvalue[i]<='9')&&(mapvalue[i]>='0'))||(mapvalue[i]=='.'))
    2.22 +		    if(((mapvalue_str[i]<'0')||(mapvalue_str[i]>'9'))&&(mapvalue_str[i]!='.'))
    2.23  		      {
    2.24 -			if(mapvalue[i]=='.')
    2.25 -			  {
    2.26 -			    //for calculating non-integer part of double we step backward from the end
    2.27 -			    //after each step the number will be divided by ten, and the new value will be added
    2.28 -			    //to step backward from the end until the point the actual character of the string is the following:
    2.29 -			    // mapvalue.length()-(i-position_of_point)
    2.30 -			    //if i was the number of the first character after the decimal point the selected character will be the last
    2.31 -			    //if i was the number of the last character, the selected character will be the first after the decimal point
    2.32 -			    offset=mapvalue.length()+i;
    2.33 -			  }
    2.34 -			else
    2.35 -			  {
    2.36 -			    if(!offset)
    2.37 -			      {
    2.38 -				double_map_value=10*double_map_value+mapvalue[i]-'0';
    2.39 -			      }
    2.40 -			    else
    2.41 -			      {
    2.42 -				double_map_fract_value=double_map_fract_value/10+(double)(mapvalue[offset-i]-'0')/10;
    2.43 -			      }
    2.44 -			  }
    2.45 +			valid_double=false;
    2.46  		      }
    2.47  		    else
    2.48  		      {
    2.49 -			found_letter++;
    2.50 -			continue;
    2.51 +			if(mapvalue_str[i]=='.')
    2.52 +			  {
    2.53 +			    point_num++;
    2.54 +			  }
    2.55  		      }
    2.56 +		    mapvalue_ch[i]=mapvalue_str[i];
    2.57  		  }
    2.58 +  
    2.59 +		double mapvalue_d=atof(mapvalue_ch);
    2.60  
    2.61 -		if(!found_letter)
    2.62 +// 		double double_map_fract_value=0;
    2.63 +// 		double double_map_value=0;
    2.64 +// 		int offset=0;
    2.65 +// 		int found_letter=0;
    2.66 +		//converting text to double
    2.67 +// 		for(int i=0;i<(int)(mapvalue.length());i++)
    2.68 +// 		  {
    2.69 +// 		    if(((mapvalue[i]<='9')&&(mapvalue[i]>='0'))||(mapvalue[i]=='.'))
    2.70 +// 		      {
    2.71 +// 			if(mapvalue[i]=='.')
    2.72 +// 			  {
    2.73 +// 			    //for calculating non-integer part of double we step backward from the end
    2.74 +// 			    //after each step the number will be divided by ten, and the new value will be added
    2.75 +// 			    //to step backward from the end until the point the actual character of the string is the following:
    2.76 +// 			    // mapvalue.length()-(i-position_of_point)
    2.77 +// 			    //if i was the number of the first character after the decimal point the selected character will be the last
    2.78 +// 			    //if i was the number of the last character, the selected character will be the first after the decimal point
    2.79 +// 			    offset=mapvalue.length()+i;
    2.80 +// 			  }
    2.81 +// 			else
    2.82 +// 			  {
    2.83 +// 			    if(!offset)
    2.84 +// 			      {
    2.85 +// 				double_map_value=10*double_map_value+mapvalue[i]-'0';
    2.86 +// 			      }
    2.87 +// 			    else
    2.88 +// 			      {
    2.89 +// 				double_map_fract_value=double_map_fract_value/10+(double)(mapvalue[offset-i]-'0')/10;
    2.90 +// 			      }
    2.91 +// 			  }
    2.92 +// 		      }
    2.93 +// 		    else
    2.94 +// 		      {
    2.95 +// 			found_letter++;
    2.96 +// 			continue;
    2.97 +// 		      }
    2.98 +// 		  }
    2.99 +
   2.100 +		if((point_num<=1)&&(valid_double))
   2.101  		  {
   2.102  		    switch(actual_tool)
   2.103  		      {
   2.104  		      case EDGE_MAP_EDIT:
   2.105 -			edgetextmap[active_edge]->property_text().set_value(mapvalue);
   2.106 -			(*(mapstorage.edgemap_storage)[edgemap_to_edit])[active_edge]=double_map_value+double_map_fract_value;
   2.107 +			edgetextmap[active_edge]->property_text().set_value(mapvalue_str);
   2.108 +			(*(mapstorage.edgemap_storage)[edgemap_to_edit])[active_edge]=mapvalue_d;
   2.109  			break;
   2.110  		      case NODE_MAP_EDIT:
   2.111 -			nodetextmap[active_node]->property_text().set_value(mapvalue);
   2.112 -			(*(mapstorage.nodemap_storage)[nodemap_to_edit])[active_node]=double_map_value+double_map_fract_value;
   2.113 +			nodetextmap[active_node]->property_text().set_value(mapvalue_str);
   2.114 +			(*(mapstorage.nodemap_storage)[nodemap_to_edit])[active_node]=mapvalue_d;
   2.115  			break;
   2.116  		      default:
   2.117  			break;
   2.118 @@ -803,16 +824,19 @@
   2.119  
   2.120  }
   2.121  
   2.122 -void GraphDisplayerCanvas::addNewEdgeMap()
   2.123 +void GraphDisplayerCanvas::addNewEdgeMap(double default_value, std::string mapname)
   2.124  {
   2.125 -  Graph::EdgeMap<double> * emptr=new Graph::EdgeMap<double> (g,20);
   2.126 -  mapstorage.addEdgeMap("NewEdgeMap",emptr);
   2.127 -  mapwin->registerNewEdgeMap("NewEdgeMap");
   2.128 -  changeEdgeText("NewEdgeMap");
   2.129 +  Graph::EdgeMap<double> * emptr=new Graph::EdgeMap<double> (g,default_value);
   2.130 +  mapstorage.addEdgeMap(mapname,emptr);
   2.131 +  mapwin->registerNewEdgeMap(mapname);
   2.132 +  changeEdgeText(mapname);
   2.133  }
   2.134  
   2.135 -void GraphDisplayerCanvas::addNewNodeMap()
   2.136 +void GraphDisplayerCanvas::addNewNodeMap(double default_value, std::string mapname)
   2.137  {
   2.138 -  std::cout << "Add New NodeMap is not yet implemented." << std::endl;
   2.139 +  Graph::NodeMap<double> * emptr=new Graph::NodeMap<double> (g,default_value);
   2.140 +  mapstorage.addNodeMap(mapname,emptr);
   2.141 +  mapwin->registerNewNodeMap(mapname);
   2.142 +  changeNodeText(mapname);
   2.143  }
   2.144  
     3.1 --- a/graph_displayer_canvas.cc	Tue Jul 26 18:14:23 2005 +0000
     3.2 +++ b/graph_displayer_canvas.cc	Tue Jul 26 21:19:41 2005 +0000
     3.3 @@ -5,7 +5,7 @@
     3.4  GraphDisplayerCanvas::GraphDisplayerCanvas(Graph & gr, CoordinatesMap & cm, MapStorage & ms, MapWin * mw):g(gr),nodesmap(g),edgesmap(g),edgetextmap(g),nodetextmap(g),displayed_graph(*(root()), 0, 0),canvasentrywidget(NULL),mapstorage(ms),isbutton(0),active_item(NULL),target_item(NULL),nodemap_to_edit(""),edgemap_to_edit(""),mapwin(mw)
     3.5  {
     3.6    
     3.7 -  
     3.8 +  //Initializing values.
     3.9    active_node=INVALID;
    3.10    active_edge=INVALID;
    3.11    forming_edge=INVALID;
     4.1 --- a/graph_displayer_canvas.h	Tue Jul 26 18:14:23 2005 +0000
     4.2 +++ b/graph_displayer_canvas.h	Tue Jul 26 21:19:41 2005 +0000
     4.3 @@ -110,9 +110,9 @@
     4.4    int getActualTool();
     4.5  
     4.6    ///creates a new Nodemap
     4.7 -  void addNewNodeMap();
     4.8 +  void addNewNodeMap(double,std::string);
     4.9    ///creates a new Edgemap
    4.10 -  void addNewEdgeMap();
    4.11 +  void addNewEdgeMap(double,std::string);
    4.12  
    4.13  private:
    4.14    ///Deletes the given element.
     5.1 --- a/main_win.cc	Tue Jul 26 18:14:23 2005 +0000
     5.2 +++ b/main_win.cc	Tue Jul 26 21:19:41 2005 +0000
     5.3 @@ -1,8 +1,12 @@
     5.4  #include <main_win.h>
     5.5  
     5.6  MainWin::MainWin(const std::string& title, Graph & graph, CoordinatesMap & cm,
     5.7 -    MapStorage & ms):mapwin("Map Setup", ms, gd_canvas),editwin("Editorial Window", gd_canvas),gd_canvas(graph, cm, ms, &mapwin)
     5.8 +    MapStorage & ms):mapwin("Map Setup", ms, gd_canvas),editwin("Editorial Window", gd_canvas),newmapwin("Creating new map",gd_canvas),gd_canvas(graph, cm, ms, &mapwin)
     5.9  {
    5.10 +  //Creating a window for setting new maps.
    5.11 +//   newmapwin=new NewMapWi("Creating new map",*this);
    5.12 +
    5.13 +
    5.14    set_title (title);
    5.15    set_default_size(WIN_WIDTH,WIN_HEIGHT);
    5.16    add(vbox);
    5.17 @@ -49,10 +53,8 @@
    5.18        sigc::bind( sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::changeEditorialTool ), 4) );
    5.19    ag->add( Gtk::Action::create("EditNodeMap", Gtk::Stock::PREFERENCES),
    5.20        sigc::bind( sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::changeEditorialTool ), 5) );
    5.21 -  ag->add( Gtk::Action::create("AddEdgeMap", Gtk::Stock::NEW),
    5.22 -      sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::addNewEdgeMap ) );
    5.23 -  ag->add( Gtk::Action::create("AddNodeMap", Gtk::Stock::NEW),
    5.24 -      sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::addNewNodeMap ) );
    5.25 +  ag->add( Gtk::Action::create("AddMap", Gtk::Stock::NEW),
    5.26 +      sigc::mem_fun ( this->newmapwin, &NewMapWin::show ) );
    5.27  
    5.28    uim=Gtk::UIManager::create();
    5.29    uim->insert_action_group(ag);
    5.30 @@ -98,8 +100,7 @@
    5.31        "    <toolitem action='MoveItem' />"
    5.32        "    <toolitem action='EditEdgeMap' />"
    5.33        "    <toolitem action='EditNodeMap' />"
    5.34 -      "    <toolitem action='AddEdgeMap' />"
    5.35 -      "    <toolitem action='AddNodeMap' />"
    5.36 +      "    <toolitem action='AddMap' />"
    5.37        "  </toolbar>"
    5.38        "</ui>";
    5.39  
     6.1 --- a/main_win.h	Tue Jul 26 18:14:23 2005 +0000
     6.2 +++ b/main_win.h	Tue Jul 26 21:19:41 2005 +0000
     6.3 @@ -6,6 +6,7 @@
     6.4  #include <all_include.h>
     6.5  #include <mapstorage.h>
     6.6  #include <map_win.h>
     6.7 +#include <new_map_win.h>
     6.8  #include <edit_win.h>
     6.9  #include <libgnomecanvasmm.h>
    6.10  #include <libgnomecanvasmm/polygon.h>
    6.11 @@ -29,6 +30,9 @@
    6.12    ///Window of editorial tools. Its type is \ref EditWin
    6.13    EditWin editwin;
    6.14  
    6.15 +  ///We need to store newmapwin, to be able to set the appropriate values for properties of new map.
    6.16 +  NewMapWin newmapwin;
    6.17 +
    6.18    ///The graph will be drawn on this \ref GraphDisplayerCanvas
    6.19    GraphDisplayerCanvas gd_canvas;
    6.20  
     7.1 --- a/map_win.cc	Tue Jul 26 18:14:23 2005 +0000
     7.2 +++ b/map_win.cc	Tue Jul 26 21:19:41 2005 +0000
     7.3 @@ -265,11 +265,13 @@
     7.4  
     7.5  void MapWin::registerNewNodeMap(std::string newmapname)
     7.6  {
     7.7 -  for(int i=0;i<EDGE_PROPERTY_NUM;i++)
     7.8 +  for(int i=0;i<NODE_PROPERTY_NUM;i++)
     7.9    {
    7.10      //filling in combo box with choices
    7.11      std::list<Glib::ustring> listStrings=n_combo_array[i].get_popdown_strings();
    7.12      listStrings.push_back(newmapname);
    7.13      n_combo_array[i].set_popdown_strings(listStrings);
    7.14    }
    7.15 +  Gtk::Entry* entry = n_combo_array[N_TEXT].get_entry();
    7.16 +  entry->set_text((Glib::ustring)newmapname);
    7.17  }