zooming should really work now gui
authorladanyi
Fri, 03 Jun 2005 12:25:23 +0000
branchgui
changeset 76a9399f56813
parent 6 603b85626bc0
child 8 abac0179a26a
zooming should really work now
graph_displayer_canvas.cc
     1.1 --- a/graph_displayer_canvas.cc	Wed Jun 01 23:33:26 2005 +0000
     1.2 +++ b/graph_displayer_canvas.cc	Fri Jun 03 12:25:23 2005 +0000
     1.3 @@ -190,6 +190,7 @@
     1.4      case GDK_BUTTON_RELEASE:
     1.5        isbutton=false;
     1.6        active_item=NULL;
     1.7 +      updateScrollRegion();
     1.8        break;
     1.9      case GDK_MOTION_NOTIFY:
    1.10        //we only have to do sg. if the mouse button is pressed
    1.11 @@ -283,25 +284,16 @@
    1.12    // add some space
    1.13    aw -= 5; if (aw < 0) aw = 0;
    1.14    ah -= 5; if (ah < 0) ah = 0;
    1.15 -  //std::cout << "aw=" << aw << " ah=" << ah << std::endl;
    1.16  
    1.17    // get the bounding box of the graph
    1.18 -  set_pixels_per_unit(1.0); // I don't really understand why this is necessary
    1.19    double wx1, wy1, wx2, wy2;
    1.20 -  double cx1, cy1, cx2, cy2;
    1.21    Gnome::Canvas::Item* pCanvasItem = root();
    1.22    pCanvasItem->get_bounds(wx1, wy1, wx2, wy2);
    1.23 -  //std::cout << "root bounds: " << wx1 << " " << wy1 << " " << wx2 << " " << wy2 << std::endl;
    1.24 -  w2c(wx1, wy1, cx1, cy1);
    1.25 -  w2c(wx2, wy2, cx2, cy2);
    1.26 -  //std::cout << "root bounds (c): " << cx1 << " " << cy1 << " " << cx2 << " " << cy2 << std::endl;
    1.27 -  //std::cout << "cx2 - cx1=" << fabs(cx2 - cx1) << " cy2 - cy1=" << fabs(cy2 - cy1) << std::endl;
    1.28  
    1.29    // fit the graph to the window
    1.30 -  double ppu1 = (double) aw / fabs(cx2 - cx1);
    1.31 -  double ppu2 = (double) ah / fabs(cy2 - cy1);
    1.32 -  //std::cout << "ppu1=" << ppu1 << " ppu2=" << ppu2 << std::endl;
    1.33 -  (ppu1 < ppu2) ? set_pixels_per_unit(ppu1) : set_pixels_per_unit(ppu2);
    1.34 +  double ppu1 = (double) aw / fabs(wx2 - wx1);
    1.35 +  double ppu2 = (double) ah / fabs(wy2 - wy1);
    1.36 +  set_pixels_per_unit((ppu1 < ppu2) ? ppu1 : ppu2);
    1.37  }
    1.38  
    1.39  void GraphDisplayerCanvas::zoom100()
    1.40 @@ -312,10 +304,7 @@
    1.41  void GraphDisplayerCanvas::updateScrollRegion()
    1.42  {
    1.43    double wx1, wy1, wx2, wy2;
    1.44 -  int cx1, cy1, cx2, cy2;
    1.45    Gnome::Canvas::Item* pCanvasItem = root();
    1.46    pCanvasItem->get_bounds(wx1, wy1, wx2, wy2);
    1.47 -  w2c(wx1, wy1, cx1, cy1);
    1.48 -  w2c(wx2, wy2, cx2, cy2);
    1.49 -  set_scroll_region(cx1, cy1, cx2, cy2);
    1.50 +  set_scroll_region(wx1, wy1, wx2, wy2);
    1.51  }