Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
bokeh / server / static / js / lib / core / util / zoom.js
Size: Mime:
import { clamp } from "./math";
// Module for zoom-related functions
export function scale_highlow(range, factor, center) {
    const [low, high] = [range.start, range.end];
    const x = center != null ? center : (high + low) / 2.0;
    const x0 = low - (low - x) * factor;
    const x1 = high - (high - x) * factor;
    return [x0, x1];
}
export function get_info(scales, [sxy0, sxy1]) {
    const info = new Map();
    for (const [name, scale] of scales) {
        const [start, end] = scale.r_invert(sxy0, sxy1);
        info.set(name, { start, end });
    }
    return info;
}
export function scale_range(frame, factor, h_axis = true, v_axis = true, center) {
    /*
     * Utility function for zoom tools to calculate/create the zoom_info object
     * of the form required by ``PlotView.update_range``
     *
     * Parameters:
     *   frame : CartesianFrame
     *   factor : Number
     *   h_axis : Boolean, optional
     *     whether to zoom the horizontal axis (default = true)
     *   v_axis : Boolean, optional
     *     whether to zoom the horizontal axis (default = true)
     *   center : object, optional
     *     of form {'x': Number, 'y', Number}
     *
     * Returns:
     *   object:
     */
    // clamp the  magnitude of factor, if it is > 1 bad things happen
    factor = clamp(factor, -0.9, 0.9);
    const hfactor = h_axis ? factor : 0;
    const [sx0, sx1] = scale_highlow(frame.bbox.h_range, hfactor, center != null ? center.x : undefined);
    const xrs = get_info(frame.x_scales, [sx0, sx1]);
    const vfactor = v_axis ? factor : 0;
    const [sy0, sy1] = scale_highlow(frame.bbox.v_range, vfactor, center != null ? center.y : undefined);
    const yrs = get_info(frame.y_scales, [sy0, sy1]);
    // OK this sucks we can't set factor independently in each direction. It is used
    // for GMap plots, and GMap plots always preserve aspect, so effective the value
    // of 'dimensions' is ignored.
    return { xrs, yrs, factor };
}
//# sourceMappingURL=zoom.js.map