`
Franciswmf
  • 浏览: 800293 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

dev 点击gridview某行切换chart显示

 
阅读更多
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;

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));//发布

                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] = "发布";
                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] = "发布";
                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] = "发布";
                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));//发布

                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] = "发布";
                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] = "发布";
                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] = "发布";
                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));//发布

                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] = "发布";
                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] = "发布";
                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] = "发布";
                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();

            int[] arr = this.gridView1.GetSelectedRows();
            for(int i=0;i<arr.Length;i++)
            {
                DataRowView dv = (DataRowView)this.gridView1.GetRow(arr[i]);
                int count = arr[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;


                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(p1);
                }
                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)
        {

        }
        //





    }
}
分享到:
评论

相关推荐

    Dev GridView 拖拽行进行排序

    默认情况下,Dev GridView并不支持直接拖拽行进行排序,但可以通过自定义事件处理程序来实现这一功能。 1. **开启拖放支持**:在Dev GridView控件上设置`AllowDragDrop`属性为`true`,以启用拖放功能。同时,设置`...

    GridView高亮显示某行

    ### GridView高亮显示某行 在Web开发中,特别是使用ASP.NET进行开发时,GridView控件是用于展示数据的一种常用工具。它可以帮助开发者快速地创建一个格式化的表格,并且可以非常方便地添加分页、排序等功能。而在...

    任意改变GridView某一行颜色和任意单元格颜色

    在开发过程中,我们有时需要根据业务需求改变GridView中的某一行或特定单元格的颜色,以突出显示特定数据或者达到更好的视觉效果。以下是对这个主题的详细解释: 1. GridView概述: GridView是ASP.NET Web Forms中...

    dev_GridView多表头合并.rar

    本教程重点讨论如何实现“dev_GridView”多表头合并,以创建更复杂的二维表头,增强数据可视化效果。 在GridView控件中,通常的表头只有一行,但在处理某些复杂的数据结构时,如需要展示层次化或者分类的数据,多...

    GridView添加合计行的实现方案

    在处理大量数据时,有时候我们需要在GridView的底部添加一个合计行,以便快速查看数据的总和或其他统计信息。本篇将详细介绍如何通过代码实现动态地为GridView添加合计行。 首先,理解GridView的基本结构和功能。...

    DevExpress GridControl GridView新增行数据解决方案

    2. 新行模板未配置:在GridView中,新行的模板可能需要设置,以显示默认的字段值或允许用户输入新数据。如果不配置,可能会导致无法输入数据。 3. 事件处理不完整:在添加新行时,可能需要处理相关的事件,如...

    C# Dev GridView 三级主从表示例

    编写事件处理代码以响应用户操作,如点击主表的行或展开按钮。这可能涉及数据绑定和解绑,以及根据需要加载或刷新从表的数据。 6. **性能优化**: 由于三级主从表可能会显示大量数据,因此要注意性能优化。可以...

    Gridview点击切换图片

    在这个“GridView点击切换图片”的场景中,我们主要涉及以下几个关键知识点: 1. GridView的基本使用: GridView继承自AbsListView,用于显示一列或多列的相同大小的项目。通过设置`android:numColumns`属性可以...

    Dev GridView绑定测试demo

    在这个"Dev GridView绑定测试demo"中,我们将探讨如何利用`GridView`绑定不同的数据源,包括`List&lt;T&gt;`、`BindingList&lt;T&gt;`以及`BindingSource`。这些技术对于任何需要在用户界面中显示动态数据的开发者来说都是至关...

    DevExpress GridControl GridView 新增行/删除行 AddNewRow /InitNewRow

    针对DevExpress GridControl GridView 新增行AddNewRow() 很多人加了代码也无法实现添加行或者添加行后InitNewRow这个事件没有触发, 其中主要原因见附件实例代码!

    DEV GridControl GridView导出到Excel 支持多个Sheet 源码

    然后,获取GridView中的数据,这可以通过遍历GridView的行和列来实现。数据通常是二维的,与Excel的单元格对应。 接下来,将数据写入到对应的Sheet中。在NPOI中,可以创建一个HSSFWorkbook对象代表整个Excel文件,...

    GridView 行单击与双击事件

    GridView 行单击与双击事件,功能:单击选中行 双击打开详细页面 说明:

    点击GridView行变色

    2. 将当前被点击行的背景色改为`PeachPuff`,以显示已被选中。 3. 保存点击行的ID到隐藏字段`Hidden2`,以便后续处理。 4. 获取其他隐藏字段的值,可能用于页面跳转或处理其他业务逻辑。 5. 更新父窗口中的iframe的...

    GridView添加行并且默认显示行数

    ### GridView添加行并且默认显示行数 #### 背景介绍 在开发Web应用程序时,尤其是在.NET框架下使用ASP.NET,经常会遇到需要处理表格数据的情况。`GridView`控件是ASP.NET提供的一个非常强大且灵活的数据绑定控件,...

    GridView动态隐藏某列

    ### GridView动态隐藏某列 在Web开发中,`GridView`是一种非常常见的用于显示表格数据的控件。在ASP.NET中,`GridView`提供了强大的数据绑定功能,并且支持各种交互操作,如排序、分页等。有时为了适应不同的业务...

    GridView选定行(续)

    当用户点击某一行时,该行会变为高亮显示,表示被选中。这个过程可以通过设置GridView的`AllowSelectingRows`属性来控制。如果希望禁用行选择,可以将其设置为`false`。 要实现GridView选定行的跟踪,我们需要监听`...

    Dev GridView 嵌入 进度条+ GaugeControl

    在本场景中,我们关注的是如何在Windows Forms应用程序中使用Dev组件库(可能指的是DevExpress)的GridView控件和GaugeControl来创建一个增强的用户界面,其中包含了进度条功能。以下是关于这两个控件及其结合使用的...

    鼠标停留在GridView某一行时,行的颜色改变

    在某些场景下,我们可能希望在用户鼠标悬停在GridView的某一行时,该行的颜色有所改变,以提供更好的用户交互体验。这个功能可以通过自定义样式和事件处理来实现。 首先,我们需要了解GridView的基本结构和工作原理...

    winform gridview最下面的合计

    当我们需要在GridView的最后一行显示总计或汇总信息时,这通常涉及到数据绑定、自定义列以及事件处理等方面的知识点。以下是对“winform gridview最下面的合计行”这一主题的详细解释。 1. **数据绑定**: - ...

    GridView 单选和全选功能以及全选操作和取消全选

    在GridView上方添加一个全选按钮,点击时将所有项的选中状态切换。这需要在Adapter中维护一个全局的全选状态变量,当全选按钮被点击时,遍历数据源,将所有项的选中状态设为全选状态。同时,如果用户手动改变了某一...

Global site tag (gtag.js) - Google Analytics