First shot at panFrame, which frames how far you can pan outside the graph's visible...
[dygraphs.git] / tests / zoom.html
index 10b0457..c0de5c1 100644 (file)
       <input type="button" value="Y (2,4)" onclick="zoomGraphY(2,4)">&nbsp;
       <input type="button" value="Y (0,2)" onclick="zoomGraphY(0,2)">&nbsp;
       <input type="button" value="Y (0,1)" onclick="zoomGraphY(0,1)">&nbsp;
-      <br>
+      <br> <br>
       <input type="button" value="Oct 8-13" onclick="zoomGraphX(1160261979962, 1163905694248)">&nbsp;
       <input type="button" value="Oct 22-28" onclick="zoomGraphX(1161489164461 , 1162008465957)">&nbsp;
       <input type="button" value="Oct 23-24" onclick="zoomGraphX(1161575878860, 1161660991675)">&nbsp;
       <input type="button" value="Oct 26 6AM-noon" onclick="zoomGraphX(1161770537840, 1161792063332)">&nbsp;
-      <br>
+      <br> <br>
       <input type="button" value="Unzoom" onclick="unzoomGraph()">&nbsp;
+      <br> <br>
+      <input type="button" value="pan frame 0" onclick="panFrame(0)">&nbsp;
+      <input type="button" value="pan frame 0.1" onclick="panFrame(0.1)">&nbsp;
+      <input type="button" value="pan frame 0.5" onclick="panFrame(0.5)">&nbsp;
       </p>
 
 
@@ -40,8 +44,8 @@
             document.getElementById("div_g"),
             NoisyData, {
               errorBars: true,
-              zoomCallback : function(minDate, maxDate, yRange) {
-                showDimensions(minDate, maxDate, yRange);
+              zoomCallback : function(minDate, maxDate, yRanges) {
+                showDimensions(minDate, maxDate, yRanges);
               }
             }
           );
       // Pull an initial value for logging.
       var minDate = g.xAxisRange()[0];
       var maxDate = g.xAxisRange()[1];
-      var minValue = g.yAxisRange();
-      showDimensions(minDate, maxDate, yAxisRange);
+      var minValue = g.yAxisRange()[0];
+      var maxValue = g.yAxisRange()[1];
+      showDimensions(minDate, maxDate, [minValue, maxValue]);
 
-      function showDimensions(minDate, maxDate, yAxisRange) {
+      function showDimensions(minDate, maxDate, yRanges) {
         showXDimensions(minDate, maxDate);
-        showYDimensions(yAxisRange);
+        showYDimensions(yRanges);
       }
 
       function showXDimensions(first, second) {
@@ -65,9 +70,9 @@
         elem.innerHTML = "dateWindow : [" + first + ", "+ second + "]";
       }
 
-      function showYDimensions(range) {
+      function showYDimensions(ranges) {
         var elem = document.getElementById("ydimensions");
-        elem.innerHTML = "valueRange : [" + range + "]";
+        elem.innerHTML = "valueRange : [" + ranges + "]";
       }
 
       function zoomGraphX(minDate, maxDate) {
@@ -81,7 +86,7 @@
         g.updateOptions({
           valueRange: [minValue, maxValue]
         });
-        showYDimensions(minValue, maxValue);
+        showYDimensions(g.yAxisRanges());
       }
 
       function unzoomGraph() {
           valueRange: null
         });
       }
+
+      function panFrame(value) {
+        g.updateOptions({ panFrame : value });
+      }
     </script>
 
   </body>