Проблема Dojo-Charting: гистограмма (ClusteredColumns) Использование массива? - PullRequest
2 голосов
/ 20 марта 2012

Проще говоря, у меня есть 2 значения ActualCost и BudgetCost, я создал диаграмму Clustered Columns для отображения их значений.Сейчас я сделал две серии для каждой из них (я хочу сделать для них легенды).В каждой серии, почему я должен использовать два значения в массиве?

Когда я использую в .addSeries([]) код {y:0,tooltip:0}, он отлично работает при отображении обеих полос, а когда я не использую его, он отображает только одну полосу.Может кто-нибудь объяснить, почему я должен использовать это (то есть {y:0,tooltip:0}).

Я написал код для него и он работает нормально, фрагмент кода ниже;

    dojo.require("dijit.layout.BorderContainer");
    dojo.require("dijit.layout.ContentPane");
    dojo.require("dijit.TitlePane");
    dojo.require("esri.dijit.Popup");
    dojo.require("dojox.charting.Chart2D");
    dojo.require("dojox.charting.plot2d.ClusteredColumns");
    dojo.require("dojox.charting.action2d.Tooltip");
    dojo.require("dojo.number");
    dojo.require("dijit.layout.TabContainer");
    dojo.require("dojox.charting.themes.Wetland");
     //...
        function getTextContent(graphic) 
          var ActualCost;
          var BudgetCost;
             (parseFloat(jsonobject.Data.Actual_Total_Cost) == 'NaN') ? ActualCost=0 :
             ActualCost=parseFloat(jsonobject.Data.Actual_Total_Cost);
             (parseFloat(jsonobject.Data.Current_Budget) == 'NaN') ? BudgetCost=0 :
             BudgetCost=parseFloat(jsonobject.Data.Current_Budget);

             //display a dojo pie chart for the Project Cost
             var CostPane = new dijit.layout.ContentPane({
                title: "Project Cost"
               });
        tc.addChild(CostPane);
        var costDiv = dojo.create("div", 
        { id:"cost",width: 300, height: 300}, dojo.create('div'));
        var barchart = new dojox.charting.Chart2D(costDiv);
        dojo.addClass(barchart,'chart');
        barchart.setTheme(dojo.getObject("dojox.charting.themes.Wetland"));
        barchart.addPlot("default",{type: "ClusteredColumns",markers: true,gap: 10});
        //barchart.addAxis("x");
        barchart.addAxis("y", {vertical: true});

        new dojox.charting.action2d.Highlight(chart, "default");
        new dojox.charting.action2d.Tooltip(chart,"default");
        new dojox.charting.action2d.MoveSlice(chart,"default");

//Why using {y:0,tooltip:0} in the array??


    barchart.addSeries("Actual Cost", [ {y:ActualCost,tooltip:'Actual Cost =' +
 Math.round(ActualCost*100)/100}, {y:0,tooltip:0}] );
        barchart.addSeries("Current Budget", [ {y:BudgetCost,tooltip:'Budget Cost =' +
 Math.round(BudgetCost*100)/100}, {y:0,tooltip:0}] );
        barchart.render();
        CostPane.set('content',barchart.node);
        deferred.callback(tc.domNode);
                                            },

Может кто-нибудьПомогите?Спасибо

1 Ответ

0 голосов
/ 07 сентября 2015

Метод addSeries принимает три аргумента, второй - массив данных, поэтому вам нужно использовать массив.Указывает данные в столбце диаграммы.

...