#include "graph_displayer_canvas.h" #include GraphDisplayerCanvas::GraphDisplayerCanvas(NoteBookTab & 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(""), autoscale(true), zoomtrack(false), radius_size(20), edge_width(10), iterations(20), attraction(0.05), propulsation(40000), was_redesigned(false), mytab(mainw) { //base event handler is move tool actual_handler=signal_event().connect(sigc::mem_fun(*this, &GraphDisplayerCanvas::moveEventHandler), false); actual_tool=MOVE; active_node=INVALID; active_edge=INVALID; forming_edge=INVALID; } GraphDisplayerCanvas::~GraphDisplayerCanvas() { for (NodeIt n((mytab.mapstorage).graph); n != INVALID; ++n) { delete nodesmap[n]; delete nodetextmap[n]; } for (EdgeIt e((mytab.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;iproperty_fill_color().set_value("darkgreen"); edgetextmap[i]->signal_event().connect(sigc::mem_fun(*this, &GraphDisplayerCanvas::mapEditEventHandler), false); edgetextmap[i]->raise_to_top(); } //afterwards nodes come to be drawn for (NodeIt i((mytab.mapstorage).graph); i!=INVALID; ++i) { //drawing bule nodes, with black line around them nodesmap[i]=new Gnome::Canvas::Ellipse( displayed_graph, (mytab.mapstorage).coords[i].x-20, (mytab.mapstorage).coords[i].y-20, (mytab.mapstorage).coords[i].x+20, (mytab.mapstorage).coords[i].y+20); *(nodesmap[i]) << Gnome::Canvas::Properties::fill_color("blue"); *(nodesmap[i]) << Gnome::Canvas::Properties::outline_color("black"); nodesmap[i]->raise_to_top(); //initializing edge-text as well, to empty string XY text_pos( ((mytab.mapstorage).coords[i].x+node_property_defaults[N_RADIUS]+5), ((mytab.mapstorage).coords[i].y+node_property_defaults[N_RADIUS]+5)); nodetextmap[i]=new Gnome::Canvas::Text(displayed_graph, text_pos.x, text_pos.y, ""); nodetextmap[i]->property_fill_color().set_value("darkblue"); nodetextmap[i]->signal_event().connect(sigc::mem_fun(*this, &GraphDisplayerCanvas::mapEditEventHandler), false); nodetextmap[i]->raise_to_top(); } updateScrollRegion(); } void GraphDisplayerCanvas::clear() { active_node=INVALID; active_edge=INVALID; forming_edge=INVALID; for (NodeIt n((mytab.mapstorage).graph); n != INVALID; ++n) { delete nodesmap[n]; delete nodetextmap[n]; } for (EdgeIt e((mytab.mapstorage).graph); e != INVALID; ++e) { delete edgesmap[e]; delete edgetextmap[e]; } } void GraphDisplayerCanvas::setView(bool autoscale_p, bool zoomtrack_p, double width_p, double radius_p) { autoscale=autoscale_p; edge_width=width_p; radius_size=radius_p; if((!zoomtrack) && zoomtrack_p) { fixed_zoom_factor=get_pixels_per_unit(); } zoomtrack=zoomtrack_p; propertyChange(false, N_RADIUS); propertyChange(true, E_WIDTH); } void GraphDisplayerCanvas::getView(bool & autoscale_p, bool & zoomtrack_p, double& width_p, double& radius_p) { autoscale_p=autoscale; zoomtrack_p=zoomtrack; width_p=edge_width; radius_p=radius_size; } void GraphDisplayerCanvas::reDesignGraph() { double min_dist=20; double init_vector_length=25; if(!was_redesigned) { NodeIt i((mytab.mapstorage).graph); double r=random(); dim2::Point init(init_vector_length*sin(r),init_vector_length*cos(r)); moveNode(init.x, init.y, nodesmap[i], i); was_redesigned=true; } //iteration counter for(int l=0;l x(mytab.mapstorage.graph); Graph::NodeMap y(mytab.mapstorage.graph); XYMap > actual_forces; actual_forces.setXMap(x); actual_forces.setYMap(y); lemon::dim2::Point delta; //count actual force for each nodes for (NodeIt i((mytab.mapstorage).graph); i!=INVALID; ++i) { //propulsation of nodes for (NodeIt j((mytab.mapstorage).graph); j!=INVALID; ++j) { if(i!=j) { delta=((mytab.mapstorage).coords[i]-(mytab.mapstorage).coords[j]); double length_sqr=delta.normSquare(); double length=sqrt(length_sqr); if(length_sqr