Can I use zoom.translateBy to set an initial pan?

前端 未结 2 1987
无人及你
无人及你 2021-01-05 19:18

I\'ve got something like

zoomable
  .call(d3.zoom()
    .scaleExtent([1, Infinity])
    .translateExtent([[0, 0], [width, height]])
    .on(\'zoom\', handleZ         


        
2条回答
  •  陌清茗
    陌清茗 (楼主)
    2021-01-05 19:39

    And this is how you would apply relative translations and zoom afterwords, in this example I am using Mousetrap to attach keyboard events to allow zooming and panning.

    transform = d3.zoomTransform(zoomable.node());
    
    Mousetrap.bind(['=', '+', 'pageup'], function() {
        zoomable.call(zoom).call(zoom.scaleTo, transform.k << 1);
    });
    Mousetrap.bind(['-', 'pagedown'], function() {
        zoomable.call(zoom).call(zoom.scaleTo, transform.k >> 1);
    });
    
    Mousetrap.bind(['down'], function() {
        zoomable
            .call(zoom)
            .call(zoom.translateBy, 
                0, // / transform.k, 
                -50 / transform.k
            ); 
    });
    Mousetrap.bind(['up'], function() {
        zoomable
            .call(zoom)
            .call(zoom.translateBy, 
                0,
                +50 / transform.k
            ); 
    });
    Mousetrap.bind(['left'], function() {
        zoomable
            .call(zoom)
            .call(zoom.translateBy, 
                +50 / transform.k, 
                0
            ); 
    });
    Mousetrap.bind(['right'], function() {
        zoomable
            .call(zoom)
            .call(zoom.translateBy, 
                -50 / transform.k, 
                0
            ); 
    });
    

提交回复
热议问题