2009-09-24 9 views
9

Betrachten Sie eine ASP.NET MVC-Controller-Methode, die ein ASP.NET-Diagrammbild erstellt.ASP.NET-Diagramm: Festlegen der Schriftarten auf X- und Y-Achse

public FileStreamResult MakeImg(IEnumerable<MyObj> stats) 
    { 
     Chart barchart = BarChart(400, 300); 

     Series series1 = new Series("Series1"); 
     series1.ChartArea = "ca1";    
     series1.ChartType = SeriesChartType.Column; 
     series1.IsValueShownAsLabel = true;  
     series1.Font = new Font("Verdana", 9f, FontStyle.Regular); 

     barchart.Series.Add(series1);    

     // Set chart data source 
     barchart.DataSource = stats; 

     // Set series members names for the X and Y values 
     barchart.Series["Series1"].XValueMember = "FriendlyDate"; 
     barchart.Series["Series1"].YValueMembers = "NumRecords"; 

     // Data bind to the selected data source 
     barchart.DataBind(); 

     MemoryStream ms = new MemoryStream(); 
     barchart.SaveImage(ms, ChartImageFormat.Png); 
     ms.Seek(0, SeekOrigin.Begin); 

     return new FileStreamResult(ms, "image/png"); 
    } 

Das Bild wird in eine unattraktive Weise gemacht:

fugly http://www.imagechicken.com/uploads/1253830647005451400.png

Frage: Wie kann ich die Schriftart programmatisch für den Satz:

  • X- und Y-Achsenbeschriftungen - dh 0 bis 35 auf Y, und die Daten auf X
  • Daten - d.h. 12, 0, 0, 3, 6?

Antwort

13
chart.ChartAreas[0].AxisX.LabelStyle.Font 
chart.ChartAreas[0].AxisY.LabelStyle.Font 

ist die Eigenschaft, die Sie die Schriftart für die Achsen festlegen müssen.

0

Ein anderes Problem, mit dem ich konfrontiert war, waren die Zacken am Text. Der Wechsel von .png zu .jpg hat es geschafft!

+0

Gleichermaßen wird dies alles für Sie glätten: chart1.AntiAliasing = AntiAliasingStyles.All; – Simon

1

Chart1.ChartAreas [0] .AxisX.LabelStyle.Font = neues System.Drawing.Font ("Verdana", 8f); Chart1.ChartAreas [0] .AxisY.LabelStyle.ForeColor = System.Drawing.Color.Red;