剑道图表渲染速度很慢

时间:2015-12-17 12:37:57

标签: kendo-ui kendo-asp.net-mvc kendo-chart

我有如下的剑道图表。我必须绘制超过20k点的图形。我面临的问题是图表渲染速度很慢。如何提高这一性能。对此有何帮助表示高度赞赏?

 @(Html.Kendo().PanelBar()
                            .Name("linePanelBar")
        //.ExpandMode(PanelBarExpandMode.Multiple)
                .HtmlAttributes(new { style = "width:100%;height:300px;background-color:transparent;" })
                            .Items(panelbar =>
                            {
                                panelbar.Add().Text("Correlation")
                                .Expanded(true)
                                .Content(@<div onclick="onCell3Clicked()">
                                              <div id="loading"></div>
                                    @if (@Model != null && @Model.XValues != null && @Model.YValues != null)
                                    {
                                        @(Html.Kendo().Chart()
        .Name("Correlationchart")
            .RenderAs(RenderingMode.Canvas)
                .Transitions(false)
        .Title(Model.YString + " Vs " + Model.XString + " Relationship")
        //.Legend(legend => legend
        //    .Position(ChartLegendPosition.Right).Visible(true)
        //)
       .SeriesDefaults(seriesDefaults =>
            seriesDefaults.ScatterLine().Style(ChartScatterLineStyle.Smooth)

            )

        .Series(series =>
        {
            series.Scatter(Model.CorrelationChartData).Fields("xValue", "yValue").NoteTextField("fallback").Notes(notes => notes.Label(label => label.Position(ChartNoteLabelPosition.Outside)).Position(ChartNotePosition.Top));
            series.ScatterLine(Model.RegressionChartData).Fields("xValue", "yValue").Name("Regression");
            series.ScatterLine(Model.LowessChartData).Fields("xValue", "yValue").Name("Lowess");

        }).Events(e=>e.SelectStart("onSelectStart").SelectEnd("onSelectEnd"))
        .ChartArea(x => x.Width(600).Height(300))
        .XAxis(x => x
            .Numeric()
            .Title(title => title.Text(Model.XString))
            .Crosshair(crosshair => crosshair
                .Visible(true)
                .Tooltip(tooltip => tooltip
                    .Visible(true)
                )
             )
        )
        .YAxis(y => y
            .Numeric()
            .Title(title => title.Text(Model.YString))
            .AxisCrossingValue(-5)
            .Crosshair(crosshair => crosshair
                .Visible(true)
                .Tooltip(tooltip => tooltip
                    .Visible(true)
                )
            )
        )
                                        )

                                    }
                                </div>);
                            }))

由于

0 个答案:

没有答案