2012-01-03 123 views
0

我试图让我的第一个MS图表出现 - 只是一个简单的线条。但是,当我单击调试(VS2010)时,我所得到的只是网页上的一个缺失图像图标(不管浏览器如何)。该图表已从MS图表样本中复制。ASP.Net MS图表:图像丢失

我的第一个想法是MS Chart没有正确安装,但所有样本在调试样本环境时工作良好。这只是我自己的测试页面无法渲染图像。

我要去哪里错?

这里的web.config文件:

<?xml version="1.0"?> 
<!-- 
    For more information on how to configure your ASP.NET application, please visit 
    http://go.microsoft.com/fwlink/?LinkId=169433 
    --> 
<configuration> 
    <appSettings> 
    <add key="ChartImageHandler" value="storage=file;timeout=20;dir=c:\TempImageFiles\;" /> 
    </appSettings> 

    <system.webServer> 
    <handlers> 
     <remove name="ChartImageHandler" /> 
     <add name="ChartImageHandler" preCondition="integratedMode" verb="GET,HEAD,POST" 
     path="ChartImg.axd" type="System.Web.UI.DataVisualization.Charting.ChartHttpHandler, System.Web.DataVisualization, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" /> 
    </handlers> 
    </system.webServer> 
    <system.web> 
    <httpHandlers> 
     <add path="ChartImg.axd" verb="GET,HEAD,POST" type="System.Web.UI.DataVisualization.Charting.ChartHttpHandler, System.Web.DataVisualization, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" 
     validate="false" /> 
    </httpHandlers> 
    <roleManager enabled="true"/> 
    <compilation debug="true" targetFramework="4.0"> 
     <assemblies> 
     <add assembly="System.Web.DataVisualization, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/> 
     </assemblies> 
    </compilation> 
    <pages theme="xxx"> 
     <controls> 
     <add tagPrefix="asp" namespace="System.Web.UI.DataVisualization.Charting" 
      assembly="System.Web.DataVisualization, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" /> 
     </controls> 
    </pages> 

</configuration> 

这里的页面代码:

<asp:chart id="chart1" runat="server" imagetype="Png" BackColor="WhiteSmoke" BorderWidth="2" BackGradientStyle="TopBottom" BackSecondaryColor="White" Palette="BrightPastel" BorderDashStyle="Solid" BorderColor="26, 59, 105" Height="296px" Width="412px"> 
    <titles> 
      <asp:title ShadowColor="32, 0, 0, 0" Font="Trebuchet MS, 12pt, style=Bold" ShadowOffset="3" Text="Two series with 20000 points each." ForeColor="26, 59, 105"> 
      </asp:title> 
    </titles> 
    <legends> 
     <asp:legend Enabled="False" IsTextAutoFit="False" Name="Default" BackColor="Transparent" Font="Trebuchet MS, 8.25pt, style=Bold"></asp:legend> 
    </legends> 
    <borderskin skinstyle="Emboss"></borderskin> 
    <series> 
     <asp:series Name="Series1" ChartType="FastLine" ShadowColor="Black" BorderColor="180, 26, 59, 105"></asp:series> 
     <asp:series Name="Series2" ChartType="FastLine" ShadowColor="Black" BorderColor="180, 26, 59, 105" Color="224, 64, 10"></asp:series> 
    </series> 
    <chartareas> 
     <asp:chartarea Name="ChartArea1" BorderColor="64, 64, 64, 64" BorderDashStyle="Solid" BackSecondaryColor="White" BackColor="Gainsboro" ShadowColor="Transparent" BackGradientStyle="TopBottom"> 
      <area3dstyle Rotation="10" perspective="10" Inclination="15" IsRightAngleAxes="False" wallwidth="0" IsClustered="False"></area3dstyle> 
      <axisy linecolor="64, 64, 64, 64" IsLabelAutoFit="False"> 
        <labelstyle font="Trebuchet MS, 8.25pt, style=Bold" /> 
        <majorgrid linecolor="64, 64, 64, 64" /> 
      </axisy> 
      <axisx linecolor="64, 64, 64, 64" IsLabelAutoFit="False"> 
        <labelstyle font="Trebuchet MS, 8.25pt, style=Bold" /> 
        <majorgrid linecolor="64, 64, 64, 64" /> 
      </axisx> 
     </asp:chartarea> 
    </chartareas> 
</asp:chart> 

代码背后:

using System; 
using System.Collections.Generic; 
using System.Web; 
using System.Web.UI; 
using System.Web.UI.WebControls; 
using System.Web.UI.DataVisualization.Charting; 
using System.Drawing; 

public partial class reporting : System.Web.UI.Page 
{ 
    protected void Page_Load(object sender, EventArgs e) 
    { 
     double yValue = 50.0; 
     Random random = new Random(); 
     for (int pointIndex = 0; pointIndex < 20000; pointIndex++) 
     { 
      yValue = yValue + (random.NextDouble() * 10.0 - 5.0); 
      chart1.Series["Series1"].Points.AddY(yValue); 
     } 

     chart1.Series["Series1"].ChartType = SeriesChartType.FastLine; 
    } 
} 

新年快乐!

回答

1

我上次使用MS Chart时,必须为Web配置中的图像提供物理路径。否则,我只会得到一个破碎的图像。没有其他选项一直工作,但创建一个c:\ tempimages文件夹并设置此值确实

此外,请确保该计算机的IIS用户有权写入该文件夹。通过IIS而不是Windows资源管理器授予权限。

1

您必须提供一个文件夹,并为IIS用户提供访问该文件夹的权限。需要访问的用户因Windows和IIS版本而异,因此您必须检查它。