- 如何让chart图进行刷新并且根据数值重新绘制
首先初始化一个chart
chart1.Titles.Add("柱状图数据分析");
chart1.ChartAreas[].AxisX.Title = "时间(月)";
chart1.ChartAreas[].AxisY.Title = "单位(元)";
//chart1
Series series = chart1.Series["Series1"];
series.LegendText = "销售分析";
chart1.DataSource = list;
series.XValueMember = "time";
series.YValueMembers = "value";
进行重新绘制
chart1.Series["Series1"].Points.Clear();//清除之前的图
Series series = chart1.Series["Series1"];
// 图示上的文字
series.LegendText = "销售分析";
//InitializeComponent();
//获取当前年份查询
List<LirunModel> list = new LirunDao().getList(year,type);
if (list != null)
{
chart1.DataSource = list;
series.XValueMember = "time";
series.YValueMembers = "value";
}
- time和value是怎么回事?
这是给chart赋值的过程;
首先有一个模型类
class LirunModel
{
private double _value; public double Value
{
get { return _value; }
set { _value = value; }
}
private string _time; public string Time
{
get { return _time; }
set { _time = value; }
} }
然后用一个List保存多个模型类的对象,最后通过这个list给chart的横纵坐标赋值。
//年份和类型 1是销售额 2是利润
public List<LirunModel> getList(int year,int type)
{
List<LirunModel> list=new List<LirunModel>(); LirunModel m=null;
for (int i = ; i < ; i++)
{
m = new LirunModel();
m.Time = i + "月";
if (type == )
{
m.Value = getInByMonth(i, year);
}
else if (type == )
{
m.Value = getInByMonth(i, year) - getOutByMonth(i, year);
}
list.Add(m);
}
return list;
}
- C#获取年份
DateTime.Now.Year.ToString(); 获取年份 // 2008
DateTime.Now.ToString(); // 2008-9-4 20:02:10
DateTime.Now.ToString("yyyy-MM-dd"); // 2008-09-04
DateTime.Now.Month.ToString(); 获取月份 // 9
DateTime.Now.DayOfWeek.ToString(); 获取星期 // Thursday
DateTime.Now.DayOfYear.ToString(); 获取第几天 // 248
- c#如何让chart中的每个横坐标都显示
首先,通过chart空间属性,找到 “ChartAreas集合” ,并且点开
于是来到了ChartAreas集合编辑器,在右边ChartAreas1属性中找到 “Axes集合",并点开,如图
因为我们要设置的是x轴,所以在 ”Axis集合编辑器“ 左边中选 ”x axis“,
在右边属性中选择 ”IntervalAutoMode“ 在下来项中选中 ”VariableCount“,设定x轴的间隔是可变的,
设定x轴间隔可变
这时,如果x轴标签过多,可能还不会使得x轴标签全部显示出来,这就需要把x轴标签分为上下两层显示
还是在 ”Axis集合编辑器“ 中找到 ”IsStaggered属性“ 设其值为 ”True“,
在 ”Axis集合编辑器“ 中找到 ”IsStaggered属性“ 设其值为 ”True“,
接着在运行,成功显示x轴全部标签
当然,还有另一种方法,使x轴标签旋转90度角显示,
在设置x轴可变后,在 ”Axis集合编辑器“ 选中 ”Angle“ 选项,设置值为90,
点击 ”确定“ 退出设置
或者可以添加这句代码
Chart1.ChartAreas[0].AxisX.LabelStyle.IsStaggered = true; //设置是否交错显示,比如数据多的时间分成两行来显示