I did a small example of what i am trying to implement, here it is - https://jsfiddle.net/zeleniy/4sgqgcx0/. You can zoom and pan SVG image as usual. But i have no idea how to implement zoom programmatically when user click on "+" and "-" buttons. Especially if he already zoom in/out and pan original image. Could you help me?
On line 13 of the code you will find zoom event handler.
var zoom = d3.zoom()
    .on('zoom', function() {
        canvas.attr('transform', d3.event.transform);
    });
On lines 35 and 39 - zoom event handlers
d3.select('#zoom-in').on('click', function() {
    // what here?
});
d3.select('#zoom-out').on('click', function() {
    // what here?
});
So when user click on "+" app should zoom in as if mouse were at the center of SVG element. And the same with "-".
来源:https://stackoverflow.com/questions/42612798/d3-js-v4-programmatic-panzoom-how