dev 点击gridview某列的Checkbox动态切换chart数据显示2

splineSeriesView5 = splineSeriesView1;


using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using Sunny.RiverForecast.Model;
using Sunny.RiverForecast.Business.Common;
using Sunny.RiverForecast.Winform.Common;
using DevExpress.XtraCharts;

namespace FloodRouting
{
public partial class SolutionSelectFrm : BaseForm
{
public SolutionSelectFrm()
{
InitializeComponent();


this.CurFormType = FormType.MainForm;
List<ReservoirGroup> revList = getReserviorList();
//MessageBox.Show("水库群个数:"+revList.Count+"; 名称:"+revList[0].GroupName+"; 预测断面:"+revList[0].FloodStation);
String[] arr = null;
if (null != revList && revList.Count > 0)
{
arr = new String[revList.Count];
for (int i = 0; i < revList.Count; i++)
{
arr[i] = revList[i].GroupName;
}
}
comboBox1.DataSource = arr;//水库群名称
dateTimePicker1.Value = DateTime.Now.AddMonths(-1);//起始时间比截至时间早一个月
gridView1.IndicatorWidth = 45;
createDataForDataGrid(0);//表格初始装填数据
}
//获取站点群信息
public List<StationInfo> getStationInfoList()
{
List<StationInfo> lstStation = GlobalData.GlobalData_Station;
return lstStation;
}
//获取水库群信息
public List<ReservoirGroup> getReserviorList()
{
List<ReservoirGroup> lstStation = GlobalData.GlobalData_ReservoirGroup;
return lstStation;
}
//为datagrid准备数据
public void createDataForDataGrid(int flag)
{
DataTable dt = null;

if (0 == flag)
{
//测试用例
dt = new DataTable();
dt.Columns.Add("name", typeof(string));//方案名称
dt.Columns.Add("objName", typeof(string));//预测断面
dt.Columns.Add("model", typeof(string));//所用模型
dt.Columns.Add("tmRange", typeof(string));//预测时间范围
dt.Columns.Add("makeTm", typeof(string));//制定日期
dt.Columns.Add("makePerson", typeof(string));//制定人
dt.Columns.Add("detail", typeof(string));//详情
dt.Columns.Add("delete", typeof(string));//删除
dt.Columns.Add("release", typeof(string));//发布
dt.Columns.Add("chk", typeof(bool));//选择

DataRow dr = null;
dr = dt.NewRow();
dr[0] = "水库群1方案1";
dr[1] = "1号断面";
dr[2] = "模型11号";
dr[3] = "2014-07-01 08:00至2014-07-15 08:00";
dr[4] = "2014-06-25 12:00";
dr[5] = "周工";
dr[6] = "详情";
dr[7] = "删除";
dr[8] = "发布";
dr[9] = false;
dt.Rows.Add(dr);

dr = dt.NewRow();
dr = dt.NewRow();
dr[0] = "水库群1方案2";
dr[1] = "2号断面";
dr[2] = "模型2号";
dr[3] = "2014-07-01 08:00至2014-07-15 08:00";
dr[4] = "2014-06-25 12:00";
dr[5] = "周工";
dr[6] = "详情";
dr[7] = "删除";
dr[8] = "发布";
dr[9] = false;
dt.Rows.Add(dr);

dr = dt.NewRow();
dr[0] = "水库群1方案3";
dr[1] = "3号断面";
dr[2] = "模型6号";
dr[3] = "2014-07-01 08:00至2014-07-15 08:00";
dr[4] = "2014-06-25 12:00";
dr[5] = "周工";
dr[6] = "详情";
dr[7] = "删除";
dr[8] = "发布";
dr[9] = false;
dt.Rows.Add(dr);
this.gridControl1.DataSource = dt;//表格
}
if (1 == flag)
{
//测试用例
dt = new DataTable();
dt.Columns.Add("name", typeof(string));//方案名称
dt.Columns.Add("objName", typeof(string));//预测断面
dt.Columns.Add("model", typeof(string));//所用模型
dt.Columns.Add("tmRange", typeof(string));//预测时间范围
dt.Columns.Add("makeTm", typeof(string));//制定日期
dt.Columns.Add("makePerson", typeof(string));//制定人
dt.Columns.Add("detail", typeof(string));//详情
dt.Columns.Add("delete", typeof(string));//删除
dt.Columns.Add("release", typeof(string));//发布
dt.Columns.Add("chk", typeof(bool));//发布

DataRow dr = null;
dr = dt.NewRow();
dr[0] = "水库群2方案5";
dr[1] = "5号断面";
dr[2] = "模型11号";
dr[3] = "2014-07-16 08:00至2014-07-31 08:00";
dr[4] = "2014-07-15 12:00";
dr[5] = "何工";
dr[6] = "详情";
dr[7] = "删除";
dr[8] = "发布";
dr[9] = false;
dt.Rows.Add(dr);

dr = dt.NewRow();
dr = dt.NewRow();
dr[0] = "水库群2方案6";
dr[1] = "6号断面";
dr[2] = "模型12号";
dr[3] = "2014-07-16 08:00至2014-07-31 08:00";
dr[4] = "2014-07-15 12:00";
dr[5] = "何工";
dr[6] = "详情";
dr[7] = "删除";
dr[8] = "发布";
dr[9] = false;
dt.Rows.Add(dr);

dr = dt.NewRow();
dr[0] = "水库群2方案7";
dr[1] = "7号断面";
dr[2] = "模型13号";
dr[3] = "2014-07-16 08:00至2014-07-31 08:00";
dr[4] = "2014-07-15 12:00";
dr[5] = "何工";
dr[6] = "详情";
dr[7] = "删除";
dr[8] = "发布";
dr[9] = false;
dt.Rows.Add(dr);
this.gridControl1.DataSource = dt;//表格
}
else if (2 == flag)
{
//测试用例
dt = new DataTable();
dt.Columns.Add("name", typeof(string));//方案名称
dt.Columns.Add("objName", typeof(string));//预测断面
dt.Columns.Add("model", typeof(string));//所用模型
dt.Columns.Add("tmRange", typeof(string));//预测时间范围
dt.Columns.Add("makeTm", typeof(string));//制定日期
dt.Columns.Add("makePerson", typeof(string));//制定人
dt.Columns.Add("detail", typeof(string));//详情
dt.Columns.Add("delete", typeof(string));//删除
dt.Columns.Add("release", typeof(string));//发布
dt.Columns.Add("chk", typeof(bool));//发布

DataRow dr = null;
dr = dt.NewRow();
dr[0] = "水库群3方案8";
dr[1] = "8号断面";
dr[2] = "模型28号";
dr[3] = "2014-08-01 08:00至2014-08-15 08:00";
dr[4] = "2014-07-25 12:00";
dr[5] = "蒋工";
dr[6] = "详情";
dr[7] = "删除";
dr[8] = "发布";
dr[9] = false;
dt.Rows.Add(dr);

dr = dt.NewRow();
dr = dt.NewRow();
dr[0] = "水库群3方案9";
dr[1] = "9号断面";
dr[2] = "模型29号";
dr[3] = "2014-08-01 08:00至2014-08-15 08:00";
dr[4] = "2014-07-25 12:00";
dr[5] = "蒋工";
dr[6] = "详情";
dr[7] = "删除";
dr[8] = "发布";
dr[9] = false;
dt.Rows.Add(dr);

dr = dt.NewRow();
dr[0] = "水库群3方案10";
dr[1] = "10号断面";
dr[2] = "模型30号";
dr[3] = "2014-08-01 08:00至2014-08-15 08:00";
dr[4] = "2014-07-25 12:00";
dr[5] = "蒋工";
dr[6] = "详情";
dr[7] = "删除";
dr[8] = "发布";
dr[9] = false;
dt.Rows.Add(dr);
this.gridControl1.DataSource = dt;//表格
}
this.gridControl1.RefreshDataSource();
}
//表格数据增加,表格行序号自动增长
private void gridView1_CustomDrawRowIndicator(object sender, DevExpress.XtraGrid.Views.Grid.RowIndicatorCustomDrawEventArgs e)
{
if (e.Info.IsRowIndicator && e.RowHandle >= 0)
{
e.Info.DisplayText = (e.RowHandle + 1).ToString();
}

}
//切换下拉列表内容,改变表格数据
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
{
int flag = comboBox1.SelectedIndex;
createDataForDataGrid(flag);
ClearLines();


}

//datagrid行点击事件
private void gridView1_RowClick(object sender, DevExpress.XtraGrid.Views.Grid.RowClickEventArgs e)
{
//ClearLines();
// int count=e.RowHandle;//行号
LoadProgram();

}
/// <summary>
/// 清理曲线
/// </summary>
private void ClearLines()
{
this.chartControl1.Series.Clear();
}
//根据选中的行加载图形,方便用户直观对比
private void LoadProgram()
{
//int[] arr = this.gridView1.GetSelectedRows();
//时间-流量-水位

int stepNum = 5;
String[] rResultArr = {
"2014-07-01 08:00,5000,20|2014-07-02 08:00,5005,20.5|2014-07-03 08:00,5050,21|2014-07-04 08:00,5200,23|2014-07-05 08:00,5000,24|2014-07-06 08:00,4900,24.5|2014-07-07 08:00,4800,25|2014-07-08 08:00,4600,24|2014-07-09 08:00,4500,24.5|2014-07-10 08:00,4000,25",
"2014-07-16 08:00,7000,10|2014-07-17 08:00,7005,10.5|2014-07-18 08:00,7050,11|2014-07-19 08:00,7200,13|2014-07-20 08:00,7000,14|2014-07-21 08:00,6900,14.5|2014-07-22 08:00,6800,15|2014-07-23 08:00,6600,14|2014-07-24 08:00,6500,14.5|2014-07-25 08:00,4000,15",
"2014-08-01 08:00,4000,20|2014-08-02 08:00,4005,22|2014-08-03 08:00,4050,24|2014-08-04 08:00,4200,29|2014-08-05 08:00,4000,29|2014-08-06 08:00,3900,28|2014-08-07 08:00,3800,32|2014-08-08 08:00,3600,26|2014-08-09 08:00,3500,24.5|2014-08-10 08:00,3000,25"
};
this.chartControl1.Series.Clear();

bool bInitChk = Convert.ToBoolean(this.gridView1.GetFocusedRowCellValue("chk"));

List<int> selRows = new List<int>();
for (int i = 0; i < this.gridView1.RowCount; i++)
{
if (this.gridView1.GetRowCellValue(i, "chk") != null && Convert.ToBoolean(this.gridView1.GetRowCellValue(i, "chk")))
{
selRows.Add(i);
}
}
if (bInitChk)
{
selRows.Remove(this.gridView1.GetFocusedDataSourceRowIndex());
}
else
{
selRows.Add(this.gridView1.GetFocusedDataSourceRowIndex());
}
foreach (int i in selRows)
{
DataRowView dv = (DataRowView)this.gridView1.GetRow(i);
int count = i;
string name = dv[0].ToString();
string rResult = rResultArr[0];


//时间-流量曲线
var Series1 = new DevExpress.XtraCharts.Series(name + "流量", DevExpress.XtraCharts.ViewType.Spline);
//Series1.ArgumentScaleType = DevExpress.XtraCharts.ScaleType.DateTime;
Series1.LegendText = name + "流量";
string[] arrRs = rResult.Split('|');
for (int j = 0; j < arrRs.Length; j++)
{
string[] rs = arrRs[j].Split(',');
Series1.Points.Add(new DevExpress.XtraCharts.SeriesPoint(DateTime.Parse(rs[0]), double.Parse(rs[1]) + stepNum * count * 500));
}

//时间-水位曲线
var Series2 = new DevExpress.XtraCharts.Series(name + "水位", DevExpress.XtraCharts.ViewType.Spline);
Series2.LegendText = name + "水位";
Series2.View = splineSeriesView5;

//XYDiagram diagram = this.chartControl1.Diagram as XYDiagram;
//Series2.View.Assign((ChartElement)diagram.SecondaryAxesY[0]);


string[] arrRs2 = rResult.Split('|');
for (int j = 0; j < arrRs2.Length; j++)
{
string[] rs = arrRs2[j].Split(',');
// Series2.Points.Add()
var p1 = new DevExpress.XtraCharts.SeriesPoint(DateTime.Parse(rs[0]), double.Parse(rs[2]) + stepNum * count);
Series2.Points.Add(new DevExpress.XtraCharts.SeriesPoint(DateTime.Parse(rs[0]), double.Parse(rs[2]) + stepNum * count));
}
this.chartControl1.Series.Add(Series1);
this.chartControl1.Series.Add(Series2);
}
}

private void SolutionSelectFrm_Load(object sender, EventArgs e)
{
this.chartControl1.Series.Clear();
}

private void groupBox1_Enter(object sender, EventArgs e)
{

}

private void gridView1_RowCellClick(object sender, DevExpress.XtraGrid.Views.Grid.RowCellClickEventArgs e)
{
if (e.Column.FieldName == "chk")
{
LoadProgram();
}
}

private void repositoryItemCheckEdit1_Click(object sender, EventArgs e)
{
LoadProgram();
}

private void simpleButton1_Click(object sender, EventArgs e)
{

//XYDiagram diagram = this.chartControl1.Diagram as XYDiagram;
}
//


}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值