Browse Source

move mouse wheel zoom from sample file to c3ext.js code

pull/310/head
danelkhen 11 years ago
parent
commit
785eb25456
  1. 61
      c3ext.js
  2. 54
      htdocs/js/samples/zoom2.js

61
c3ext.js

@ -35,7 +35,7 @@ c3ext.generate = function (options) {
refresh(); refresh();
} }
var zoom2 = ZoomBehavior.create({ changed: onZoomChanged }); var zoom2 = ZoomBehavior.create({ changed: onZoomChanged, bindto:options.bindto });
zoom2.enhance = function () { zoom2.enhance = function () {
_zoom2_maxItems *= 2; _zoom2_maxItems *= 2;
@ -49,7 +49,7 @@ c3ext.generate = function (options) {
refresh(); refresh();
} }
zoom2.maxItems = function(){return _zoom2_maxItems;}; zoom2.maxItems = function () { return _zoom2_maxItems; };
function zoomAndReduceData(list, zoomRange, func, maxItems) { function zoomAndReduceData(list, zoomRange, func, maxItems) {
//var maxItems = 10;//Math.ceil(10 * zoomFactor); //var maxItems = 10;//Math.ceil(10 * zoomFactor);
var list2 = list.slice(zoomRange[0], zoomRange[1]); var list2 = list.slice(zoomRange[0], zoomRange[1]);
@ -124,7 +124,13 @@ ZoomBehavior.create = function (options) {
var _left; var _left;
var totalItems; var totalItems;
var currentZoom; var currentZoom;
var bindto = options.bindto;
var _zoomChanged = options.changed || function () { }; var _zoomChanged = options.changed || function () { };
var element;
var mousewheelTimer;
var deltaY = 0;
var leftRatio = 0;
zoom.setOptions = function (options) { zoom.setOptions = function (options) {
if (options == null) if (options == null)
@ -188,7 +194,7 @@ ZoomBehavior.create = function (options) {
_zoom2_factor = factor; _zoom2_factor = factor;
if (_zoom2_factor < 1) if (_zoom2_factor < 1)
_zoom2_factor = 1; _zoom2_factor = 1;
if(skipDraw) if (skipDraw)
return; return;
applyZoomAndPan(); applyZoomAndPan();
} }
@ -202,8 +208,8 @@ ZoomBehavior.create = function (options) {
//_left += pageSize; //_left += pageSize;
if (_left + pageSize > totalItems) if (_left + pageSize > totalItems)
_left = totalItems - pageSize; _left = totalItems - pageSize;
console.log({left:_left, pageSize:pageSize}); console.log({ left: _left, pageSize: pageSize });
if(skipDraw) if (skipDraw)
return; return;
applyZoomAndPan(); applyZoomAndPan();
} }
@ -211,22 +217,22 @@ ZoomBehavior.create = function (options) {
zoom.zoomAndPanByRatio = function (zoomRatio, panRatio) { zoom.zoomAndPanByRatio = function (zoomRatio, panRatio) {
var pageSize = getItemsToShow(); var pageSize = getItemsToShow();
var leftOffset = Math.round(pageSize*panRatio); var leftOffset = Math.round(pageSize * panRatio);
var mouseLeft = _left+leftOffset; var mouseLeft = _left + leftOffset;
zoom.factor(zoom.factor()*zoomRatio, true); zoom.factor(zoom.factor() * zoomRatio, true);
var finalLeft = mouseLeft; var finalLeft = mouseLeft;
if(zoomRatio!=1){ if (zoomRatio != 1) {
var pageSize2 = getItemsToShow(); var pageSize2 = getItemsToShow();
var leftOffset2 = Math.round(pageSize2*panRatio); var leftOffset2 = Math.round(pageSize2 * panRatio);
var finalLeft = mouseLeft-leftOffset2; finalLeft = mouseLeft - leftOffset2;
} }
zoom.left(finalLeft, true); zoom.left(finalLeft, true);
applyZoomAndPan(); applyZoomAndPan();
} }
zoom.zoomIn = function () { zoom.zoomIn = function () {
zoom.zoomAndPanByRatio(2,0); zoom.zoomAndPanByRatio(2, 0);
} }
zoom.zoomOut = function () { zoom.zoomOut = function () {
@ -245,6 +251,37 @@ ZoomBehavior.create = function (options) {
_zoom2_factor = 1; _zoom2_factor = 1;
applyZoomAndPan(); applyZoomAndPan();
} }
function doZoom() {
if (deltaY != 0) {
var maxDelta = 10;
var multiply = (maxDelta + deltaY) / maxDelta;
//var factor = chart.zoom2.factor()*multiply;
//factor= Math.ceil(factor*100) / 100;
console.log({ deltaY: deltaY, multiply: multiply });
zoom.zoomAndPanByRatio(multiply, leftRatio);//0.5);//leftRatio);
deltaY = 0;
}
}
function element_mousewheel(e) {
deltaY += e.deltaY;
leftRatio = (e.offsetX - 70) / (e.currentTarget.offsetWidth - 70);
//console.log({ "e.offsetX": e.offsetX, "e.currentTarget.offsetWidth": e.currentTarget.offsetWidth, leftRatio: leftRatio });
mousewheelTimer.set(150);
e.preventDefault();
}
if (bindto != null) {
element = $(options.bindto);
if (element.mousewheel) {
mousewheelTimer = new Timer(doZoom);
element.mousewheel(element_mousewheel);
}
}
return zoom; return zoom;
} }

54
htdocs/js/samples/zoom2.js

@ -46,22 +46,22 @@ function main() {
chart = c3ext.generate(options); chart = c3ext.generate(options);
var deltaY = 0; //var deltaY = 0;
var leftRatio = 0; //var leftRatio = 0;
var el = $("#divChart"); //var el = $("#divChart");
var timer = new Timer(doZoom); //var timer = new Timer(doZoom);
el.mousewheel(function (e) { //el.mousewheel(function (e) {
deltaY += e.deltaY; // deltaY += e.deltaY;
leftRatio = (e.offsetX - 70) / (e.currentTarget.offsetWidth - 70); // leftRatio = (e.offsetX - 70) / (e.currentTarget.offsetWidth - 70);
console.log({ "e.offsetX": e.offsetX, "e.currentTarget.offsetWidth": e.currentTarget.offsetWidth, leftRatio: leftRatio }); // console.log({ "e.offsetX": e.offsetX, "e.currentTarget.offsetWidth": e.currentTarget.offsetWidth, leftRatio: leftRatio });
timer.set(150); // timer.set(150);
e.preventDefault(); // e.preventDefault();
//if(e.deltaY>0) // //if(e.deltaY>0)
// chart.zoom2.zoomIn(); // // chart.zoom2.zoomIn();
//else if(e.deltaY<0) // //else if(e.deltaY<0)
// chart.zoom2.zoomOut(); // // chart.zoom2.zoomOut();
//console.log(e.deltaX, e.deltaY, e.deltaFactor); // //console.log(e.deltaX, e.deltaY, e.deltaFactor);
}); //});
window.setInterval(refreshStatus, 1000); window.setInterval(refreshStatus, 1000);
@ -75,17 +75,17 @@ function main() {
}; };
$("#status").text(JSON.stringify(info, null, " ")); $("#status").text(JSON.stringify(info, null, " "));
} }
function doZoom() { //function doZoom() {
if (deltaY != 0) { // if (deltaY != 0) {
var maxDelta = 10; // var maxDelta = 10;
var multiply = (maxDelta + deltaY) / maxDelta; // var multiply = (maxDelta + deltaY) / maxDelta;
//var factor = chart.zoom2.factor()*multiply; // //var factor = chart.zoom2.factor()*multiply;
//factor= Math.ceil(factor*100) / 100; // //factor= Math.ceil(factor*100) / 100;
console.log({ deltaY: deltaY, multiply: multiply }); // console.log({ deltaY: deltaY, multiply: multiply });
chart.zoom2.zoomAndPanByRatio(multiply, leftRatio);//0.5);//leftRatio); // chart.zoom2.zoomAndPanByRatio(multiply, leftRatio);//0.5);//leftRatio);
deltaY = 0; // deltaY = 0;
} // }
} //}
}; };

Loading…
Cancel
Save