半岛权威十大直营(官方)网站

高性能图表控件LightningChart对数轴-更多刻度线问题解答

翻译|使用教程|编辑:杨鹏连|2021-02-07 10:33:03.927|阅读 135 次

概述:本文主要介绍了高性能图表控件LightningChart对数轴-更多刻度线问题解答。

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

相关链接:

LightningChart.NET完全由GPU加速,并且性能经过优化,可用于实时显示海量数据-超过10亿个数据点。 LightningChart包括广泛的2D,高级3D,Polar,Smith,3D饼/甜甜圈,地理地图和GIS图表以及适用于科学,工程,医学,航空,贸易,能源和其他领域的体绘制功能。

LightningChart.NET现已加入在线订购,SignalTools , 12 months, WPF版本原价4105元,现价只需3499元,现在抢购立享优惠!立即购买>>

点击下载LightningChart.NET最新试用版

问题:对数轴-更多刻度线?

我正在努力实现在我的应用中查看对数X轴的功能。除一种情况外,它通常都能按预期工作:

当您没有大量数据时,轴不会显示太多信息。例如,给定x值为177-8000(带有18个点),对数轴如下所示:

除了一个标签,我有什么方法可以强制执行?我知道它只想标记1,10,100,1000,但有时在只有1个标签的情况下,我想添加更多标签。

回复:对数轴-更多的刻度线?

当ScaleType设置为Logarithmic时,将根据轴的LogBase设置自动计算轴标签。LogBase = 10会导致1、10、100、1000等。当前无法禁用此行为。

如果要显示更多的报价,可以使用CustomTicks。这些允许您在任意位置手动设置任意数量的刻度。启用CustomTicks会隐藏原始刻度。

            // Adding CustomTicks
            axisX.CustomTicks.Add(new CustomAxisTick(axisX, 800, "800", 10, true, Color.White, CustomTickStyle.TickAndGrid));
            axisX.CustomTicks.Add(new CustomAxisTick(axisX, 900, "900", 10, true, Color.White, CustomTickStyle.TickAndGrid));
            axisX.CustomTicks.Add(new CustomAxisTick(axisX, 1000, "1000", 10, true, Color.White, CustomTickStyle.TickAndGrid));
            axisX.CustomTicks.Add(new CustomAxisTick(axisX, 1100, "1100", 10, true, Color.White, CustomTickStyle.TickAndGrid));
            axisX.CustomTicks.Add(new CustomAxisTick(axisX, 1200, "1200", 10, true, Color.White, CustomTickStyle.TickAndGrid));
添加CustomTicks不会自动显示它们。您必须将轴的CustomTicksEnabled设置为true。禁用AutoFormatLabels也是一个好主意。就您而言,您可以在RangeChanged事件内部检查可见的原始标签数。如果只有一个或没有,则启用CustomTicks。
_chart.AfterRendering += _chart_AfterRendering;

        private void _chart_AfterRendering(object sender, AfterRenderingEventArgs e)
        {
            _chart.AfterRendering -= _chart_AfterRendering;

            _chart.ViewXY.XAxes[0].RangeChanged += AxisX_RangeChanged;
        }

        private void AxisX_RangeChanged(object sender, RangeChangedEventArgs e)
        {
            double ticks = _chart.ViewXY.XAxes[0].GetMajorTicks().Length;
            _chart.BeginUpdate();
            if (ticks < 2)
            {
                _chart.ViewXY.XAxes[0].AutoFormatLabels = false;
                _chart.ViewXY.XAxes[0].CustomTicksEnabled = true;
            }
            else if (_chart.ViewXY.XAxes[0].CustomTicksEnabled)
            {
                _chart.ViewXY.XAxes[0].AutoFormatLabels = true;
                _chart.ViewXY.XAxes[0].CustomTicksEnabled = false;
            }
            _chart.EndUpdate();
        }
GetMajorTicks仅返回原始刻度数,而忽略CustomTicks。


请注意,我们在上面使用了AfterRendering事件,因为RangeChanged实际上是在创建轴时触发的。由于此时可能尚未渲染轴或统计图本身,因此可能会发生崩溃。
希望这会有所帮助。

如果对此有任何疑问,以获取更多信息。

想要购买LightningChart正版授权,或了解更多产品信息请点击


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@wqylolg.cn

文章转载自:

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP