My flex data grid has a XMLListCollection as its data provider.

AlivePDF's Grid expects data grid's data provider to be an array.

Is there a way to PDF this table without going through each and every XML node and populating an array of objects to feed to AlivePDF's Grid?

Are there any other better solutions that I can try out to covert this table to PDF?

Thanks!

有帮助吗?

解决方案

ListCollectionView (XMLListCollection base class) has toArray() method

So, just new Grid(dataProvider.toArray(),...)

其他提示

Here is a sample code snippet that may help you : Here dataGrid has 2 columns. And chilledWaterLoopXml is the xml containing the data..

            var gridColumnFirstcol:GridColumn = new GridColumn('Design ΔT','designDelta', 40, Align.LEFT, Align.LEFT);
            var gridColumnSecondcol:GridColumn = new GridColumn('Chilled Water', 'chilledWtrPump', 40, Align.LEFT, Align.LEFT);                 


            var result:ArrayCollection=new ArrayCollection();
            for(var i:int =0;i<chilledWaterLoopXml.children().length();i++)
            {
                var resultant:Object = new Object();
                resultant["designDelta"]=chilledWaterLoopXml.child(i).designDelta;
                resultant["chilledWtrPump"]=chilledWaterLoopXml.child(i).chilledWtrPump;            
                result.addItem(resultant);
            }

            var grid:org.alivepdf.data.Grid = new org.alivepdf.data.Grid( result.toArray() , 100,50, new RGBColor(0xD4CCC5), new RGBColor(0x66C66C),0, new RGBColor(0x000000),1,Joint.ROUND);
            grid.columns = columns;                                                 
            pdf.addGrid(grid);
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top