graph_displayer_canvas.cc
author ladanyi
Mon, 23 May 2005 04:48:14 +0000
branchgui
changeset 3 bd60a2909c53
child 4 e099638ff236
permissions -rwxr-xr-x
trunk/src/* move to trunk/
ladanyi@1
     1
#include <graph_displayer_canvas.h>
ladanyi@1
     2
ladanyi@1
     3
GraphDisplayerCanvas::GraphDisplayerCanvas(Graph & gr, CoordinatesMap & cm, MapStorage & ms):g(gr),nodesmap(g),edgesmap(g),edgetextmap(g),displayed_graph(*(root()), 0, 0),mapstorage(ms),isbutton(false),active_item(NULL)
ladanyi@1
     4
{
ladanyi@1
     5
ladanyi@1
     6
  for (EdgeIt i(g); i!=INVALID; ++i)
ladanyi@1
     7
  {
ladanyi@1
     8
    Gnome::Canvas::Points coos;
ladanyi@1
     9
    coos.push_back(Gnome::Art::Point(cm[g.source(i)].x,cm[g.source(i)].y));
ladanyi@1
    10
    coos.push_back(Gnome::Art::Point(cm[g.target(i)].x,cm[g.target(i)].y));
ladanyi@1
    11
    
ladanyi@1
    12
    edgesmap[i]=new Gnome::Canvas::Line(displayed_graph, coos);
ladanyi@1
    13
    *(edgesmap[i]) << Gnome::Canvas::Properties::fill_color("green");
ladanyi@1
    14
    edgesmap[i]->property_width_pixels().set_value(10);
ladanyi@1
    15
    
ladanyi@1
    16
    
ladanyi@1
    17
    double x1, x2, y1, y2;
ladanyi@1
    18
    edgesmap[i]->get_bounds(x1, y1, x2, y2);
ladanyi@1
    19
    
ladanyi@1
    20
    edgetextmap[i]=new Gnome::Canvas::Text(displayed_graph,(x1+x2)/2, (y1+y2)/2, "");
ladanyi@1
    21
    edgetextmap[i]->property_fill_color().set_value("black");
ladanyi@1
    22
  }
ladanyi@1
    23
ladanyi@1
    24
  NodeIt i(g);
ladanyi@1
    25
  int maxx=0, maxy=0, minx=(int)cm[i].x, miny=(int)cm[i].y;
ladanyi@1
    26
ladanyi@1
    27
  for (; i!=INVALID; ++i)
ladanyi@1
    28
  {
ladanyi@1
    29
    if(cm[i].x>maxx)maxx=(int)cm[i].x;
ladanyi@1
    30
    if(cm[i].y>maxy)maxy=(int)cm[i].y;
ladanyi@1
    31
    if(cm[i].x<minx)minx=(int)cm[i].x;
ladanyi@1
    32
    if(cm[i].y<miny)miny=(int)cm[i].y;
ladanyi@1
    33
ladanyi@1
    34
    nodesmap[i]=new Gnome::Canvas::Ellipse(displayed_graph, cm[i].x-20, cm[i].y-20, cm[i].x+20, cm[i].y+20);
ladanyi@1
    35
    *(nodesmap[i]) << Gnome::Canvas::Properties::fill_color("blue");
ladanyi@1
    36
    *(nodesmap[i]) << Gnome::Canvas::Properties::outline_color("black");
ladanyi@1
    37
    (nodesmap[i])->signal_event().connect(sigc::bind(sigc::mem_fun(*this, &GraphDisplayerCanvas::event_handler),i));
ladanyi@1
    38
  }
ladanyi@1
    39
ladanyi@1
    40
  double biggest_x=(abs(maxx)>abs(minx))?(abs(maxx)+80):(abs(minx)+80);
ladanyi@1
    41
  double biggest_y=(abs(maxy)>abs(miny))?(abs(maxy)+80):(abs(miny)+80);
ladanyi@1
    42
ladanyi@1
    43
  set_pixels_per_unit((biggest_x>biggest_y)?(WIN_WIDTH/biggest_x/2):(WIN_HEIGHT/biggest_y/2));
ladanyi@1
    44
  std::cout<<abs(maxx)<<" "<<abs(minx)<<" big x "<<biggest_x<<" "<<abs(maxy)<<" "<<abs(miny)<<" big y "<<biggest_y<<std::endl;
ladanyi@1
    45
  std::cout<<maxx<<" "<<minx<<" big x "<<biggest_x<<" "<<maxy<<" "<<miny<<" big y "<<biggest_y<<std::endl;
ladanyi@1
    46
  std::cout<<"dx "<<(maxx-minx)<<" dy "<<(maxy-miny)<<" xrate "<<((maxx-minx)/WIN_WIDTH)<<" yrate "<<((maxy-miny)/WIN_HEIGHT)<<std::endl;
ladanyi@1
    47
ladanyi@1
    48
}
ladanyi@1
    49
ladanyi@1
    50
GraphDisplayerCanvas::~GraphDisplayerCanvas()
ladanyi@1
    51
{
ladanyi@1
    52
    Graph::NodeMap <int> id(g);
ladanyi@1
    53
    Graph::NodeMap <double> xc(g);
ladanyi@1
    54
    Graph::NodeMap <double> yc(g);
ladanyi@1
    55
ladanyi@1
    56
    int j=1;
ladanyi@1
    57
ladanyi@1
    58
    for (NodeIt i(g); i!=INVALID; ++i)
ladanyi@1
    59
    {
ladanyi@1
    60
        double x1,y1,x2,y2;
ladanyi@1
    61
        nodesmap[i]->get_bounds(x1, y1, x2, y2);
ladanyi@1
    62
ladanyi@1
    63
        id[i]=j++;
ladanyi@1
    64
        xc[i]=(x1+x2)/2;
ladanyi@1
    65
        yc[i]=(y1+y2)/2;
ladanyi@1
    66
    }
ladanyi@1
    67
ladanyi@1
    68
    GraphWriter<Graph> writer(std::cout,g);
ladanyi@1
    69
ladanyi@1
    70
    writer.writeNodeMap("id", id);
ladanyi@1
    71
    writer.writeNodeMap("coordinates_x", xc);
ladanyi@1
    72
    writer.writeNodeMap("coordinates_y", yc);
ladanyi@1
    73
    writer.run();
ladanyi@1
    74
}
ladanyi@1
    75
ladanyi@1
    76
int GraphDisplayerCanvas::changeLineWidth (std::string mapname)
ladanyi@1
    77
{
ladanyi@1
    78
  for (EdgeIt i(g); i!=INVALID; ++i)
ladanyi@1
    79
  {
ladanyi@1
    80
    int w=(int)(*(mapstorage.edgemap_storage)[mapname])[i];
ladanyi@1
    81
    edgesmap[i]->property_width_pixels().set_value(w);
ladanyi@1
    82
  }
ladanyi@1
    83
  return 0;
ladanyi@1
    84
};
ladanyi@1
    85
ladanyi@1
    86
int GraphDisplayerCanvas::changeColor (std::string mapname)
ladanyi@1
    87
{  
ladanyi@1
    88
  for (EdgeIt i(g); i!=INVALID; ++i)
ladanyi@1
    89
  {
ladanyi@1
    90
    double w=(*(mapstorage.edgemap_storage)[mapname])[i];
ladanyi@1
    91
    double max=mapstorage.maxOfEdgeMap(mapname);
ladanyi@1
    92
    double min=mapstorage.minOfEdgeMap(mapname);
ladanyi@1
    93
      
ladanyi@1
    94
    //std::cout<<w<<" "<<max<<" "<<min<<" "<<100*(w-min)/(max-min)<<std::endl;
ladanyi@1
    95
    Gdk::Color color;
ladanyi@1
    96
    if(max!=min)
ladanyi@1
    97
    {
ladanyi@1
    98
      color.set_rgb_p (0, 100*(w-min)/(max-min), 0);
ladanyi@1
    99
    }
ladanyi@1
   100
    else
ladanyi@1
   101
    {
ladanyi@1
   102
      color.set_rgb_p (0, 100, 0);
ladanyi@1
   103
    }
ladanyi@1
   104
ladanyi@1
   105
    edgesmap[i]->property_fill_color_gdk().set_value(color);
ladanyi@1
   106
  }
ladanyi@1
   107
  return 0;
ladanyi@1
   108
};
ladanyi@1
   109
ladanyi@1
   110
int GraphDisplayerCanvas::changeText (std::string mapname)
ladanyi@1
   111
{
ladanyi@1
   112
  for (EdgeIt i(g); i!=INVALID; ++i)
ladanyi@1
   113
  {
ladanyi@1
   114
    if(mapname!="Text")
ladanyi@1
   115
    {
ladanyi@1
   116
      double number=(*(mapstorage.edgemap_storage)[mapname])[i];
ladanyi@1
   117
      int length=(int)(floor(log(number)/log(10)))+1;
ladanyi@1
   118
      int maxpos=(int)(pow(10,length-1));
ladanyi@1
   119
      int strl=length+1+RANGE;
ladanyi@1
   120
      char * str=new char[strl];
ladanyi@1
   121
      str[length]='.';
ladanyi@1
   122
      str[strl]='\0';
ladanyi@1
   123
      
ladanyi@1
   124
      for(int j=0;j<strl;j++)
ladanyi@1
   125
      {
ladanyi@1
   126
	if(j!=length)
ladanyi@1
   127
        {
ladanyi@1
   128
	  int digit=(int)(number/maxpos);
ladanyi@1
   129
	  str[j]=(digit+'0');
ladanyi@1
   130
	  number-=digit*maxpos;
ladanyi@1
   131
	  number*=10;
ladanyi@1
   132
        }
ladanyi@1
   133
      }
ladanyi@1
   134
      
ladanyi@1
   135
      edgetextmap[i]->property_text().set_value(str);
ladanyi@1
   136
    }
ladanyi@1
   137
    else
ladanyi@1
   138
    {
ladanyi@1
   139
      edgetextmap[i]->property_text().set_value("");
ladanyi@1
   140
    }
ladanyi@1
   141
  }
ladanyi@1
   142
  return 0;
ladanyi@1
   143
};
ladanyi@1
   144
ladanyi@1
   145
ladanyi@1
   146
int GraphDisplayerCanvas::rezoom ()
ladanyi@1
   147
{
ladanyi@1
   148
  double x1, x2, y1, y2;
ladanyi@1
   149
  int x,y;
ladanyi@1
   150
ladanyi@1
   151
  NodeIt i(g);
ladanyi@1
   152
  nodesmap[i]->get_bounds(x1, y1, x2, y2);
ladanyi@1
   153
ladanyi@1
   154
  x=(int)((x1+x2)/2);
ladanyi@1
   155
  y=(int)((y1+y2)/2);
ladanyi@1
   156
  
ladanyi@1
   157
  int maxx=0, maxy=0, minx=(int)x, miny=(int)y;
ladanyi@1
   158
ladanyi@1
   159
  for (; i!=INVALID; ++i)
ladanyi@1
   160
  {
ladanyi@1
   161
    nodesmap[i]->get_bounds(x1, y1, x2, y2);
ladanyi@1
   162
ladanyi@1
   163
    x=(int)((x1+x2)/2);
ladanyi@1
   164
    y=(int)((y1+y2)/2);
ladanyi@1
   165
ladanyi@1
   166
    if(x>maxx)maxx=x;
ladanyi@1
   167
    if(y>maxy)maxy=y;
ladanyi@1
   168
    if(x<minx)minx=x;
ladanyi@1
   169
    if(y<miny)miny=y;
ladanyi@1
   170
  }
ladanyi@1
   171
ladanyi@1
   172
  double biggest_x=(abs(maxx)>abs(minx))?(abs(maxx)+80):(abs(minx)+80);
ladanyi@1
   173
  double biggest_y=(abs(maxy)>abs(miny))?(abs(maxy)+80):(abs(miny)+80);
ladanyi@1
   174
ladanyi@1
   175
  set_pixels_per_unit((biggest_x-WIN_WIDTH>biggest_y-WIN_HEIGHT)?(WIN_WIDTH/biggest_x/2):(WIN_HEIGHT/biggest_y/2));
ladanyi@1
   176
  return 0;
ladanyi@1
   177
};
ladanyi@1
   178
ladanyi@1
   179
ladanyi@1
   180
///This function moves only one node of displayed_graph,
ladanyi@1
   181
///but recalculate the location of weight point,
ladanyi@1
   182
///and also redraw the sides of the planefigure.
ladanyi@1
   183
bool GraphDisplayerCanvas::event_handler(GdkEvent* e, Node n)
ladanyi@1
   184
{
ladanyi@1
   185
  switch(e->type)
ladanyi@1
   186
  {
ladanyi@1
   187
    case GDK_BUTTON_PRESS:
ladanyi@1
   188
      clicked_x=e->button.x;
ladanyi@1
   189
      clicked_y=e->button.y;
ladanyi@1
   190
      active_item=(get_item_at(e->button.x, e->button.y));
ladanyi@1
   191
      isbutton=true;
ladanyi@1
   192
      break;
ladanyi@1
   193
    case GDK_BUTTON_RELEASE:
ladanyi@1
   194
      isbutton=false;
ladanyi@1
   195
      active_item=NULL;
ladanyi@1
   196
      break;
ladanyi@1
   197
    case GDK_MOTION_NOTIFY:
ladanyi@1
   198
      if(isbutton)
ladanyi@1
   199
      {
ladanyi@1
   200
        double dx=e->motion.x-clicked_x;
ladanyi@1
   201
        double dy=e->motion.y-clicked_y;
ladanyi@1
   202
        active_item->move(dx, dy);
ladanyi@1
   203
        clicked_x=e->motion.x;
ladanyi@1
   204
        clicked_y=e->motion.y;
ladanyi@1
   205
ladanyi@1
   206
        EdgeIt e;
ladanyi@1
   207
ladanyi@1
   208
        g.firstOut(e,n);
ladanyi@1
   209
        for(;e!=INVALID;g.nextOut(e))
ladanyi@1
   210
        {
ladanyi@1
   211
            Gnome::Canvas::Points coos;
ladanyi@1
   212
            double x1, x2, y1, y2;
ladanyi@1
   213
ladanyi@1
   214
            nodesmap[g.source(e)]->get_bounds(x1, y1, x2, y2);
ladanyi@1
   215
            coos.push_back(Gnome::Art::Point((x1+x2)/2,(y1+y2)/2));
ladanyi@1
   216
ladanyi@1
   217
            nodesmap[g.target(e)]->get_bounds(x1, y1, x2, y2);
ladanyi@1
   218
            coos.push_back(Gnome::Art::Point((x1+x2)/2,(y1+y2)/2));
ladanyi@1
   219
ladanyi@1
   220
            edgesmap[e]->property_points().set_value(coos);
ladanyi@1
   221
ladanyi@1
   222
	    edgesmap[e]->get_bounds(x1, y1, x2, y2);
ladanyi@1
   223
ladanyi@1
   224
	    edgetextmap[e]->property_x().set_value((x1+x2)/2);
ladanyi@1
   225
	    edgetextmap[e]->property_y().set_value((y1+y2)/2);
ladanyi@1
   226
        }
ladanyi@1
   227
ladanyi@1
   228
        g.firstIn(e,n);
ladanyi@1
   229
        for(;e!=INVALID;g.nextIn(e))
ladanyi@1
   230
        {
ladanyi@1
   231
            Gnome::Canvas::Points coos;
ladanyi@1
   232
            double x1, x2, y1, y2;
ladanyi@1
   233
ladanyi@1
   234
            nodesmap[g.source(e)]->get_bounds(x1, y1, x2, y2);
ladanyi@1
   235
            coos.push_back(Gnome::Art::Point((x1+x2)/2,(y1+y2)/2));
ladanyi@1
   236
ladanyi@1
   237
            nodesmap[g.target(e)]->get_bounds(x1, y1, x2, y2);
ladanyi@1
   238
            coos.push_back(Gnome::Art::Point((x1+x2)/2,(y1+y2)/2));
ladanyi@1
   239
ladanyi@1
   240
            edgesmap[e]->property_points().set_value(coos);
ladanyi@1
   241
ladanyi@1
   242
	    edgesmap[e]->get_bounds(x1, y1, x2, y2);
ladanyi@1
   243
ladanyi@1
   244
	    edgetextmap[e]->property_x().set_value((x1+x2)/2);
ladanyi@1
   245
	    edgetextmap[e]->property_y().set_value((y1+y2)/2);
ladanyi@1
   246
        }
ladanyi@1
   247
      }
ladanyi@1
   248
    default: break;
ladanyi@1
   249
  }
ladanyi@1
   250
  return true;
ladanyi@1
   251
}
ladanyi@1
   252
ladanyi@1
   253
bool GraphDisplayerCanvas::on_expose_event(GdkEventExpose *event)
ladanyi@1
   254
{
ladanyi@1
   255
  Gnome::Canvas::CanvasAA::on_expose_event(event);
ladanyi@1
   256
  //usleep(10000);
ladanyi@1
   257
  //rezoom();
ladanyi@1
   258
  return true;
ladanyi@1
   259
}