【问题标题】:Clearing/Emptying a lineChart in Flex在 Flex 中清除/清空折线图
【发布时间】:2011-10-21 09:15:28
【问题描述】:

我有一个带有日期时间轴的 flex 折线图。我正在通过 actionscript 将 dataprovider 设置为该折线图。图表被绘制。当我将 null 分配给 dataprovider 以使图形变为空时,就会出现问题。

实际代码类似于下面的代码:

var actualValues:XMLList=flowChartDP.upFlows;
var localSeries1:LineSeries = new LineSeries();
localSeries1.dataProvider = actualValues;
localSeries1.yField = "flow";
localSeries1.xField = "time";
localSeries1.setStyle("form","curve");
var currentSeries1:Array =lineChart.series;
currentSeries1.push(localSeries1);
lineChart.series = currentSeries1;
var actualValues2:XMLList=flowChartDP.downFlows;
var localSeries2:LineSeries = new LineSeries();
localSeries2.dataProvider = actualValues2;
localSeries2.yField = "flow";
localSeries2.xField = "time";
localSeries2.setStyle("form","curve");
var currentSeries2:Array =lineChart.series;
currentSeries2.push(localSeries2);
lineChart.series = currentSeries2;

我将在 lineChart 中添加两个完全相同的系列。虽然我猜这不是编写代码的最佳方式,但这个工作正常。 问题在于重置图表。

我有一个按钮,当点击它时: lineChart.dataprovider=null; lineChart.series=null;

但是我的 flash player(FP 10 调试器版本)抛出以下错误

TypeError: Error #1009: Cannot access a property or method of a null object reference.
    at mx.charts::AxisRenderer/measureHorizontalGutters()[E:\dev\4.0.0\frameworks\projects\datavisualization\src\mx\charts\AxisRenderer.as:2275]
    at mx.charts::AxisRenderer/calcRotationAndSpacing()[E:\dev\4.0.0\frameworks\projects\datavisualization\src\mx\charts\AxisRenderer.as:1889]
    at mx.charts::AxisRenderer/adjustGutters()[E:\dev\4.0.0\frameworks\projects\datavisualization\src\mx\charts\AxisRenderer.as:1565]
    at mx.charts.chartClasses::CartesianChart/updateAxisLayout()[E:\dev\4.0.0\frameworks\projects\datavisualization\src\mx\charts\chartClasses\CartesianChart.as:2133]
    at mx.charts.chartClasses::CartesianChart/updateDisplayList()[E:\dev\4.0.0\frameworks\projects\datavisualization\src\mx\charts\chartClasses\CartesianChart.as:1391]
    at mx.core::UIComponent/validateDisplayList()[E:\dev\4.0.0\frameworks\projects\framework\src\mx\core\UIComponent.as:8531]
    at mx.managers::LayoutManager/validateDisplayList()[E:\dev\4.0.0\frameworks\projects\framework\src\mx\managers\LayoutManager.as:663]
    at mx.managers::LayoutManager/doPhasedInstantiation()[E:\dev\4.0.0\frameworks\projects\framework\src\mx\managers\LayoutManager.as:736]
    at mx.managers::LayoutManager/doPhasedInstantiationCallback()[E:\dev\4.0.0\frameworks\projects\framework\src\mx\managers\LayoutManager.as:1072]

解决办法是什么?时不会抛出错误

lineChart.series=null;

被删除。但是声明

lineChart.dataprovider=null;

也不会使图表为空。

【问题讨论】:

    标签: actionscript-3 flex4 dataprovider series linechart


    【解决方案1】:

    以下是我创建的一个简单应用程序,用于重新创建您的问题。将 dataProvider 设置为 null 确实会清除图表,对我来说没有任何例外。运行它看看。我说你的问题出在其他地方。

    <?xml version="1.0" encoding="utf-8"?>
    <s:Application
       xmlns:fx="http://ns.adobe.com/mxml/2009" 
       xmlns:s="library://ns.adobe.com/flex/spark"             
       xmlns:mx="library://ns.adobe.com/flex/mx" >
    
        <fx:Script><![CDATA[
    
            import mx.collections.ArrayCollection;
            [Bindable]
            public var expenses:ArrayCollection = new ArrayCollection([
                {Month:"Jan", Profit:2000, Expenses:1500, Amount:450},
                {Month:"Feb", Profit:1000, Expenses:200, Amount:600},
                {Month:"Mar", Profit:1500, Expenses:500, Amount:300}
            ]);
    
    
            protected function button1_clickHandler(event:MouseEvent):void
            {
                myChart.dataProvider = null;
    
            }
    
        ]]></fx:Script>
    
        <s:layout>
            <s:VerticalLayout />
        </s:layout>
    
    
        <mx:Panel title="Line Chart">
            <mx:LineChart id="myChart" 
                          dataProvider="{expenses}" 
                          showDataTips="true"
                          >
                <mx:horizontalAxis>
                    <mx:CategoryAxis 
                        dataProvider="{expenses}" 
                        categoryField="Month"
                        />
                </mx:horizontalAxis>
                <mx:series>
                    <mx:LineSeries 
                        yField="Profit" 
                        displayName="Profit"
                        />
                    <mx:LineSeries 
                        yField="Expenses" 
                        displayName="Expenses"
                        />
                </mx:series>
            </mx:LineChart>
            <mx:Legend dataProvider="{myChart}"/>
        </mx:Panel>
    
        <s:Button click="button1_clickHandler(event)" label="Clear" />
    
    </s:Application>
    

    【讨论】:

    • 我正在动态地创建流程上的系列,并将数据提供者也分配给系列。
    • 无论是动态创建还是在运行时设置,除非 Flex 中存在 bug(这种情况很少见),两者都应该一样工作。无论如何,所有这些代码在编译时都会转换为 ActionScript。您可以使用相关代码更新您的问题吗?显示按钮的代码。
    • 数据提供者是 XMLList 对象。例如 var actualValues:XMLList=flowChartDP.flows; var localSeries1:LineSeries = new LineSeries(); localSeries1.dataProvider = 实际值; localSeries1.yField = "流"; localSeries1.xField = "时间"; localSeries1.setStyle("form","curve"); var currentSeries1:Array = lineChart.series; currentSeries1.push(localSeries1); lineChart.series = currentSeries1;
    • 我将在 lineChart 中添加三个完全相同的系列。折线图代码是
    • 我已经更新了 Ranhiru 的问题。感谢您调查它。我也在用一个像你这样的例子来检查这个,它工作得很好。所以我现在正在研究我的代码。希望更新后的问题能进一步澄清问题..
    猜你喜欢
    • 2019-12-09
    • 1970-01-01
    • 1970-01-01
    • 2020-06-09
    • 1970-01-01
    • 1970-01-01
    • 2020-06-07
    • 1970-01-01
    • 2014-04-10
    相关资源
    最近更新 更多