D3
OG
Old school D3 from simpler times
All examples
By author
By category
About
mhsmith
Full window
Github gist
Pan+Zoom within limits (discontinuous and log scales)
<!DOCTYPE html> <meta charset="utf-8"> <title>Pan+Zoom within limits (discontinuous and log scales)</title> <style> svg { font: 10px sans-serif; shape-rendering: crispEdges; } rect { fill: #ddd; } .axis path, .axis line { fill: none; stroke: #fff; } </style> <body> <script src="d3-pan-zoom-extent.js"></script> <script> var margin = {top: 20, right: 20, bottom: 30, left: 40}, width = 960 - margin.left - margin.right, height = 500 - margin.top - margin.bottom; var x = d3.scale.linear() .domain([-10, 0, 100]) .range([0, width/2, width]); var y = d3.scale.log() .domain([1,height]) .range([height, 0]); var xAxis = d3.svg.axis() .scale(x) .orient("bottom") .tickSize(-height); var yAxis = d3.svg.axis() .scale(y) .orient("left") .ticks(5) .tickSize(-width); var zoom = d3.behavior.zoom() .x(x) .xExtent([-50,500]) .y(y) .yExtent([0.1,1500]) .scaleExtent([0.1, 10]) .on("zoom", zoomed); var svg = d3.select("body").append("svg") .attr("width", width + margin.left + margin.right) .attr("height", height + margin.top + margin.bottom) .append("g") .attr("transform", "translate(" + margin.left + "," + margin.top + ")") .call(zoom); svg.append("rect") .attr("width", width) .attr("height", height); svg.append("g") .attr("class", "x axis") .attr("transform", "translate(0," + height + ")") .call(xAxis); svg.append("g") .attr("class", "y axis") .call(yAxis); function zoomed() { svg.select(".x.axis").call(xAxis); svg.select(".y.axis").call(yAxis); } </script>