graph_displayer_canvas-edge.cc
author hegyi
Mon, 25 Jul 2005 11:17:23 +0000
branchgui
changeset 38 9cab23d9b124
parent 35 79bffdf6aea2
child 40 cebacea4f965
permissions -rwxr-xr-x
Continuing adding new maps.
     1 #include <graph_displayer_canvas.h>
     2 #include <broken_edge.h>
     3 #include <math.h>
     4 
     5 
     6 int GraphDisplayerCanvas::changeEdgeWidth (std::string mapname, Graph::Edge edge)
     7 {
     8   Graph::EdgeMap<double> * actual_map;
     9   if(mapname=="Default")
    10     {
    11       actual_map=new Graph::EdgeMap<double>(g,edge_property_defaults[E_WIDTH]);
    12     }
    13   else
    14     {
    15       actual_map=(mapstorage.edgemap_storage)[mapname];
    16     }
    17 
    18   if(edge==INVALID)
    19     {
    20       for (EdgeIt i(g); i!=INVALID; ++i)
    21 	{
    22 	  int w=(int)(*actual_map)[i];
    23 	  if(w>=0)
    24 	    {
    25 	      edgesmap[i]->property_width_pixels().set_value(w);
    26 	    }
    27 	}
    28     }
    29   else
    30     {
    31       int w=(int)(*actual_map)[edge];
    32       if(w>=0)
    33 	{
    34 	  edgesmap[edge]->property_width_pixels().set_value(w);
    35 	}
    36     }
    37   return 0;
    38 };
    39 
    40 int GraphDisplayerCanvas::changeEdgeColor (std::string mapname, Graph::Edge edge)
    41 {  
    42 
    43   //function maps the range of the maximum and
    44   //the minimum of the nodemap to the range of
    45   //green in RGB
    46   Graph::EdgeMap<double> * actual_map;
    47   if(mapname=="Default")
    48     {
    49       actual_map=new Graph::EdgeMap<double>(g,edge_property_defaults[E_COLOR]);
    50     }
    51   else
    52     {
    53       actual_map=(mapstorage.edgemap_storage)[mapname];
    54     }
    55 
    56   double max, min;
    57 
    58   if(mapname!="Default")
    59     {
    60       max=mapstorage.maxOfEdgeMap(mapname);
    61       min=mapstorage.minOfEdgeMap(mapname);
    62     }
    63   else
    64     {
    65       max=edge_property_defaults[E_COLOR];
    66       min=edge_property_defaults[E_COLOR];
    67     }
    68 
    69   if(edge==INVALID)
    70     {
    71       for (EdgeIt i(g); i!=INVALID; ++i)
    72 	{
    73 	  double w=(*actual_map)[i];
    74 
    75 	  Gdk::Color color;
    76 	  if(max!=min)
    77 	    {
    78 	      color.set_rgb_p (0, 100*(w-min)/(max-min), 0);
    79 	    }
    80 	  else
    81 	    {
    82 	      color.set_rgb_p (0, 100, 0);
    83 	    }
    84 	  edgesmap[i]->property_fill_color_gdk().set_value(color);
    85 	}
    86     }
    87   else
    88     {
    89       Gdk::Color color;
    90 
    91       double w=(*actual_map)[edge];
    92 
    93       if(max!=min)
    94 	{
    95 	  color.set_rgb_p (0, 100*(w-min)/(max-min), 0);
    96 	}
    97       else
    98 	{
    99 	  color.set_rgb_p (0, 100, 0);
   100 	}
   101 
   102       edgesmap[edge]->property_fill_color_gdk().set_value(color);
   103     }
   104   return 0;
   105 };
   106 
   107 int GraphDisplayerCanvas::changeEdgeText (std::string mapname, Graph::Edge edge)
   108 {
   109 
   110   //the number in the map will be written on the edge
   111   //EXCEPT when the name of the map is Text, because
   112   //in that case empty string will be written, because
   113   //that is the deleter map
   114 
   115   if(edge==INVALID)
   116     {
   117       for (EdgeIt i(g); i!=INVALID; ++i)
   118 	{
   119 	  if(mapname!="Default")
   120 	    {
   121 	      edgemap_to_edit=mapname;
   122 	      double number=(*(mapstorage.edgemap_storage)[mapname])[i];
   123 	      int length=1;
   124 	      //if number is smaller than one, length would be negative, or invalid
   125 	      if(number>=1)
   126 		{
   127 		  length=(int)(floor(log(number)/log(10)))+1;
   128 		}
   129 	      int maxpos=(int)(pow(10,length-1));
   130 	      int strl=length+1+RANGE;
   131 	      char * str=new char[strl];
   132 	      str[length]='.';
   133 	      str[strl]='\0';
   134       
   135 	      for(int j=0;j<strl;j++)
   136 		{
   137 		  if(j!=length)
   138 		    {
   139 		      if((number-(int)number)>ALMOST_ONE)
   140 			{
   141 			  number=round(number);
   142 			}
   143 		      int digit=(int)(number/maxpos);
   144 		      str[j]=(digit+'0');
   145 		      number-=digit*maxpos;
   146 		      number*=10;
   147 		    }
   148 		}
   149       
   150 	      edgetextmap[i]->property_text().set_value(str);
   151 	    }
   152 	  else
   153 	    {
   154 	      edgemap_to_edit="";
   155 	      edgetextmap[i]->property_text().set_value("");
   156 	    }
   157 	}
   158 
   159     }
   160   else
   161     {
   162       if(mapname!="Default")
   163 	{
   164 	  double number=(*(mapstorage.edgemap_storage)[mapname])[edge];
   165 	  int length=1;
   166 	  //if number is smaller than one, length would be negative, or invalid
   167 	  if(number>=1)
   168 	    {
   169 	      length=(int)(floor(log(number)/log(10)))+1;
   170 	    }
   171 	  int maxpos=(int)(pow(10,length-1));
   172 	  int strl=length+1+RANGE;
   173 	  char * str=new char[strl];
   174 	  str[length]='.';
   175 	  str[strl]='\0';
   176       
   177 	  for(int j=0;j<strl;j++)
   178 	    {
   179 	      if(j!=length)
   180 		{
   181 		  if((number-(int)number)>ALMOST_ONE)
   182 		    {
   183 		      number=round(number);
   184 		    }
   185 		  int digit=(int)(number/maxpos);
   186 		  str[j]=(digit+'0');
   187 		  number-=digit*maxpos;
   188 		  number*=10;
   189 		}
   190 	    }
   191       
   192 	  edgetextmap[edge]->property_text().set_value(str);
   193 	}
   194       else
   195 	{
   196 	  edgetextmap[edge]->property_text().set_value("");
   197 	}
   198 	  
   199     }
   200 
   201   return 0;
   202 
   203 };