ZedGraph 属性及基础教程
最后的两个Stack和PercentStack就是按先前的位标依次累积上升。例如有两个坐标为( 0 ,100 ), ( 0 , 120),那么第一个坐标位置就是( 0 , 100 ) , 第二个就是( 100 , 220 )。而PercentStack是把相应的坐标转换成百分比来计算坐标位置的。例图可以参看本节的前两个图。
基本教程篇--第八节PieSampleDemo.cs介绍
这节我把饼形图粗略的介绍一下,如下图。
25 / 33
ZedGraph 属性及基础教程
using System;
using System.Drawing; using System.Collections; using ZedGraph;
namespace ZedGraph.Demo
{
///
/// Summary description for SimpleDemo. ///
public class PieSampleDemo : DemoBase {
public PieSampleDemo() : base( \Project Pie Sample\Sample\DemoType.Pie, DemoType.Tutorial ) {
GraphPane myPane = base.GraphPane; // Set the GraphPane title
myPane.Title = \ZedGraph Sales by Region\\n($M)\ myPane.FontSpec.IsItalic = true; myPane.FontSpec.Size = 24f; myPane.FontSpec.Family = \
// Fill the pane background with a color gradient
myPane.PaneFill = new Fill( Color.White, Color.Goldenrod, 45.0f ); // No fill for the axis background myPane.AxisFill.Type = FillType.None; // Set the legend to an arbitrary location myPane.Legend.Position = LegendPos.Float ;
myPane.Legend.Location = new Location( 0.95f, 0.15f, CoordType.PaneFraction,AlignH.Right, AlignV.Top ); myPane.Legend.FontSpec.Size = 10f; myPane.Legend.IsHStack = false;
// Add some pie slices
PieItem segment1 = myPane.AddPieSlice( 20, Color.Navy, Color.White, 45f, 0, \); PieItem segment3 = myPane.AddPieSlice( 30, Color.Purple, Color.White, 45f, .0, \);
26 / 33
ZedGraph 属性及基础教程
PieItem segment4 = myPane.AddPieSlice( 10.21, Color.LimeGreen, Color.White, 45f, 0, \); PieItem segment2 = myPane.AddPieSlice( 40, Color.SandyBrown, Color.White, 45f, 0.2, \); PieItem segment6 = myPane.AddPieSlice( 250, Color.Red, Color.White, 45f, 0, \); PieItem segment7 = myPane.AddPieSlice( 50, Color.Blue, Color.White, 45f, 0.2, \Rim\); PieItem segment8 = myPane.AddPieSlice( 400, Color.Green, Color.White, 45f, 0, \America\); PieItem segment9 = myPane.AddPieSlice( 50, Color.Yellow, Color.White, 45f, 0.2, \);
segment2.LabelDetail.FontSpec.FontColor = Color.Red; // Sum up the pie values
CurveList curves = myPane.CurveList ;
double total = 0 ;
for ( int x = 0 ; x < curves.Count ; x++ ) total += ((PieItem)curves[x]).Value ; // Make a text label to highlight the total value
TextItem text = new TextItem( \2004 Sales\\n\+ \+ total.ToString () + \ 0.18F, 0.40F, CoordType.PaneFraction ); text.Location.AlignH = AlignH.Center; text.Location.AlignV = AlignV.Bottom; text.FontSpec.Border.IsVisible = false ;
text.FontSpec.Fill = new Fill( Color.White, Color.FromArgb( 255, 100, 100 ), 45F ); text.FontSpec.StringAlignment = StringAlignment.Center ; myPane.GraphItemList.Add( text );
// Create a drop shadow for the total value text item TextItem text2 = new TextItem( text ); text2.FontSpec.Fill = new Fill( Color.Black ); text2.Location.X += 0.008f; text2.Location.Y += 0.01f;
myPane.GraphItemList.Add( text2 ); base.ZedGraphControl.AxisChange(); } }
27 / 33
ZedGraph 属性及基础教程
}
代码分析:
我们先把Legend类的相关属性再补充一下。 // Set the legend to an arbitrary location
myPane.Legend.Position = LegendPos.Float ;
myPane.Legend.Location = new Location( 0.95f, 0.15f, CoordType.PaneFraction,AlignH.Right, AlignV.Top ); myPane.Legend.FontSpec.Size = 10f; myPane.Legend.IsHStack = false;
LegendPos是一个枚举,共有13个枚举值:Top、Left、Right、Bottom、InsideTopLeft、InsideTopRight、InsideBotLeft、InsideBotRight、Float、TopCenter、BottomCenter、TopFlushLeft和BottomFlushLeft。具体含义我就不解释了,都是关于Legend位置的。
Location是指定Legend具体坐标的一个类,要注意的是,只有当LegendPos是Float时,Location才会起作用。 FontSpec类就是一个字体类,里面是关于字体的一些相关设置,这里不再细说。
IsHStack是一个Legend的属性,是设置Legend中文字和图形的显示方式是水平还是垂直。
下面说说本节的主角PieItem类:
PieItem segment6 = myPane.AddPieSlice( 250, Color.Red, Color.White, 45f, 0, \);
Pie重载了五个构造函数,上面是参数最多的一个构造函数,共有六个,意思分别是:在整个饼形图中占的比重,渐变颜色1,渐变颜色2,渐变颜色角度,远离中心点的距离,饼形图的文字注释。
饼形图也是继承 ZedGraph.CurveItem,与其它继承CurveItem不同的是,PieItem有一个value的属性,可以方便的存取PieItem实例的值,从而可以很方便的动态改变一个饼形在整个饼形区域所占的比重。 关于饼形的其它属性和方法的使用,在饼形图那一章再做专门的介绍。
基本教程篇----第九节MasterSampleDemo.cs介绍
最近一直挺忙的,都没时间写博客了,好在这是基础篇的最后一篇了,我也可以歇歇了,关于其它的深入章节我会在以后的时间补上的。
先来看看这一节的示图和源代码吧。
28 / 33