# HG changeset patch # User hegyi # Date 1133292718 0 # Node ID adfdc2f7054895c3b381dd9ad99a68a7eb44e9bf # Parent 56eb90299693297a1fe02c175d7746635ebc4ef2 Structure of GUI is now more clear-cut than before. diff -r 56eb90299693 -r adfdc2f70548 graph_displayer_canvas-edge.cc --- a/graph_displayer_canvas-edge.cc Wed Nov 23 16:24:59 2005 +0000 +++ b/graph_displayer_canvas-edge.cc Tue Nov 29 19:31:58 2005 +0000 @@ -8,11 +8,11 @@ min=edge_property_defaults[E_WIDTH]; max=edge_property_defaults[E_WIDTH]; - Graph::EdgeMap actual_map(mapstorage.graph,edge_property_defaults[E_WIDTH]); + Graph::EdgeMap actual_map((mainwin.mapstorage).graph,edge_property_defaults[E_WIDTH]); if(edge==INVALID) { - for (EdgeIt i(mapstorage.graph); i!=INVALID; ++i) + for (EdgeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { double v=fabs(actual_map[i]); int w; @@ -44,13 +44,13 @@ Graph::EdgeMap * actual_map; double min, max; - min=mapstorage.minOfEdgeMap(mapname); - max=mapstorage.maxOfEdgeMap(mapname); - actual_map=(mapstorage.edgemap_storage)[mapname]; + min=(mainwin.mapstorage).minOfEdgeMap(mapname); + max=(mainwin.mapstorage).maxOfEdgeMap(mapname); + actual_map=((mainwin.mapstorage).edgemap_storage)[mapname]; if(edge==INVALID) { - for (EdgeIt i(mapstorage.graph); i!=INVALID; ++i) + for (EdgeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { double v=fabs((*actual_map)[i]); int w; @@ -83,16 +83,16 @@ //the minimum of the nodemap to the range of //green in RGB Graph::EdgeMap * actual_map; - actual_map=(mapstorage.edgemap_storage)[mapname]; + actual_map=((mainwin.mapstorage).edgemap_storage)[mapname]; double max, min; - max=mapstorage.maxOfEdgeMap(mapname); - min=mapstorage.minOfEdgeMap(mapname); + max=(mainwin.mapstorage).maxOfEdgeMap(mapname); + min=(mainwin.mapstorage).minOfEdgeMap(mapname); if(edge==INVALID) { - for (EdgeIt i(mapstorage.graph); i!=INVALID; ++i) + for (EdgeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { double w=(*actual_map)[i]; @@ -134,7 +134,7 @@ //function maps the range of the maximum and //the minimum of the nodemap to the range of //green in RGB - Graph::EdgeMap actual_map(mapstorage.graph,edge_property_defaults[E_COLOR]); + Graph::EdgeMap actual_map((mainwin.mapstorage).graph,edge_property_defaults[E_COLOR]); double max, min; @@ -143,7 +143,7 @@ if(edge==INVALID) { - for (EdgeIt i(mapstorage.graph); i!=INVALID; ++i) + for (EdgeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { double w=actual_map[i]; @@ -188,10 +188,10 @@ if(edge==INVALID) { - for (EdgeIt i(mapstorage.graph); i!=INVALID; ++i) + for (EdgeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { edgemap_to_edit=mapname; - double number=(*(mapstorage.edgemap_storage)[mapname])[i]; + double number=(*((mainwin.mapstorage).edgemap_storage)[mapname])[i]; std::ostringstream ostr; ostr << number; @@ -202,7 +202,7 @@ } else { - double number=(*(mapstorage.edgemap_storage)[mapname])[edge]; + double number=(*((mainwin.mapstorage).edgemap_storage)[mapname])[edge]; std::ostringstream ostr; ostr << number; @@ -223,7 +223,7 @@ if(edge==INVALID) { - for (EdgeIt i(mapstorage.graph); i!=INVALID; ++i) + for (EdgeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { edgemap_to_edit=""; edgetextmap[i]->property_text().set_value(""); diff -r 56eb90299693 -r adfdc2f70548 graph_displayer_canvas-event.cc --- a/graph_displayer_canvas-event.cc Wed Nov 23 16:24:59 2005 +0000 +++ b/graph_displayer_canvas-event.cc Tue Nov 29 19:31:58 2005 +0000 @@ -94,7 +94,7 @@ active_item=(get_item_at(clicked_x, clicked_y)); active_node=INVALID; - for (NodeIt i(mapstorage.graph); i!=INVALID; ++i) + for (NodeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { if(nodesmap[i]==active_item) { @@ -125,7 +125,7 @@ //we only have to do sg. if the mouse button is pressed AND the click was on a node that was found in the set of nodes if(active_node!=INVALID) { - mapstorage.modified = true; + (mainwin.mapstorage).modified = true; //new coordinates will be the old values, //because the item will be moved to the @@ -144,52 +144,52 @@ nodetextmap[active_node]->move(dx, dy); // the new coordinates of the centre of the node - double coord_x = new_x - (clicked_x - mapstorage.coords[active_node].x); - double coord_y = new_y - (clicked_y - mapstorage.coords[active_node].y); + double coord_x = new_x - (clicked_x - (mainwin.mapstorage).coords[active_node].x); + double coord_y = new_y - (clicked_y - (mainwin.mapstorage).coords[active_node].y); clicked_x=new_x; clicked_y=new_y; // write back the new coordinates to the coords map - mapstorage.coords.set(active_node, xy(coord_x, coord_y)); + (mainwin.mapstorage).coords.set(active_node, xy(coord_x, coord_y)); // reposition the coordinates text std::ostringstream ostr; ostr << "(" << - mapstorage.coords[active_node].x << ", " << - mapstorage.coords[active_node].y << ")"; + (mainwin.mapstorage).coords[active_node].x << ", " << + (mainwin.mapstorage).coords[active_node].y << ")"; double radius = (nodesmap[active_node]->property_x2().get_value() - nodesmap[active_node]->property_x1().get_value()) / 2.0; if (coord_text) { coord_text->property_text().set_value(ostr.str()); - coord_text->property_x().set_value(mapstorage.coords[active_node].x + + coord_text->property_x().set_value((mainwin.mapstorage).coords[active_node].x + radius); - coord_text->property_y().set_value(mapstorage.coords[active_node].y - + coord_text->property_y().set_value((mainwin.mapstorage).coords[active_node].y - radius); } else { coord_text = new Gnome::Canvas::Text( displayed_graph, - mapstorage.coords[active_node].x + radius, - mapstorage.coords[active_node].y - radius, + (mainwin.mapstorage).coords[active_node].x + radius, + (mainwin.mapstorage).coords[active_node].y - radius, ostr.str()); coord_text->property_fill_color().set_value("black"); coord_text->property_anchor().set_value(Gtk::ANCHOR_SOUTH_WEST); } //all the edges connected to the moved point has to be redrawn - for(OutEdgeIt ei(mapstorage.graph,active_node);ei!=INVALID;++ei) + for(OutEdgeIt ei((mainwin.mapstorage).graph,active_node);ei!=INVALID;++ei) { Gnome::Canvas::Points coos; double x1, x2, y1, y2; - nodesmap[mapstorage.graph.source(ei)]->get_bounds(x1, y1, x2, y2); + nodesmap[(mainwin.mapstorage).graph.source(ei)]->get_bounds(x1, y1, x2, y2); coos.push_back(Gnome::Art::Point((x1+x2)/2,(y1+y2)/2)); - nodesmap[mapstorage.graph.target(ei)]->get_bounds(x1, y1, x2, y2); + nodesmap[(mainwin.mapstorage).graph.target(ei)]->get_bounds(x1, y1, x2, y2); coos.push_back(Gnome::Art::Point((x1+x2)/2,(y1+y2)/2)); if(isbutton==3) @@ -208,15 +208,15 @@ edgetextmap[ei]->property_y().set_value(text_pos.y); } - for(InEdgeIt ei(mapstorage.graph,active_node);ei!=INVALID;++ei) + for(InEdgeIt ei((mainwin.mapstorage).graph,active_node);ei!=INVALID;++ei) { Gnome::Canvas::Points coos; double x1, x2, y1, y2; - nodesmap[mapstorage.graph.source(ei)]->get_bounds(x1, y1, x2, y2); + nodesmap[(mainwin.mapstorage).graph.source(ei)]->get_bounds(x1, y1, x2, y2); coos.push_back(Gnome::Art::Point((x1+x2)/2,(y1+y2)/2)); - nodesmap[mapstorage.graph.target(ei)]->get_bounds(x1, y1, x2, y2); + nodesmap[(mainwin.mapstorage).graph.target(ei)]->get_bounds(x1, y1, x2, y2); coos.push_back(Gnome::Art::Point((x1+x2)/2,(y1+y2)/2)); if(isbutton==3) @@ -256,33 +256,33 @@ } case GDK_BUTTON_RELEASE: - mapstorage.modified = true; + (mainwin.mapstorage).modified = true; isbutton=1; - active_node=mapstorage.graph.addNode(); + active_node=(mainwin.mapstorage).graph.addNode(); //initiating values corresponding to new node in maps window_to_world (e->button.x, e->button.y, clicked_x, clicked_y); // update coordinates - mapstorage.coords.set(active_node, xy(clicked_x, clicked_y)); + (mainwin.mapstorage).coords.set(active_node, xy(clicked_x, clicked_y)); // update all other maps for (std::map*>::const_iterator it = - mapstorage.nodemap_storage.begin(); it != - mapstorage.nodemap_storage.end(); ++it) + (mainwin.mapstorage).nodemap_storage.begin(); it != + (mainwin.mapstorage).nodemap_storage.end(); ++it) { if ((it->first != "coordinates_x") && (it->first != "coordinates_y")) { (*(it->second))[active_node] = - mapstorage.nodemap_default[it->first]; + (mainwin.mapstorage).nodemap_default[it->first]; } } // increment the id map's default value - mapstorage.nodemap_default["id"] += 1.0; + (mainwin.mapstorage).nodemap_default["id"] += 1.0; nodesmap[active_node]=new Gnome::Canvas::Ellipse(displayed_graph, clicked_x-20, clicked_y-20, clicked_x+20, clicked_y+20); @@ -301,7 +301,8 @@ nodetextmap[active_node]->property_fill_color().set_value("darkblue"); nodetextmap[active_node]->raise_to_top(); - mapwin.updateNode(active_node); +// mapwin.updateNode(active_node); + propertyUpdate(active_node); isbutton=0; target_item=NULL; @@ -331,7 +332,7 @@ active_item=(get_item_at(clicked_x, clicked_y)); active_node=INVALID; - for (NodeIt i(mapstorage.graph); i!=INVALID; ++i) + for (NodeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { if(nodesmap[i]==active_item) { @@ -360,7 +361,7 @@ window_to_world (e->button.x, e->button.y, clicked_x, clicked_y); target_item=(get_item_at(clicked_x, clicked_y)); Node target_node=INVALID; - for (NodeIt i(mapstorage.graph); i!=INVALID; ++i) + for (NodeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { if(nodesmap[i]==target_item) { @@ -372,26 +373,26 @@ { if(target_node!=active_node) { - mapstorage.modified = true; + (mainwin.mapstorage).modified = true; *(nodesmap[target_node]) << Gnome::Canvas::Properties::fill_color("red"); //creating new edge - active_edge=mapstorage.graph.addEdge(active_node, + active_edge=(mainwin.mapstorage).graph.addEdge(active_node, target_node); // update maps for (std::map*>::const_iterator it = - mapstorage.edgemap_storage.begin(); it != - mapstorage.edgemap_storage.end(); ++it) + (mainwin.mapstorage).edgemap_storage.begin(); it != + (mainwin.mapstorage).edgemap_storage.end(); ++it) { (*(it->second))[active_edge] = - mapstorage.edgemap_default[it->first]; + (mainwin.mapstorage).edgemap_default[it->first]; } // increment the id map's default value - mapstorage.edgemap_default["id"] += 1.0; + (mainwin.mapstorage).edgemap_default["id"] += 1.0; //calculating coordinates of new edge Gnome::Canvas::Points coos; @@ -423,7 +424,8 @@ edgetextmap[active_edge]->raise_to_top(); //updating its properties - mapwin.updateEdge(active_edge); +// mapwin.updateEdge(active_edge); + propertyUpdate(active_edge); } else { @@ -478,7 +480,7 @@ active_node=INVALID; active_edge=INVALID; //was it a node? - for (NodeIt i(mapstorage.graph); i!=INVALID; ++i) + for (NodeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { if(nodesmap[i]==active_item) { @@ -488,7 +490,7 @@ //or was it an edge? if(active_node==INVALID) { - for (EdgeIt i(mapstorage.graph); i!=INVALID; ++i) + for (EdgeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { if(edgesmap[i]==active_item) { @@ -514,16 +516,16 @@ //a node was found if(active_node!=INVALID) { - mapstorage.modified = true; + (mainwin.mapstorage).modified = true; std::set edges_to_delete; - for(OutEdgeIt e(mapstorage.graph,active_node);e!=INVALID;++e) + for(OutEdgeIt e((mainwin.mapstorage).graph,active_node);e!=INVALID;++e) { edges_to_delete.insert(e); } - for(InEdgeIt e(mapstorage.graph,active_node);e!=INVALID;++e) + for(InEdgeIt e((mainwin.mapstorage).graph,active_node);e!=INVALID;++e) { edges_to_delete.insert(e); } @@ -587,7 +589,7 @@ active_item=(get_item_at(clicked_x, clicked_y)); //find the activated item between texts - for (EdgeIt i(mapstorage.graph); i!=INVALID; ++i) + for (EdgeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { //at the same time only one can be active if(edgetextmap[i]==active_item) @@ -599,7 +601,7 @@ //if it was not between texts, search for it between edges if(clicked_edge==INVALID) { - for (EdgeIt i(mapstorage.graph); i!=INVALID; ++i) + for (EdgeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { //at the same time only one can be active if((edgesmap[i]==active_item)||(edgetextmap[i]==active_item)) @@ -622,7 +624,7 @@ active_edge=clicked_edge; //create a dialog - Gtk::Dialog dialog("Edit value", *parentwin, true); + Gtk::Dialog dialog("Edit value", mainwin, true); dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL); dialog.add_button(Gtk::Stock::OK, Gtk::RESPONSE_ACCEPT); Gtk::VBox* vbox = dialog.get_vbox(); @@ -639,14 +641,15 @@ break; case Gtk::RESPONSE_ACCEPT: double new_value = spin.get_value(); - (*mapstorage.edgemap_storage[edgemap_to_edit])[active_edge] = + (*(mainwin.mapstorage).edgemap_storage[edgemap_to_edit])[active_edge] = new_value; std::ostringstream ostr; ostr << new_value; edgetextmap[active_edge]->property_text().set_value( ostr.str()); //mapwin.updateEdge(active_edge); - mapwin.updateEdge(Edge(INVALID)); +// mapwin.updateEdge(Edge(INVALID)); + propertyUpdate(Edge(INVALID)); } } } @@ -674,7 +677,7 @@ active_item=(get_item_at(clicked_x, clicked_y)); //find the activated item between texts - for (NodeIt i(mapstorage.graph); i!=INVALID; ++i) + for (NodeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { //at the same time only one can be active if(nodetextmap[i]==active_item) @@ -686,7 +689,7 @@ //if there was not, search for it between nodes if(clicked_node==INVALID) { - for (NodeIt i(mapstorage.graph); i!=INVALID; ++i) + for (NodeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { //at the same time only one can be active if(nodesmap[i]==active_item) @@ -709,7 +712,7 @@ active_node=clicked_node; //create a dialog - Gtk::Dialog dialog("Edit value", *parentwin, true); + Gtk::Dialog dialog("Edit value", mainwin, true); dialog.add_button(Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL); dialog.add_button(Gtk::Stock::OK, Gtk::RESPONSE_ACCEPT); Gtk::VBox* vbox = dialog.get_vbox(); @@ -726,14 +729,15 @@ break; case Gtk::RESPONSE_ACCEPT: double new_value = spin.get_value(); - (*mapstorage.nodemap_storage[nodemap_to_edit])[active_node] = + (*(mainwin.mapstorage).nodemap_storage[nodemap_to_edit])[active_node] = new_value; std::ostringstream ostr; ostr << new_value; nodetextmap[active_node]->property_text().set_value( ostr.str()); //mapwin.updateNode(active_node); - mapwin.updateNode(Node(INVALID)); +// mapwin.updateNode(Node(INVALID)); + propertyUpdate(Node(INVALID)); } } } @@ -750,14 +754,14 @@ { delete(nodetextmap[node_to_delete]); delete(nodesmap[node_to_delete]); - mapstorage.graph.erase(node_to_delete); + (mainwin.mapstorage).graph.erase(node_to_delete); } void GraphDisplayerCanvas::deleteItem(Edge edge_to_delete) { delete(edgetextmap[edge_to_delete]); delete(edgesmap[edge_to_delete]); - mapstorage.graph.erase(edge_to_delete); + (mainwin.mapstorage).graph.erase(edge_to_delete); } void GraphDisplayerCanvas::textReposition(xy new_place) @@ -777,7 +781,7 @@ } else { - for (EdgeIt i(mapstorage.graph); i!=INVALID; ++i) + for (EdgeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { if(edgesmap[i]==active_bre) { @@ -803,18 +807,18 @@ int GraphDisplayerCanvas::addNewEdgeMap(double default_value, std::string mapname) { //create the new map - Graph::EdgeMap * emptr=new Graph::EdgeMap (mapstorage.graph, default_value); + Graph::EdgeMap * emptr=new Graph::EdgeMap ((mainwin.mapstorage).graph, default_value); //if addition was not successful addEdgeMap returns one. //cause can be that there is already a map named like the new one - if(mapstorage.addEdgeMap(mapname,emptr, default_value)) + if((mainwin.mapstorage).addEdgeMap(mapname,emptr, default_value)) { return 1; } //add it to the list of the displayable maps - mapwin.registerNewEdgeMap(mapname); + mainwin.registerNewEdgeMap(mapname); //display it changeEdgeText(mapname); @@ -825,17 +829,17 @@ int GraphDisplayerCanvas::addNewNodeMap(double default_value, std::string mapname) { //create the new map - Graph::NodeMap * emptr=new Graph::NodeMap (mapstorage.graph,default_value); + Graph::NodeMap * emptr=new Graph::NodeMap ((mainwin.mapstorage).graph,default_value); //if addition was not successful addNodeMap returns one. //cause can be that there is already a map named like the new one - if(mapstorage.addNodeMap(mapname,emptr, default_value)) + if((mainwin.mapstorage).addNodeMap(mapname,emptr, default_value)) { return 1; } //add it to the list of the displayable maps - mapwin.registerNewNodeMap(mapname); + mainwin.registerNewNodeMap(mapname); //display it changeNodeText(mapname); diff -r 56eb90299693 -r adfdc2f70548 graph_displayer_canvas-node.cc --- a/graph_displayer_canvas-node.cc Wed Nov 23 16:24:59 2005 +0000 +++ b/graph_displayer_canvas-node.cc Tue Nov 29 19:31:58 2005 +0000 @@ -6,13 +6,13 @@ { Graph::NodeMap * actual_map; double min, max; - min=mapstorage.minOfNodeMap(mapname); - max=mapstorage.maxOfNodeMap(mapname); - actual_map=(mapstorage.nodemap_storage)[mapname]; + min=(mainwin.mapstorage).minOfNodeMap(mapname); + max=(mainwin.mapstorage).maxOfNodeMap(mapname); + actual_map=((mainwin.mapstorage).nodemap_storage)[mapname]; if(node==INVALID) { - for (NodeIt i(mapstorage.graph); i!=INVALID; ++i) + for (NodeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { double v=fabs((*actual_map)[i]); int w; @@ -64,11 +64,11 @@ double min, max; min=node_property_defaults[N_RADIUS]; max=node_property_defaults[N_RADIUS]; - Graph::NodeMap actual_map(mapstorage.graph,node_property_defaults[N_RADIUS]); + Graph::NodeMap actual_map((mainwin.mapstorage).graph,node_property_defaults[N_RADIUS]); if(node==INVALID) { - for (NodeIt i(mapstorage.graph); i!=INVALID; ++i) + for (NodeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { double v=fabs(actual_map[i]); int w; @@ -123,17 +123,17 @@ //green in RGB Graph::NodeMap * actual_map; - actual_map=(mapstorage.nodemap_storage)[mapname]; + actual_map=((mainwin.mapstorage).nodemap_storage)[mapname]; double max, min; - max=mapstorage.maxOfNodeMap(mapname); - min=mapstorage.minOfNodeMap(mapname); + max=(mainwin.mapstorage).maxOfNodeMap(mapname); + min=(mainwin.mapstorage).minOfNodeMap(mapname); if(node==INVALID) { - for (NodeIt i(mapstorage.graph); i!=INVALID; ++i) + for (NodeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { Gdk::Color color; @@ -178,7 +178,7 @@ //the minimum of the nodemap to the range of //green in RGB - Graph::NodeMap actual_map(mapstorage.graph,node_property_defaults[N_COLOR]); + Graph::NodeMap actual_map((mainwin.mapstorage).graph,node_property_defaults[N_COLOR]); double max, min; @@ -188,7 +188,7 @@ if(node==INVALID) { - for (NodeIt i(mapstorage.graph); i!=INVALID; ++i) + for (NodeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { Gdk::Color color; @@ -235,11 +235,11 @@ //that is the deleter map Graph::NodeMap * actual_map=NULL; - actual_map=(mapstorage.nodemap_storage)[mapname]; + actual_map=((mainwin.mapstorage).nodemap_storage)[mapname]; if(node==INVALID) { - for (NodeIt i(mapstorage.graph); i!=INVALID; ++i) + for (NodeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { nodemap_to_edit=mapname; double number=(*actual_map)[i]; @@ -272,7 +272,7 @@ if(node==INVALID) { - for (NodeIt i(mapstorage.graph); i!=INVALID; ++i) + for (NodeIt i((mainwin.mapstorage).graph); i!=INVALID; ++i) { nodemap_to_edit=""; nodetextmap[i]->property_text().set_value(""); diff -r 56eb90299693 -r adfdc2f70548 graph_displayer_canvas.cc --- a/graph_displayer_canvas.cc Wed Nov 23 16:24:59 2005 +0000 +++ b/graph_displayer_canvas.cc Tue Nov 29 19:31:58 2005 +0000 @@ -1,14 +1,12 @@ #include "graph_displayer_canvas.h" #include -GraphDisplayerCanvas::GraphDisplayerCanvas(MapStorage & ms, MapWin & mw, Gtk::Window * mainwin) : - nodesmap(ms.graph), edgesmap(ms.graph), edgetextmap(ms.graph), - nodetextmap(ms.graph), displayed_graph(*(root()), 0, 0), mapstorage(ms), +GraphDisplayerCanvas::GraphDisplayerCanvas(MainWin & mainw) : + nodesmap(mainw.mapstorage.graph), edgesmap(mainw.mapstorage.graph), edgetextmap(mainw.mapstorage.graph), + nodetextmap(mainw.mapstorage.graph), displayed_graph(*(root()), 0, 0), isbutton(0), active_item(NULL), target_item(NULL), nodemap_to_edit(""), - edgemap_to_edit(""), mapwin(mw) + edgemap_to_edit(""), mainwin(mainw) { - parentwin=mainwin; - //base event handler is move tool actual_handler=signal_event().connect(sigc::mem_fun(*this, &GraphDisplayerCanvas::moveEventHandler), false); actual_tool=MOVE; @@ -20,35 +18,155 @@ GraphDisplayerCanvas::~GraphDisplayerCanvas() { - for (NodeIt n(mapstorage.graph); n != INVALID; ++n) - { - delete nodesmap[n]; - delete nodetextmap[n]; - } + for (NodeIt n((mainwin.mapstorage).graph); n != INVALID; ++n) + { + delete nodesmap[n]; + delete nodetextmap[n]; + } + + for (EdgeIt e((mainwin.mapstorage).graph); e != INVALID; ++e) + { + delete edgesmap[e]; + delete edgetextmap[e]; + } +} - for (EdgeIt e(mapstorage.graph); e != INVALID; ++e) - { - delete edgesmap[e]; - delete edgetextmap[e]; - } +void GraphDisplayerCanvas::propertyChange(bool itisedge, int prop) +{ + if(itisedge) + { + propertyUpdate(Edge(INVALID), prop); + } + else + { + propertyUpdate(Node(INVALID), prop); + } +} + +void GraphDisplayerCanvas::propertyUpdate(Edge edge) +{ + for(int i=0;iraise_to_top(); @@ -85,8 +203,8 @@ //initializing edge-text as well, to empty string xy text_pos( - (mapstorage.coords[i].x+node_property_defaults[N_RADIUS]+5), - (mapstorage.coords[i].y+node_property_defaults[N_RADIUS]+5)); + ((mainwin.mapstorage).coords[i].x+node_property_defaults[N_RADIUS]+5), + ((mainwin.mapstorage).coords[i].y+node_property_defaults[N_RADIUS]+5)); nodetextmap[i]=new Gnome::Canvas::Text(displayed_graph, text_pos.x, text_pos.y, ""); @@ -104,13 +222,13 @@ active_edge=INVALID; forming_edge=INVALID; - for (NodeIt n(mapstorage.graph); n != INVALID; ++n) + for (NodeIt n((mainwin.mapstorage).graph); n != INVALID; ++n) { delete nodesmap[n]; delete nodetextmap[n]; } - for (EdgeIt e(mapstorage.graph); e != INVALID; ++e) + for (EdgeIt e((mainwin.mapstorage).graph); e != INVALID; ++e) { delete edgesmap[e]; delete edgetextmap[e]; diff -r 56eb90299693 -r adfdc2f70548 graph_displayer_canvas.h --- a/graph_displayer_canvas.h Wed Nov 23 16:24:59 2005 +0000 +++ b/graph_displayer_canvas.h Tue Nov 29 19:31:58 2005 +0000 @@ -6,8 +6,7 @@ class GraphDisplayerCanvas; #include "all_include.h" -#include "mapstorage.h" -#include "map_win.h" +#include "main_win.h" #include #include #include @@ -40,7 +39,7 @@ typedef Gnome::Canvas::CanvasAA Parent; public: - GraphDisplayerCanvas(MapStorage &, MapWin &, Gtk::Window *); + GraphDisplayerCanvas(MainWin &); virtual ~GraphDisplayerCanvas(); ///Changes the linewidth attribute according to the given map. @@ -73,6 +72,13 @@ int changeNodeText (std::string mapname, Node new_item=INVALID); int resetNodeText (Node new_item=INVALID); + void propertyChange(bool, int); + void propertyUpdate(Edge, int, int dummy=0); + void propertyUpdate(Node, int, int dummy=0); + + void propertyUpdate(Edge); + void propertyUpdate(Node); + ///Callback for 'ViewZoomIn' action. virtual void zoomIn(); ///Callback for 'ViewZoomOut' action. @@ -165,10 +171,6 @@ ///Group of graphical elements of displayed_graph Gnome::Canvas::Group displayed_graph; -public: - ///Here we store the maps that can be displayed through properties. - MapStorage & mapstorage; - private: ///Indicates whether the button of mouse is pressed or not int isbutton; @@ -193,14 +195,10 @@ static const int zoom_step = 5; -public: - ///We need to store mapwin, to be able to ask the appropriate values for properties of new items. - MapWin & mapwin; - private: - ///pointer to the parent window - Gtk::Window * parentwin; + ///reference to the parent window + MainWin & mainwin; }; diff -r 56eb90299693 -r adfdc2f70548 main_win.cc --- a/main_win.cc Wed Nov 23 16:24:59 2005 +0000 +++ b/main_win.cc Tue Nov 29 19:31:58 2005 +0000 @@ -1,14 +1,17 @@ #include "main_win.h" #include "icons/guipixbufs.h" -MainWin::MainWin() : - mapwin("Map Setup", mapstorage, gd_canvas), - gd_canvas(mapstorage, mapwin, (Gtk::Window *)this) +MainWin::MainWin() { + mapwin=new MapWin("Map Setup", mapstorage.getEdgeMapList(), mapstorage.getNodeMapList(), *this); + gd_canvas=new GraphDisplayerCanvas(*this); + set_title ("unsaved file - " + prog_name); set_default_size(WIN_WIDTH,WIN_HEIGHT); add(vbox); + //connecting signals - controller character + mapstorage.signal_prop_ch().connect(sigc::mem_fun(*gd_canvas, &GraphDisplayerCanvas::propertyChange)); // custom icons for the toolbar @@ -92,35 +95,35 @@ ag->add( Gtk::Action::create("ViewMenu", "_View") ); ag->add( Gtk::Action::create("ViewZoomIn", Gtk::Stock::ZOOM_IN), - sigc::mem_fun(this->gd_canvas, &GraphDisplayerCanvas::zoomIn)); + sigc::mem_fun(*(this->gd_canvas), &GraphDisplayerCanvas::zoomIn)); ag->add( Gtk::Action::create("ViewZoomOut", Gtk::Stock::ZOOM_OUT), - sigc::mem_fun(this->gd_canvas, &GraphDisplayerCanvas::zoomOut)); + sigc::mem_fun(*(this->gd_canvas), &GraphDisplayerCanvas::zoomOut)); ag->add( Gtk::Action::create("ViewZoomFit", Gtk::Stock::ZOOM_FIT), - sigc::mem_fun(this->gd_canvas, &GraphDisplayerCanvas::zoomFit)); + sigc::mem_fun(*(this->gd_canvas), &GraphDisplayerCanvas::zoomFit)); ag->add( Gtk::Action::create("ViewZoom100", Gtk::Stock::ZOOM_100), - sigc::mem_fun(this->gd_canvas, &GraphDisplayerCanvas::zoom100)); + sigc::mem_fun(*(this->gd_canvas), &GraphDisplayerCanvas::zoom100)); ag->add( Gtk::Action::create("ShowMenu", "_Show") ); ag->add( Gtk::Action::create("ShowMaps", "_Maps"), - sigc::mem_fun(this->mapwin, &MapWin::show)); + sigc::mem_fun(*(this->mapwin), &MapWin::show)); Gtk::RadioAction::Group tool_group; ag->add( Gtk::RadioAction::create(tool_group, "MoveItem", Gtk::StockID("gd-move"), "Move"), - sigc::bind( sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::changeEditorialTool ), 0) ); + sigc::bind( sigc::mem_fun ( *(this->gd_canvas), &GraphDisplayerCanvas::changeEditorialTool ), 0) ); ag->add( Gtk::RadioAction::create(tool_group, "CreateNode", Gtk::StockID("gd-addnode"), "Create node"), - sigc::bind( sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::changeEditorialTool ), 1) ); + sigc::bind( sigc::mem_fun ( *(this->gd_canvas), &GraphDisplayerCanvas::changeEditorialTool ), 1) ); ag->add( Gtk::RadioAction::create(tool_group, "CreateEdge", Gtk::StockID("gd-addlink"), "Create edge"), - sigc::bind( sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::changeEditorialTool ), 2) ); + sigc::bind( sigc::mem_fun ( *(this->gd_canvas), &GraphDisplayerCanvas::changeEditorialTool ), 2) ); ag->add( Gtk::RadioAction::create(tool_group, "EraseItem", Gtk::StockID("gd-delete"), "Delete"), - sigc::bind( sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::changeEditorialTool ), 3) ); + sigc::bind( sigc::mem_fun ( *(this->gd_canvas), &GraphDisplayerCanvas::changeEditorialTool ), 3) ); ag->add( Gtk::RadioAction::create(tool_group, "EditEdgeMap", Gtk::StockID("gd-editlink"), "Edit edge map"), - sigc::bind( sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::changeEditorialTool ), 4) ); + sigc::bind( sigc::mem_fun ( *(this->gd_canvas), &GraphDisplayerCanvas::changeEditorialTool ), 4) ); ag->add( Gtk::RadioAction::create(tool_group, "EditNodeMap", Gtk::StockID("gd-editnode"), "Edit node map"), - sigc::bind( sigc::mem_fun ( this->gd_canvas, &GraphDisplayerCanvas::changeEditorialTool ), 5) ); + sigc::bind( sigc::mem_fun ( *(this->gd_canvas), &GraphDisplayerCanvas::changeEditorialTool ), 5) ); ag->add( Gtk::Action::create("AddMap", Gtk::StockID("gd-newmap")), - sigc::mem_fun (new NewMapWin("NewMapWin", gd_canvas), &NewMapWin::show ) ); + sigc::mem_fun (new NewMapWin("NewMapWin", *this), &NewMapWin::show ) ); uim=Gtk::UIManager::create(); uim->insert_action_group(ag); @@ -194,7 +197,7 @@ Gtk::ScrolledWindow* pScrolledWindow = manage(new Gtk::ScrolledWindow()); pScrolledWindow->set_shadow_type(Gtk::SHADOW_IN); - pScrolledWindow->add(gd_canvas); + pScrolledWindow->add(*gd_canvas); vbox.pack_start(*pScrolledWindow); tooltips.set_tip(*(uim->get_widget("/ToolBar/CreateNode")),"Create Node"); @@ -208,8 +211,8 @@ mapstorage.readFromFile(file); mapstorage.file_name = file; mapstorage.modified = false; - gd_canvas.drawGraph(); - mapwin.update(); + gd_canvas->drawGraph(); + mapwin->update(mapstorage.getEdgeMapList(), mapstorage.getNodeMapList()); set_title(Glib::filename_display_basename(file) + " - " + prog_name); } @@ -233,9 +236,9 @@ break; } } - gd_canvas.clear(); + gd_canvas->clear(); mapstorage.clear(); - mapwin.update(); + mapwin->update(mapstorage.getEdgeMapList(), mapstorage.getNodeMapList()); set_title("unsaved file - " + prog_name); } @@ -264,15 +267,15 @@ fcdialog.add_button(Gtk::Stock::OPEN, Gtk::RESPONSE_ACCEPT); if (fcdialog.run() == Gtk::RESPONSE_ACCEPT) { - gd_canvas.clear(); + gd_canvas->clear(); mapstorage.clear(); Glib::ustring filename = fcdialog.get_filename(); if (!mapstorage.readFromFile(filename)) { mapstorage.file_name = filename; mapstorage.modified = false; - gd_canvas.drawGraph(); - mapwin.update(); + gd_canvas->drawGraph(); + mapwin->update(mapstorage.getEdgeMapList(), mapstorage.getNodeMapList()); set_title(Glib::filename_display_basename(filename) + " - " + prog_name); } } @@ -327,8 +330,39 @@ break; } } - gd_canvas.clear(); + gd_canvas->clear(); mapstorage.clear(); - mapwin.update(); + mapwin->update(mapstorage.getEdgeMapList(), mapstorage.getNodeMapList()); set_title("unsaved file - " + prog_name); } + +void MainWin::propertyChange(bool itisedge, int prop, std::string mapname) +{ + mapstorage.changeActiveMap(itisedge, prop, mapname); +} + +void MainWin::popupNewMapWin(bool itisedge, int prop) +{ + prop=prop; + (new NewMapWin("NewMapWin", *this, itisedge, false))->run(); +} + +std::string MainWin::getActiveEdgeMap(int prop) +{ + return mapstorage.getActiveEdgeMap(prop); +} + +std::string MainWin::getActiveNodeMap(int prop) +{ + return mapstorage.getActiveNodeMap(prop); +} + +void MainWin::registerNewEdgeMap(std::string mapname) +{ + mapwin->registerNewEdgeMap(mapname); +} + +void MainWin::registerNewNodeMap(std::string mapname) +{ + mapwin->registerNewNodeMap(mapname); +} diff -r 56eb90299693 -r adfdc2f70548 main_win.h --- a/main_win.h Wed Nov 23 16:24:59 2005 +0000 +++ b/main_win.h Tue Nov 29 19:31:58 2005 +0000 @@ -3,6 +3,8 @@ #ifndef MAIN_WIN_H #define MAIN_WIN_H +class MainWin; + #include "all_include.h" #include "mapstorage.h" #include "map_win.h" @@ -26,10 +28,10 @@ protected: ///Window of map-showing setup. Its type is \ref MapWin - MapWin mapwin; + MapWin * mapwin; ///The graph will be drawn on this \ref GraphDisplayerCanvas - GraphDisplayerCanvas gd_canvas; + GraphDisplayerCanvas * gd_canvas; ///ActionGroup for menu Glib::RefPtr ag; @@ -53,6 +55,17 @@ virtual void saveFileAs(); ///Callback for 'Close' action. virtual void close(); + +public: + void propertyChange(bool, int, std::string); + void popupNewMapWin(bool, int); + + std::string getActiveEdgeMap(int); + std::string getActiveNodeMap(int); + + void registerNewEdgeMap(std::string); + void registerNewNodeMap(std::string); + }; #endif //MAIN_WIN_H diff -r 56eb90299693 -r adfdc2f70548 map_win.cc --- a/map_win.cc Wed Nov 23 16:24:59 2005 +0000 +++ b/map_win.cc Tue Nov 29 19:31:58 2005 +0000 @@ -10,7 +10,7 @@ return true; } -MapWin::MapWin(const std::string& title, MapStorage & mapst, GraphDisplayerCanvas & grdispc):gdc(grdispc),ms(mapst) +MapWin::MapWin(const std::string& title, std::vector eml, std::vector nml, MainWin & mw):mainwin(mw) { set_title(title); set_default_size(200, 50); @@ -23,9 +23,12 @@ for(int i=0;isignal_cbt_ch().connect(sigc::bind(sigc::mem_fun(*this, &MapWin::edgeMapChanged), i)); + e_combo_array[i]->signal_newmapwin_needed().connect(sigc::bind(sigc::mem_fun(*this, &MapWin::newMapWinNeeded), i)); } vbox.pack_start(*(new Gtk::Label("Edge properties"))); @@ -40,9 +43,12 @@ for(int i=0;isignal_cbt_ch().connect(sigc::bind(sigc::mem_fun(*this, &MapWin::nodeMapChanged), i)); + n_combo_array[i]->signal_newmapwin_needed().connect(sigc::bind(sigc::mem_fun(*this, &MapWin::newMapWinNeeded), i)); } add(vbox); @@ -55,36 +61,34 @@ } -void MapWin::update() +void MapWin::nodeMapChanged(std::string mapname, int prop) +{ + mainwin.propertyChange(false, prop, mapname); +} + +void MapWin::edgeMapChanged(std::string mapname, int prop) +{ + mainwin.propertyChange(true, prop, mapname); +} + +void MapWin::newMapWinNeeded(bool itisedge, int prop) +{ + mainwin.popupNewMapWin(itisedge, prop); +} + +void MapWin::update(std::vector eml, std::vector nml) { for(int i=0;iupdate_list(); + e_combo_array[i]->update_list(eml); } for(int i=0;iupdate_list(); + n_combo_array[i]->update_list(nml); } } - -void MapWin::updateNode(Node node) -{ - for(int i=0;iupdate(node); - } -} - -void MapWin::updateEdge(Edge edge) -{ - for(int i=0;iupdate(edge); - } -} - void MapWin::registerNewEdgeMap(std::string newmapname) { for(int i=0;i +#include #include #include @@ -21,9 +19,8 @@ class MapSelector : public Gtk::HBox { protected: - GraphDisplayerCanvas & gdc; - ///The \ref MapStorage in which the visualizable maps are stored - MapStorage & ms; + sigc::signal signal_cbt; + sigc::signal signal_newmapwin; int id; @@ -41,15 +38,14 @@ Gtk::Label * label; - Node node_to_update; - Edge edge_to_update; - - public: - MapSelector(GraphDisplayerCanvas &, MapStorage &, int, bool); + MapSelector(std::vector, int, bool); - void update_list(); + sigc::signal signal_cbt_ch(); + sigc::signal signal_newmapwin_needed(); + + void update_list( std::vector ); ///If a radiobutton is clicked, this function determines ///which button was that and after that calls the @@ -61,9 +57,6 @@ virtual void reset(); - virtual void update(Node node); - virtual void update(Edge edge); - Glib::ustring get_active_text(); void set_active_text(Glib::ustring); void append_text(Glib::ustring); @@ -72,14 +65,7 @@ protected: - ///The \ref GraphDisplayerCanvas on which the graph will be drawn. - ///It has to be known for this class, because - ///when a map assigned to a certain attribute - ///a function of the \ref GraphDisplayerCanvas will be called. - GraphDisplayerCanvas & gdc; - - ///The \ref MapStorage in which the visualizable maps are stored - MapStorage & ms; + MainWin & mainwin; Gtk::Table * table; @@ -91,13 +77,13 @@ public: ///Constructor of MapWin creates the widgets shown in MapWin. - MapWin(const std::string& title, MapStorage &, GraphDisplayerCanvas &); + MapWin(const std::string& title, std::vector, std::vector, MainWin & mw); - ///This function is created to set the appropriate maps on the newly created node - void updateNode(Graph::Node); + void nodeMapChanged(std::string, int); - ///This function is created to set the appropriate maps on the newly created edge - void updateEdge(Graph::Edge); + void edgeMapChanged(std::string, int); + + void newMapWinNeeded(bool, int); ///This function inserts name of the new edgemap in the list in the combo box void registerNewEdgeMap(std::string); @@ -107,7 +93,7 @@ virtual bool closeIfEscapeIsPressed(GdkEventKey*); - void update(); + void update(std::vector, std::vector); }; #endif //MAP_WIN_H diff -r 56eb90299693 -r adfdc2f70548 mapstorage.cc --- a/mapstorage.cc Wed Nov 23 16:24:59 2005 +0000 +++ b/mapstorage.cc Tue Nov 29 19:31:58 2005 +0000 @@ -16,6 +16,18 @@ nodemap_default["id"] = 1.0; edgemap_default["id"] = 1.0; + + active_nodemaps.resize(NODE_PROPERTY_NUM); + for(int i=0;i MapStorage::getEdgeMapList() +{ + std::vector eml; + eml.resize(edgemap_storage.size()); + int i=0; + std::map< std::string,Graph::EdgeMap * >::iterator emsi=beginOfEdgeMaps(); + for(;emsi!=endOfEdgeMaps();emsi++) + { + eml[i]=(emsi->first); + i++; + } + return eml; +} + +std::vector MapStorage::getNodeMapList() +{ + std::vector nml; + nml.resize(nodemap_storage.size()); + int i=0; + std::map< std::string,Graph::NodeMap * >::iterator nmsi=beginOfNodeMaps(); + for(;nmsi!=endOfNodeMaps();nmsi++) + { + nml[i]=(nmsi->first); + i++; + } + return nml; +} + +MapStorage::Signal_Prop MapStorage::signal_prop_ch() +{ + return signal_prop; +} + int MapStorage::addEdgeMap(const std::string & name, Graph::EdgeMap *edgemap, double default_value = 0.0) { if( edgemap_storage.find(name) == edgemap_storage.end() ) diff -r 56eb90299693 -r adfdc2f70548 mapstorage.h --- a/mapstorage.h Wed Nov 23 16:24:59 2005 +0000 +++ b/mapstorage.h Tue Nov 29 19:31:58 2005 +0000 @@ -3,8 +3,11 @@ #ifndef MAPSTORAGE_H #define MAPSTORAGE_H +class Mapstorage; + #include "all_include.h" #include "xymap.h" +#include ///Class MapStorage is responsible for storing ///NodeMaps and EdgeMaps that can be shown later @@ -37,12 +40,22 @@ //Stores the default values for the different visualization edge attributes std::vector > default_edgemaps; + //Stores the active maps for the different visualization node attributes + std::vector< std::string > active_nodemaps; + + //Stores the active maps for the different visualization edge attributes + std::vector< std::string > active_edgemaps; + // Default values for the maps std::map< std::string, double > nodemap_default; // Default values for the maps std::map< std::string, double > edgemap_default; +protected: + typedef sigc::signal Signal_Prop; + Signal_Prop signal_prop; + public: ///Constructor of MapStorage. Expects the Graph of ///which maps will be stored in it. @@ -54,6 +67,16 @@ ~MapStorage(); + void changeActiveMap(bool, int, std::string); + + std::string getActiveEdgeMap(int); + std::string getActiveNodeMap(int); + + std::vector getEdgeMapList(); + std::vector getNodeMapList(); + + Signal_Prop signal_prop_ch(); + ///Adds given map to storage. A name and the map itself has to be provided. ///\param name is the name of map ///\nodemap is the pointer of the given nodemap diff -r 56eb90299693 -r adfdc2f70548 mw-mapselector.cc --- a/mw-mapselector.cc Wed Nov 23 16:24:59 2005 +0000 +++ b/mw-mapselector.cc Tue Nov 29 19:31:58 2005 +0000 @@ -1,8 +1,8 @@ #include "map_win.h" -MapWin::MapSelector::MapSelector(GraphDisplayerCanvas & grdispc, MapStorage & mapst, int identifier, bool edge):gdc(grdispc),ms(mapst),id(identifier),itisedge(edge),default_state(true),set_new_map(false),node_to_update(INVALID),edge_to_update(INVALID) +MapWin::MapSelector::MapSelector(std::vector ml, int identifier, bool edge):id(identifier),itisedge(edge),default_state(true),set_new_map(false) { - update_list(); + update_list(ml); cbt.set_active(0); @@ -50,27 +50,16 @@ void MapWin::MapSelector::new_but_pressed() { set_new_map=true; - (new NewMapWin("NewMapWin", gdc, itisedge, false))->run(); + signal_newmapwin.emit(itisedge); } -void MapWin::MapSelector::update_list() +void MapWin::MapSelector::update_list( std::vector< std::string > ml ) { cbt.clear(); - if(itisedge) + std::vector< std::string >::iterator emsi=ml.begin(); + for(;emsi!=ml.end();emsi++) { - std::map< std::string,Graph::EdgeMap * >::iterator emsi=ms.beginOfEdgeMaps(); - for(;emsi!=ms.endOfEdgeMaps();emsi++) - { - cbt.append_text(emsi->first); - } - } - else - { - std::map< std::string,Graph::NodeMap * >::iterator emsi=ms.beginOfNodeMaps(); - for(;emsi!=ms.endOfNodeMaps();emsi++) - { - cbt.append_text(emsi->first); - } + cbt.append_text(*emsi); } cbt.prepend_text("Default values"); } @@ -83,52 +72,12 @@ Glib::ustring mapname = cbt.get_active_text(); if(!(mapname.empty())) //We seem to get 2 signals, one when the text is empty. { - if(itisedge) - { - if( ( (ms.edgemap_storage).find(mapname) != (ms.edgemap_storage).end() ) ) - { - Edge edge=edge_to_update; - switch(id) - { - case E_WIDTH: - gdc.changeEdgeWidth(mapname, edge); - break; - case E_COLOR: - gdc.changeEdgeColor(mapname, edge); - break; - case E_TEXT: - gdc.changeEdgeText(mapname, edge); - break; - default: - std::cerr<<"Error\n"; - } - } - } - else - { - if( ( (ms.nodemap_storage).find(mapname) != (ms.nodemap_storage).end() ) ) - { - Node node=node_to_update; - switch(id) - { - case N_RADIUS: - gdc.changeNodeRadius(mapname, node); - break; - case N_COLOR: - gdc.changeNodeColor(mapname, node); - break; - case N_TEXT: - gdc.changeNodeText(mapname, node); - break; - default: - std::cerr<<"Error\n"; - } - } - } + signal_cbt.emit(mapname); } } else if((!default_state)&&(cbt.get_active_row_number()==0)) { + signal_cbt.emit(""); reset(); } } @@ -138,71 +87,9 @@ default_state=true; cbt.set_active(0); - if(itisedge) - { - Edge edge=edge_to_update; - switch(id) - { - case E_WIDTH: - gdc.resetEdgeWidth(edge); - break; - case E_COLOR: - gdc.resetEdgeColor(edge); - break; - case E_TEXT: - gdc.resetEdgeText(edge); - break; - default: - std::cerr<<"Error\n"; - } - } - else - { - Node node=node_to_update; - switch(id) - { - case N_RADIUS: - gdc.resetNodeRadius(node); - break; - case N_COLOR: - gdc.resetNodeColor(node); - break; - case N_TEXT: - gdc.resetNodeText(node); - break; - default: - std::cerr<<"Error\n"; - } - } + signal_cbt.emit(""); } -void MapWin::MapSelector::update(Node node) -{ - node_to_update=node; - if(default_state) - { - reset(); - } - else - { - comboChanged(); - } - node_to_update=INVALID; -} - -void MapWin::MapSelector::update(Edge edge) -{ - edge_to_update=edge; - if(default_state) - { - reset(); - } - else - { - comboChanged(); - } - edge_to_update=INVALID; -} Glib::ustring MapWin::MapSelector::get_active_text() { @@ -223,3 +110,13 @@ set_new_map=false; } } + +sigc::signal MapWin::MapSelector::signal_cbt_ch() +{ + return signal_cbt; +} + +sigc::signal MapWin::MapSelector::signal_newmapwin_needed() +{ + return signal_newmapwin; +} diff -r 56eb90299693 -r adfdc2f70548 new_map_win.cc --- a/new_map_win.cc Wed Nov 23 16:24:59 2005 +0000 +++ b/new_map_win.cc Tue Nov 29 19:31:58 2005 +0000 @@ -9,7 +9,7 @@ return true; } -NewMapWin::NewMapWin(const std::string& title, GraphDisplayerCanvas & grdispc, bool itisedge, bool edgenode):Gtk::Dialog(title, true, true),gdc(grdispc),node("Create NodeMap"),edge("Create EdgeMap") +NewMapWin::NewMapWin(const std::string& title, MainWin & mw, bool itisedge, bool edgenode):Gtk::Dialog(title, true, true),mainwin(mw),node("Create NodeMap"),edge("Create EdgeMap") { set_default_size(200, 50); @@ -83,11 +83,11 @@ if(edge.get_active()) { //create the new map - Graph::EdgeMap * emptr=new Graph::EdgeMap (gdc.mapstorage.graph); + Graph::EdgeMap * emptr=new Graph::EdgeMap (mainwin.mapstorage.graph); std::stack polishstack; - for(EdgeIt k(gdc.mapstorage.graph); k!=INVALID; ++k) + for(EdgeIt k(mainwin.mapstorage.graph); k!=INVALID; ++k) { for(int i=0;i<(int)polishform.size();i++) { @@ -106,11 +106,11 @@ break; default: //substitute variable - std::map< std::string,Graph::EdgeMap * > ems=gdc.mapstorage.edgemap_storage; + std::map< std::string,Graph::EdgeMap * > ems=mainwin.mapstorage.edgemap_storage; bool itisvar=(ems.find(ch2var[ polishform[i] ])!=ems.end()); if(itisvar) { - polishstack.push( (*(gdc.mapstorage.edgemap_storage[ ch2var[ polishform[i] ] ]))[k]); + polishstack.push( (*(mainwin.mapstorage.edgemap_storage[ ch2var[ polishform[i] ] ]))[k]); } else { @@ -153,25 +153,25 @@ //if addition was not successful addEdgeMap returns one. //cause can be that there is already a map named like the new one - if(gdc.mapstorage.addEdgeMap(mapname, emptr, def_val)) + if(mainwin.mapstorage.addEdgeMap(mapname, emptr, def_val)) { abortion=1; } //add it to the list of the displayable maps - gdc.mapwin.registerNewEdgeMap(mapname); + mainwin.registerNewEdgeMap(mapname); //display it - gdc.changeEdgeText(mapname); + //gdc.changeEdgeText(mapname); } else //!edge.get_active() { //create the new map - Graph::NodeMap * emptr=new Graph::NodeMap (gdc.mapstorage.graph); + Graph::NodeMap * emptr=new Graph::NodeMap (mainwin.mapstorage.graph); std::stack polishstack; - for(NodeIt k(gdc.mapstorage.graph); k!=INVALID; ++k) + for(NodeIt k(mainwin.mapstorage.graph); k!=INVALID; ++k) { for(int i=0;i<(int)polishform.size();i++) { @@ -189,11 +189,11 @@ polishstack.pop(); break; default: - std::map< std::string,Graph::NodeMap * > nms=gdc.mapstorage.nodemap_storage; + std::map< std::string,Graph::NodeMap * > nms=mainwin.mapstorage.nodemap_storage; bool itisvar=(nms.find(ch2var[ polishform[i] ])!=nms.end()); if(itisvar) { - polishstack.push( (*(gdc.mapstorage.nodemap_storage[ ch2var[ polishform[i] ] ]))[k]); + polishstack.push( (*(mainwin.mapstorage.nodemap_storage[ ch2var[ polishform[i] ] ]))[k]); } else { @@ -236,13 +236,13 @@ //if addition was not successful addNodeMap returns one. //cause can be that there is already a map named like the new one - if(gdc.mapstorage.addNodeMap(mapname,emptr, def_val)) + if(mainwin.mapstorage.addNodeMap(mapname,emptr, def_val)) { abortion=1; } //add it to the list of the displayable maps - gdc.mapwin.registerNewNodeMap(mapname); + mainwin.registerNewNodeMap(mapname); //display it //gdc.changeNodeText(mapname); @@ -431,11 +431,11 @@ //is it mapname? if(itisedge) { - cancel=(gdc.mapstorage.edgemap_storage.find(variable)==gdc.mapstorage.edgemap_storage.end()); + cancel=(mainwin.mapstorage.edgemap_storage.find(variable)==mainwin.mapstorage.edgemap_storage.end()); } else { - cancel=(gdc.mapstorage.nodemap_storage.find(variable)==gdc.mapstorage.nodemap_storage.end()); + cancel=(mainwin.mapstorage.nodemap_storage.find(variable)==mainwin.mapstorage.nodemap_storage.end()); } //maybe it is number int point_num=0; diff -r 56eb90299693 -r adfdc2f70548 new_map_win.h --- a/new_map_win.h Wed Nov 23 16:24:59 2005 +0000 +++ b/new_map_win.h Tue Nov 29 19:31:58 2005 +0000 @@ -6,7 +6,7 @@ class NewMapWin; #include -#include +#include #include #include #include @@ -16,11 +16,7 @@ class NewMapWin : public Gtk::Dialog { - ///The \ref GraphDisplayerCanvas on which the graph will be drawn. - ///It has to be known for this class, because - ///when a map is created - ///a function of the \ref GraphDisplayerCanvas will be called. - GraphDisplayerCanvas & gdc; + MainWin & mainwin; public: struct tree_node @@ -31,7 +27,7 @@ }; ///Constructor of NewMapWin creates the widgets shown in NewMapWin. - NewMapWin(const std::string& title, GraphDisplayerCanvas &, bool itisedge=true, bool edgenode=true); + NewMapWin(const std::string& title, MainWin &, bool itisedge=true, bool edgenode=true); ///Signal on button is connected to this function, ///Therefore this function determines whether to