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

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;
        }
        //





    }
}
分享到:
评论

相关推荐

    DevExpress实现GridControl列头绘制Checkbox的方法

    本文实例展示了DevExpress实现GridControl列头绘制Checkbox的方法,具体实现方法如下: 主要功能代码如下: /// /// 为列头绘制CheckBox /// /// &lt;param name=view&gt;GridView /// &lt;param name=checkItem&gt;...

    获取GridView中Checkbox的值

    在ASP.NET开发中,GridView控件常用于展示数据表格,而Checkbox则经常被用来实现用户选择功能。在“获取GridView中Checkbox的值”这个场景下,我们通常关注的是如何在用户交互后,如点击按钮时,获取到GridView中被...

    GridView动态隐藏某列

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

    Dev GridView 拖拽行进行排序

    总的来说,实现Dev GridView的拖拽行排序涉及多个事件的处理和数据源的动态调整。这个特性增强了用户交互性,使得对大量数据的排序变得更加直观。在实际开发中,还需要考虑性能优化,特别是处理大量数据时,以避免...

    js获得Gridview中选中checkbox行的信息

    1. **事件绑定**:为GridView中的Checkbox添加点击事件监听器。可以使用`addEventListener`方法来实现,例如: ```javascript var checkboxes = document.querySelectorAll('.gridview input[type="checkbox"]'); ...

    dev_GridView多表头合并.rar

    在.NET开发领域,GridView控件是ASP.NET Web Forms中常用的一种数据展示组件,它能够方便地将数据库中的数据以表格的形式展示出来。本教程重点讨论如何实现“dev_GridView”多表头合并,以创建更复杂的二维表头,...

    GridView合计列

    当我们在Web应用程序中处理大量数据时,经常需要计算某一列或多列的总计。在本篇内容中,我们将深入探讨如何通过代码实现GridView控件的合计列功能,以便更好地理解和应用在实际项目中。 首先,了解GridView的基本...

    C#中GridView动态添加列的实现方法

    总的来说,C#中动态添加GridView列的关键在于理解和使用TemplateField或BoundField等列类型,以及正确地处理数据绑定和模板设置。这个过程使得开发更加灵活,能够适应各种不同的数据展示需求。希望上述内容能对你的...

    Gridview中checkBox选择数据的使用

    1. **在Gridview中添加CheckBox列**:首先需要在Gridview中定义一个包含CheckBox的模板列(TemplateField),并通过`ItemTemplate`来指定CheckBox控件。 ```html 选择"&gt; &lt;asp:CheckBox ID="Upgradingchk" ...

    GridView控件中CheckBox(2.0)

    要实现在GridView中显示CheckBox,我们通常会定义一个BoundField或TemplateField。如果是模板字段,我们可以直接在ItemTemplate中添加CheckBox控件。以下是一个简单的示例: ```asp &lt;asp:GridView ID="gvData" ...

    GridView和CheckBox结合

    在Web开发中,`GridView`控件常被用于展示数据表,而`CheckBox`则用于提供用户选择或切换某些功能的能力。将两者结合使用,可以实现对多条记录的批量操作,如删除、编辑等。本文将基于提供的代码示例来详细解析`...

    GridView表格抬头列值复选筛选

    GridView由多个列(BoundField、TemplateField等)组成,每一列可以显示数据源中的一个字段。在“抬头”即表头部分,我们可以添加自定义的HTML或控件来实现扩展功能,如添加三角图标。 实现复选筛选的第一步是在...

    winform中gridview的checkbox使用案例

    1. 静态添加:在设计视图中,右键点击GridView,选择"Edit Columns",然后添加一个"DataGridViewTextBoxColumn",将其显示样式设置为"CheckBox"。 2. 动态添加:在代码中创建并设置Checkbox列。 ```csharp ...

    Gridview动态添加列 根据需要添加列和进行增删改操作

    Gridview动态添加列 根据需要添加列和进行增删改操作 京华志&精华志出品 希望大家互相学习,互相进步 支持CSDN 支持微软 主要包括C# ASP.NET SQLDBA 源码 毕业设计 开题报告 答辩PPT等

    GridView 冻结列和行

    GridView是ASP.NET中一个常用的控件,用于展示数据表格,常用于网页开发。在实际应用中,有时我们需要在用户滚动页面时保持某些列或行始终可见,这就是所谓的“冻结列和行”功能。这个功能可以帮助用户更好地浏览和...

    GridView与CheckBox结合

    首先,我们需要创建一个自定义的Adapter,这个Adapter将负责填充GridView的数据并处理CheckBox的状态。自定义Adapter通常继承自BaseAdapter,我们需要重写其中的几个关键方法: 1. `getCount()`: 返回GridView中的...

    GridView头部放一个CheckBox

    `GridView`是ASP.NET中一个非常强大的数据绑定控件,它允许用户以表格形式显示数据。`GridView`提供了多种特性,如排序、分页、编辑等,非常适合展示大量数据。 #### 二、在`GridView`头部放置CheckBox 要在`...

    GridView和CheckBox结合使用

    2. **数据绑定**:在`getView()`方法内,使用`convertView.findViewById()`找到CheckBox,并根据数据源设置其初始状态。可以通过设置CheckBox的`setOnCheckedChangeListener`监听器来跟踪用户的选中状态变化。 3. *...

    GridView中选择checkBox的项删除事件

    - 根据删除操作的结果显示不同的提示消息,并重新绑定`GridView`以更新数据显示。 - 如果没有选中任何复选框,则提示用户必须至少选择一项。 ##### 2. `Button3_Click` 方法 ```csharp protected void Button3_...

Global site tag (gtag.js) - Google Analytics