我有一个包含三列的表,后两列中包含值。我正在尝试输出两个饼图,显示每个饼图的数据。出于某种原因,第二个饼图没有显示,而是显示为灰色方块。此外,传说连续出现两次,但这只是一个对我来说没有意义的传说。
这是标记:
<asp:Chart Height="500" Width="500" ID="ClientModelChart" runat="server">
<Series>
<asp:Series ChartType="Pie" IsValueShownAsLabel="true" Name="PortfolioActual"></asp:Series>
<asp:Series ChartType="Pie" IsValueShownAsLabel="true" Name="ModelActual"></asp:Series>
</Series>
<Legends>
<asp:Legend Name="PortfolioActual"></asp:Legend>
<asp:Legend Name="ModelActual"></asp:Legend>
</Legends>
<ChartAreas>
<asp:ChartArea Area3DStyle-Enable3D="true" Area3DStyle-LightStyle="Realistic" Name="PortfolioActual"></asp:ChartArea>
<asp:ChartArea Area3DStyle-Enable3D="true" Name="ModelActual"></asp:ChartArea>
</ChartAreas>
</asp:Chart>
然后我有一个SqlDataAdapter
用来填充一个的DataSet
,然后我把它DataTableCollection
变成一个IEnumerable
列表类型,这样我就可以在数据绑定图表系列时使用它。看起来有点麻烦,但我这样做的原因是因为DataSet
稍后用于某些 XSLT 输出,所以当我已经获得我需要/想要的数据时,重新查询数据库是没有意义的。
Dim sectorList As IList = CType(ds.Tables(1), IListSource).GetList()
ClientModelChart.Series("PortfolioActual").Points.DataBind(sectorList, "Sector", "Model", Nothing)
ClientModelChart.Series("ModelActual").Points.DataBind(sectorList, "Sector", "Client", Nothing)
所以第二个饼图(ModelActual)根本没有显示,它只是一个灰色的正方形。我一直在摆弄几个小时无济于事。(编辑:另外,我已经做过类似的事情,所以我不知道为什么这个不起作用。与我的另一个不同之处在于它最初来自两组不同的数据,但这不应该是它不起作用的原因)
谢谢。