[转]dataGridView控件DateTime列插入DateTimePicker

本文介绍了一个在DataGridView中集成DateTimePicker的方法,使得用户可以在表格中的日期字段上直接选择日期。该实现包括了显示和隐藏DateTimePicker控件的逻辑,以及如何将所选日期同步回DataGridView。

来自:http://www.cnblogs.com/ojekleen/articles/dataGridView.html

 

public Form1()
        {
            InitializeComponent();
        }


        //定义一个DateTimePicker控件
        private DateTimePicker dTimePicker = new DateTimePicker();

        //定义一个DataSet
        private DataSet ds;
       
        private void Form1_Load(object sender, EventArgs e)
        
            //隐藏dTimePicker
            dTimePicker.Visible = false;
            
            //dataGirdView1控件数据绑定
            Data_Bind();


            //定义控件dTimePicker当Text变更时委托于事件dTimePicker_TextChanged
            dTimePicker.TextChanged += new EventHandler(dTimePicker_TextChanged);

            //dataGridView1添加控件dTimePicker
            dataGridView1.Controls.Add(dTimePicker);
        }


        /**//// <summary>
        /// dataGirdView绑定数据
        /// </summary>

        private void Data_Bind()
        {
            string sqlstr = "select businessname,lastlogindate from business";
            ds = SqlHelper.ExecuteDS(CommandType.Text, sqlstr);
            dataGridView1.DataSource = ds.Tables[0].DefaultView;
        }



        //事件dTimePicker_TextChanged,当dTimePicker当Text变更时触发
        private void dTimePicker_TextChanged(object sender, EventArgs e)
        {
            //把dTimePicker的Text值赋给dataGridView1选中的单元格值
            dataGridView1.CurrentCell.Value = dTimePicker.Text;
        }

        
        private void dataGridView1_Scroll(object sender, ScrollEventArgs e)
        {
            //当dataGridView1滚动条移动时dTimePicker控件隐藏
            dTimePicker.Visible = false;
        }


        private void dataGridView1_ColumnWidthChanged(object sender, DataGridViewColumnEventArgs e)
        {
            //当dataGridView1的列宽改变时dTimePicker控件隐藏
            dTimePicker.Visible = false;

        }


        private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e)
        {
            //判断选中行时日期类型
            //dt = ds.Tables[0];
            Type t = ds.Tables[0].Columns[dataGridView1.CurrentCell.ColumnIndex].DataType;
            DateTime d = DateTime.Now;
            if (t== d.GetType() )
            {
                //获得dataGridView1选中单元格显示区域的矩形
                Rectangle Rect = this.dataGridView1.GetCellDisplayRectangle(this.dataGridView1.CurrentCell.ColumnIndex, this.dataGridView1.CurrentCell.RowIndex, false);
                //显示dTimePicker在dataGridView1选中单元格显示区域的矩形里面,即选中单元格内
                dTimePicker.Visible = true;
                dTimePicker.Top = Rect.Top;
                dTimePicker.Left = Rect.Left;
                dTimePicker.Height = Rect.Height;
                dTimePicker.Width = Rect.Width;
                //dTimePicker控件获取初始值为dataGridView1选中单元格值
                dTimePicker.Text=dataGridView1.CurrentCell.Value.ToString();

            }

        }

转载于:https://www.cnblogs.com/2008freestyle/archive/2012/04/10/2441163.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值