为AdvancedDataGrid设置备用颜色 - 一个用于父节点,另一个用于子节点

时间:2011-04-06 13:02:41

标签: flex advanceddatagrid

似乎有各种方法可以为数据网格设置背景颜色。

请参阅:How to dynamically change background colour of datagrid row?

请参阅:Setting background color for datagrid row in Adobe Flex

我有一个高级数据网格,其中HierarchicalData作为数据源。为此,我必须为父节点设置备用背景颜色,为子节点设置其他背景颜色。

<mx:AdvancedDataGrid id="electionGrid" alternatingItemColors="[#449933, #994433]" width="100%" height="70%" folderOpenIcon="{null}" folderClosedIcon="{null}" defaultLeafIcon="{null}" editable="true">
        <mx:dataProvider>
            <mx:HierarchicalData source="{electionSummary}" childrenField="electionOptions"/>
        </mx:dataProvider>
        <mx:columns>
            <mx:AdvancedDataGridColumn dataField="product" headerText="Product" editable="false"/>              
            <mx:AdvancedDataGridColumn dataField="accountID" headerText="Account ID" editable="false"/>
            <mx:AdvancedDataGridColumn dataField="accountDescription" headerText="Account Description" editable="false"/>
            <mx:AdvancedDataGridColumn dataField="electionOption" headerText="Election Options" editable="false"/>
            <mx:AdvancedDataGridColumn dataField="electionStatus" headerText="Election Status" editable="true"/>
            <mx:AdvancedDataGridColumn dataField="entitledQuantity" headerText="Entitled Quantity"/> 
            <mx:AdvancedDataGridColumn dataField="electedQuantity" headerText="Elected Quantity"/>
            <mx:AdvancedDataGridColumn dataField="percentelectionDetails" headerText="Election %Details"/>
            <mx:AdvancedDataGridColumn dataField="comments" headerText="Comments"/>
        </mx:columns>        
    </mx:AdvancedDataGrid>

我使用了alternatingItemColors样式,但它没有按预期工作。

alternatingItemColors="[#449933, #994433]"

我需要为父节点和子节点设置备用颜色。

Hiearchical Data:

<mx:ArrayCollection id="electionSummary">
    <model:Elections product="Global PB" accountID="10473834" accountDescription="Fund 1.2 Account" entitledQuantity="250000"
                        electedQuantity="0" percentelectionDetails="0">    
        <model:electionOptions>
            <mx:ArrayCollection id="optionData1">
                <model:Options electionStatus="Not Submitted"/>
            </mx:ArrayCollection>
        </model:electionOptions>
    </model:Elections>

    <model:Elections product="Global PB" accountID="10473834" accountDescription="Fund 1.2 Account" entitledQuantity="250000"
                        electedQuantity="0" percentelectionDetails="0">    
        <model:electionOptions>
            <mx:ArrayCollection id="optionData2">
                <model:Options electionStatus="Not Submitted"/>
            </mx:ArrayCollection>
        </model:electionOptions>
    </model:Elections>

    <model:Elections product="Global PB" accountID="10473834" accountDescription="Fund 1.2 Account" entitledQuantity="250000"
                        electedQuantity="0" percentelectionDetails="0">    
        <model:electionOptions>
            <mx:ArrayCollection id="optionData3">
                <model:Options electionStatus="Not Submitted"/>
            </mx:ArrayCollection>
        </model:electionOptions>
    </model:Elections>
</mx:ArrayCollection>

它也可以通过覆盖datagrid中的drawRowBackground函数来实现。

请参阅:http://flexpearls.blogspot.com/2008/02/row-background-color-in.html

是否有一种简单的方法可以为DataGrid中使用的层级数据完成备用颜色设置。

1 个答案:

答案 0 :(得分:1)

简而言之,没有。据我所知,没有“简单”的方法可以根据深度(父/子)为AdvancedDataGrid设置不同的交替行颜色。

最接近你想要的是depthColors属性,但是会将该深度的所有行设置为一种颜色,而不是交替行。