2012-01-03 45 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版本而異,因此您必須檢查它。