C#使用winform实现进度条效果

 更新时间:2022年07月27日 14:11:08   作者:地狱高速公路  
这篇文章主要为大家详细介绍了C#使用winform实现进度条效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C#使用winform实现进度条效果的具体代码,供大家参考,具体内容如下

1.例子

2.点击查询按钮代码

private void button8_Click(object sender, EventArgs e)
        {
            string orgid = string.Empty;
            string scbz = string.Empty;
            if (comboBox7.SelectedIndex == -1)
            {
                orgid = "";
            }
            else
            {
                orgid = comboBox7.SelectedItem.ToString().Substring(0, 6);
            }
            if (comboBox8.SelectedIndex == -1)
            {
                scbz = "";
            }
            else
            {
                scbz = comboBox8.SelectedItem.ToString().Substring(0, 1);
            }
            Det_SummaryDataContext org = new Det_SummaryDataContext();
            var query = from item in org.Peo_EmployeeInfo
                        orderby item.StaID
                        where (string.IsNullOrEmpty(orgid) || item.StaID == orgid)
                            && (string.IsNullOrEmpty(scbz) || item.SCBZ == scbz)
                        select item;
            dataGridView4.DataSource = query.ToList();
            label16.Text = "共" + dataGridView4.RowCount + "条数据";
            progressBar1.Value = 0;//初始化进度条的值
            progressBar1.Minimum = 0;
            progressBar1.Maximum = dataGridView4.RowCount;//设置进度条范围
        }

3.点击手动上传按钮代码

private void button7_Click(object sender, EventArgs e)
        {
            if (dataGridView4.DataSource == null)
            {
                MessageBox.Show("没有需要上传的数据", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
            }
            else
            {
                int sumcout = 0;
                int upcount = 0;
                foreach (DataGridViewRow row in dataGridView4.SelectedRows)
                {
                    sumcout += 1;
                    progressBar1.Value++;//动态显示进度条进度
                    Application.DoEvents();//处理当前在消息队列中的所有windows消息
 
                    string orgid = row.Cells["StaID"].Value.ToString();
                    string empid = row.Cells["EmpID"].Value.ToString();
 
                    Det_SummaryDataContext det = new Det_SummaryDataContext();
                    string cityid = (from sys in det.Base_SystemParameter
                                     select sys.CityID).ToList()[0];
 
                    root r = new root();
                    head h = new head();
                    body b = new body();
                    string strxml = string.Empty;
                    string restr = string.Empty;
                    ServiceReference1.VeptsServiceImplClient vsc = new ServiceReference1.VeptsServiceImplClient();
                    int evl = 0;
 
                    var query1 = from ur in det.Peo_TUserRole
                                 join ri in det.Peo_RoleInfo on ur.RoleID equals ri.RoleID into A
                                 from urri in A.DefaultIfEmpty()
                                 select new
                                 {
                                     UADID = ur.UADID,
                                     RoleID = ur.RoleID,
                                     RoleName = urri.RoleName
                                 };
                    var query2 = from q in query1
                                 join tu in det.Peo_TUserRightRelation on q.UADID equals tu.UADID into B
                                 from qtu in B.DefaultIfEmpty()
                                 select new
                                 {
                                     UADID = q.UADID,
                                     RoleID = q.RoleID,
                                     RoleName = q.RoleName,
                                     EmpID = qtu.EmpID
                                 };
                    var query = from q in query2
                                join ei in det.Peo_EmployeeInfo on q.EmpID equals ei.EmpID into C
                                from qei in C.DefaultIfEmpty()
                                where qei.EmpID == empid
                                select new JCZ03
                                {
                                    idcardno = qei.IDNumber,
                                    tsno = cityid + qei.StaID.Substring(4, 2),
                                    personname = qei.EmpName,
                                    culturegrade = qei.Educational,
                                    workdate = qei.DivisionTime,
                                    //1站长 2技术负责人 3质量负责人 4外检员 5登录员 6驾控员 7尾气操作员 8其他
                                    jobduty = q.RoleID == "130100002" ? "5" : q.RoleID == "130100003" ? "7" : q.RoleID == "130100004" ? "7" : q.RoleID == "130100005" ? "6" : q.RoleID == "130100006" ? "1" : "8",
                                    //状态(0:未审;1:在岗;2:离职,3 锁止)
                                    state = qei.EmpState == "0" ? "1" : "2"
                                };
 
                    List<JCZ03> jcz033 = query.ToList<JCZ03>();
                    h.organ = Properties.Settings.Default.JKBH;
                    h.jkxlh = Properties.Settings.Default.JKXLH;
                    h.jkid = "JCZ03";
                    b.vehispara = jcz033[0];
                    r.head = h;
                    r.body = b;
                    strxml = Other.XmlSerialize<root>(r);
                    Other.WriteLwLog(strxml);//打印发送日志
                    restr = System.Web.HttpUtility.UrlDecode(vsc.write(strxml));
                    Other.WriteLwLog(restr,false);//打印接受日志
                    if (!restr.Contains(@"<code>1</code>"))
                    {
                        evl += 1;
                    }
                    if (evl == 0)
                    {
                        var query3 = from item in det.Peo_EmployeeInfo
                                    where item.StaID == orgid && item.EmpID == empid
                                    select item;
                        foreach (var item in query3)
                        {
                            item.SCBZ = "O";
                        }
                        det.SubmitChanges();
                        upcount += 1;//上传数量 成功上传一条就自增1 
                    }
                    else
                    {
                        var query3 = from item in det.Peo_EmployeeInfo
                                    where item.StaID == orgid && item.EmpID == empid
                                    select item;
                        foreach (var item in query3)
                        {
                            item.SCBZ = "E";
                        }
                        det.SubmitChanges();
                    }
                }
                MessageBox.Show(string.Format("选中{0}条数据,成功上传{1}条!", sumcout, upcount), "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
            }
}

4.思路

首先设置processBar的范围,该范围就是要动态处理数据集的大小。

然后在foreach循环里设置进度条值自增,即processBar.Value++;

最后加上一句Application.DoEvents(); 用来刷新UI显示进度条进度。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C#实现调用迅雷下载的方法

    C#实现调用迅雷下载的方法

    这篇文章主要介绍了C#实现调用迅雷下载的方法,非常实用的一个技巧,对于进行C#程序设计有很好的借鉴价值,需要的朋友可以参考下
    2014-08-08
  • C# WinForm创建Excel文件的实例

    C# WinForm创建Excel文件的实例

    下面小编就为大家带来一篇C# WinForm创建Excel文件的实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • 解析C#中的常量及如何在C#编程中定义常量

    解析C#中的常量及如何在C#编程中定义常量

    这篇文章主要介绍了C#中的常量及如何在C#编程中定义常量,是C#入门学习中的基础知识,需要的朋友可以参考下
    2016-01-01
  • C#中变量、常量、枚举、预处理器指令知多少

    C#中变量、常量、枚举、预处理器指令知多少

    这篇文章主要介绍了c#共有其中变量类型有:静态变量、实类变量、数组元素、数值参数、引用参数、输出参数和局部变量,需要的朋友可以参考一下
    2017-04-04
  • C# wpf Canvas中实现控件拖动调整大小的示例

    C# wpf Canvas中实现控件拖动调整大小的示例

    本文主要介绍了C# wpf Canvas中实现控件拖动调整大小的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • C#、.Net中把字符串(String)格式转换为DateTime类型的三种方法

    C#、.Net中把字符串(String)格式转换为DateTime类型的三种方法

    这篇文章主要介绍了C#、.Net中把字符串(String)格式转换为DateTime类型的三种方法,本文总结了Convert.ToDateTime(string)、Convert.ToDateTime(string, IFormatProvider)、DateTime.ParseExact()三种方法,需要的朋友可以参考下
    2015-07-07
  • 基于WPF制作一个可编程画板

    基于WPF制作一个可编程画板

    这篇文章主要为大家详细介绍了如何基于WPF制作一个可编程画板,文中的示例代码讲解详细,对我们学习或工作有一定帮助,感兴趣的小伙伴可以了解一下
    2023-05-05
  • C#字符串与数值类型、字节数组的互相转换实战案例

    C#字符串与数值类型、字节数组的互相转换实战案例

    最近由于编程的需要,对C#的类型转换做了一些研究,下面这篇文章主要给大家介绍了关于C#字符串与数值类型、字节数组的互相转换的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-06-06
  • .net2.0+ Winform项目实现弹出容器层

    .net2.0+ Winform项目实现弹出容器层

    在实际工作中,如果能像菜单一样弹出自定义内容,会方便很多,比如查询时,比如下拉列表显示多列信息时,比如在填写某个信息需要查看一些信息树时。这个时候自定义弹出界面就显的非常重要了
    2015-08-08
  • C#封装DBHelper类

    C#封装DBHelper类

    DBHelper类是用类将ADO.NET用方法封装起来,用以减少程序员的工作量。本文为大家提供一个C#封装的DBHelper类,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05

最新评论