|
1 <!DOCTYPE html> |
|
2 <html> |
|
3 <head> |
|
4 <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> |
|
5 <title>Zoom + Pan</title> |
|
6 <script type="text/javascript" src="../../d3.js"></script> |
|
7 <style type="text/css"> |
|
8 |
|
9 svg { |
|
10 font: 10px sans-serif; |
|
11 shape-rendering: crispEdges; |
|
12 } |
|
13 |
|
14 </style> |
|
15 </head> |
|
16 <body> |
|
17 <script type="text/javascript"> |
|
18 |
|
19 var size = [710, 500], // width height |
|
20 padding = [4, 4, 20, 40], // top right bottom left |
|
21 tx = function(d) { return "translate(" + x(d) + ",0)"; }, |
|
22 ty = function(d) { return "translate(0," + y(d) + ")"; }, |
|
23 stroke = function(d) { return d ? "#ccc" : "#666"; }; |
|
24 |
|
25 // x-scale (1.42 = 710/500) |
|
26 var x = d3.scale.linear() |
|
27 .domain([-1.42, +1.42]) |
|
28 .range([0, size[0]]); |
|
29 |
|
30 // y-scale (inverted domain) |
|
31 var y = d3.scale.linear() |
|
32 .domain([+1.00, -1.00]) |
|
33 .range([0, size[1]]); |
|
34 |
|
35 var svg = d3.select("body").append("svg:svg") |
|
36 .attr("width", size[0] + padding[3] + padding[1]) |
|
37 .attr("height", size[1] + padding[0] + padding[2]) |
|
38 .attr("pointer-events", "all") |
|
39 .append("svg:g") |
|
40 .attr("transform", "translate(" + padding[3] + "," + padding[0] + ")") |
|
41 .call(d3.behavior.zoom() |
|
42 .extent([[0, size[0]], [0, size[1]], [0, Infinity]]) |
|
43 .on("zoom", redraw)) |
|
44 .append("svg:g"); |
|
45 |
|
46 // Generate x-ticks… |
|
47 var gx = svg.selectAll("g.x") |
|
48 .data(x.ticks(10)) |
|
49 .enter().append("svg:g") |
|
50 .attr("class", "x") |
|
51 .attr("transform", tx); |
|
52 |
|
53 gx.append("svg:line") |
|
54 .attr("stroke", stroke) |
|
55 .attr("y1", 0) |
|
56 .attr("y2", size[1]); |
|
57 |
|
58 gx.append("svg:text") |
|
59 .attr("y", size[1]) |
|
60 .attr("dy", "1em") |
|
61 .attr("text-anchor", "middle") |
|
62 .text(x.tickFormat(10)); |
|
63 |
|
64 // Generate y-ticks… |
|
65 var gy = svg.selectAll("g.y") |
|
66 .data(y.ticks(10)) |
|
67 .enter().append("svg:g") |
|
68 .attr("class", "y") |
|
69 .attr("transform", ty); |
|
70 |
|
71 gy.append("svg:line") |
|
72 .attr("stroke", stroke) |
|
73 .attr("x1", 0) |
|
74 .attr("x2", size[0]); |
|
75 |
|
76 gy.append("svg:text") |
|
77 .attr("x", -3) |
|
78 .attr("dy", ".35em") |
|
79 .attr("text-anchor", "end") |
|
80 .text(y.tickFormat(10)); |
|
81 |
|
82 svg.append("svg:rect") |
|
83 .attr("width", size[0]) |
|
84 .attr("height", size[1]) |
|
85 .attr("stroke", stroke) |
|
86 .attr("fill", "none"); |
|
87 |
|
88 function redraw() { |
|
89 svg.attr("transform", |
|
90 "translate(" + d3.event.translate + ")" |
|
91 + "scale(" + d3.event.scale + ")"); |
|
92 } |
|
93 |
|
94 </script> |
|
95 </body> |
|
96 </html> |