在 Highstock 中重置/设置 ZoomType 控制

发布于 2025-01-06 07:37:08 字数 281 浏览 0 评论 0原文

我正在使用 highcharts api 在我的应用程序中开发图表。我正在使用 highcharts 中的 highstack 类。

我正在寻找的是我想处理外部按钮的缩放控制。

例如,有一个像缩放这样的单选按钮(是,否),如果我们选择“是”,那么缩放功能应该在我的图表中启用。如果未选择,则应禁用缩放功能。

我尝试过以下属性:

zoomType: 'xy'

我尝试重置上述属性,但失败了。

请给我任何建议来解决这个问题。

提前致谢..

I am using highcharts api to develop charts in my application. I am using highstack class from highcharts.

What I am looking is I want handle the zoom controls from external buttons.

for example there is a radio button like zoom (yes, no), if we select yes then zoom functionality should be enable in my chart. If no selected then zoom functionality should be disabled.

I have tried with following property:

zoomType: 'xy'

I have tried to reset the above property, but failed.

Please give me any suggestion to fix this issue.

Thanks in advance..

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

等风来 2025-01-13 07:37:08

那么,您可以使用以下代码删除 mousedown 处理程序:chart.container.onmousedown。这不是最好的解决方案(当使用触摸事件时我还没有在移动设备上测试过这个),但无论如何它是一个很好的起点。

在这里您可以找到实时演示: http://jsfiddle.net/3qYAZ 以及该演示的代码:

window.chart = new Highcharts.Chart({

    chart: {
        renderTo: 'container',
        zoomType: 'x'
    },

    series: [{
        data: [29.9, 71.5, 106.4, 129.2, 144.0, 176.0, 135.6, 148.5, 216.4, 194.1, 95.6, 54.4]
    }]

}, function (chart) {

    var checkbox = $('#zoom'), // a checkbox input in your html
        zoomHandler = chart.container.onmousedown;

    checkbox.on('change', function () {
        if (this.checked)
            chart.container.onmousedown = zoomHandler;
        else
            chart.container.onmousedown = null;
    });
});

Well, you can just remove mousedown handler with the following code: chart.container.onmousedown. It's not the best solution (and I haven't tested this on mobile when touch events are used), but anyway it's a good starting point.

Here you can find live demo: http://jsfiddle.net/3qYAZ and that demo's code:

window.chart = new Highcharts.Chart({

    chart: {
        renderTo: 'container',
        zoomType: 'x'
    },

    series: [{
        data: [29.9, 71.5, 106.4, 129.2, 144.0, 176.0, 135.6, 148.5, 216.4, 194.1, 95.6, 54.4]
    }]

}, function (chart) {

    var checkbox = $('#zoom'), // a checkbox input in your html
        zoomHandler = chart.container.onmousedown;

    checkbox.on('change', function () {
        if (this.checked)
            chart.container.onmousedown = zoomHandler;
        else
            chart.container.onmousedown = null;
    });
});
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文