来自 威尼斯国际官方网站 2019-10-02 13:50 的文章
当前位置: 威尼斯国际官方网站 > 威尼斯国际官方网站 > 正文

威尼斯国际官方网站事件式实时下载更新滚动条

  关于下载更新数据于滚动条类似PrograssBar控件的问题,我网上搜索了下,总体结合大致采用微软的定时器Timer控件更新数据。

    public class ImportExportToExcel

  在网上发现了典型的例子是使用TImer定时器和BackgroundWorker组件的结合更新PrograssBar进度的操作,网址如下:

    {

 

        private string strConn ;

  但是使用Timer定时器更新滚动条并非实时更新数据,顶多只是尽量模拟程序执行的步骤,本篇文章采用另一种下载更新滚动条数据的方式来实现实时更新数据,结合WebService网络服务和线程执行操作。

        

  •   关于WebService的引用大致分为组件引用和网址引用,如图:威尼斯国际官方网站 1
  •   关于WebService的部署和发布,结合本地IIS方式,如图:

        private System.Windows.Forms.OpenFileDialog openFileDlg=new System.Windows.Forms.OpenFileDialog();

  威尼斯国际官方网站 2

        private System.Windows.Forms.SaveFileDialog saveFileDlg=new System.Windows.Forms.SaveFileDialog();      

威尼斯国际官方网站 3

        

  (1)主程序入口:

        public ImportExportToExcel()

/// <summary>
/// 应用程序的主入口点。
/// </summary>
[STAThread]
static void Main()
{
  Application.EnableVisualStyles();
  Application.SetCompatibleTextRenderingDefault(false);
  //Application.Run(new Form1());
  System.Threading.Thread thread = new System.Threading.Thread(new System.Threading.ThreadStart(UpdateLoading));
  thread.Start();
}

        {

static void UpdateLoading()
{
  ConvMyReord.Uil.Welcome.DownLoader downLoader = new Uil.Welcome.DownLoader();
  downLoader.Show();
  downLoader.Start();
}

            //

  (2)DownLoader类:

            // TODO: 在此处添加构造函数逻辑

private void downLoading_DownLoadingCancelEvnet()
{
  if (_downLoading != null && _downLoading.GetDialogResult == DialogResult.No)
  Application.Exit();
}

            //

public void Start()
{
  if (_downLoading == null) _downLoading = new DownLoading();
  _downLoading.Dock = DockStyle.Fill;
  this.pnlMain.Controls.Add(_downLoading);
  _downLoading.DownLoadingCancelEvnet += downLoading_DownLoadingCancelEvnet;
  _downLoading.StartDownLoading();
}

            this.openFileDlg.DefaultExt = "xls";

  (3)自定义控件:DownLoading

            this.openFileDlg.Filter = "Excel文件 (*.xls)|*.xls";

威尼斯国际官方网站 4

            this.saveFileDlg.DefaultExt="xls";

public delegate void DownLoadingCancel();
public event DownLoadingCancel DownLoadingCancelEvnet;
public DialogResult GetDialogResult {get;set;}

            this.saveFileDlg.Filter= "Excel文件 (*.xls)|*.xls";

private void btnCancel_Click(object sender, EventArgs e)
{
  if(DownLoadingCancelEvnet != null)
  {
    this.GetDialogResult = DialogResult.No;
    DownLoadingCancelEvnet();
  }
}

        }

public void StartDownLoading()
{
  ConvMyReord.WebReference.ConverRecordWebService converRecordWebService
  = new WebReference.ConverRecordWebService();
  System.Data.DataSet ds = converRecordWebService.DownLoadingScoure();//调用服务方法
  DownLoadHelper downLoadHelper = new DownLoadHelper();
  downLoadHelper.DownLoadProgressEvent += downloader_onDownLoadProgress;
  downLoadHelper.StartLoading(ds, this.progressBarControl1, lblDownLoad);
}

        从Excel文件导入到DataSet#region 从Excel文件导入到DataSet

//同步更新UI
private void downloader_onDownLoadProgress(long totalCount, long current)
{
  float percent = 0;
  if (this.InvokeRequired)
  {
    this.Invoke(new DownLoadHelper.DownLoadProgress(downloader_onDownLoadProgress), new object[] { totalCount, current });
  }
  else
  {
    if (this.progressBarControl1.Properties.Maximum == this.progressBarControl1.Position)
    {
      this.GetDialogResult = DialogResult.Yes;
      this.btnCancel.Enabled = false;
    }
    this.progressBarControl1.Properties.Maximum = (int)totalCount;
    this.progressBarControl1.Position = (int)current;
    percent = (float)current / (float)totalCount * 100;
    this.lblDownLoad.Text = "当前补丁下载进度:" + percent.ToString()

        //        /// <summary>

  • "%";
        System.Windows.Forms.Application.DoEvents();
      }
    }

        //        /// 从Excel导入文件

  (4)DownLoadHelper帮助类:

        //        /// </summary>

public delegate void DownLoadProgress(long total, long current);
public event DownLoadProgress DownLoadProgressEvent;

        //        /// <param name="strExcelFileName">Excel文件名</param>

public void StartLoading(System.Data.DataSet ds, DevExpress.XtraEditors.ProgressBarControl progressBar1, System.Windows.Forms.Label label1)
{
  if (ds == null) return;
  long totalCount = GetRowCounts(ds);
  LoadingData(totalCount, ds, progressBar1, label1);
}

        //        /// <returns>返回DataSet</returns>

private static long GetRowCounts(System.Data.DataSet ds)
{
  long count = 0;
  if (ds.Tables.Count <= 0) return count;
  for (int i = 0; i < ds.Tables.Count; i++)
  {
    System.Data.DataTable table = ds.Tables[i];
    count += table.Rows.Count;
  }
  return count;
}

        //        public DataSet ImportFromExcel(string strExcelFileName)

public void LoadingData(long totalCount, System.Data.DataSet ds, DevExpress.XtraEditors.ProgressBarControl progressBar1, System.Windows.Forms.Label label1)
{
  if (totalCount <= 0 || ds.Tables.Count <= 0) return;
  long count = 0;
  for (int i = 0; i < ds.Tables.Count; i++)
  {
    System.Data.DataTable table = ds.Tables[i];
    if (table == null || table.Rows.Count <= 0) continue;
    for (int j = 0; j < table.Rows.Count; j++)
    {
      ++count;
      System.Windows.Forms.Application.DoEvents();
      if (DownLoadProgressEvent != null)
      DownLoadProgressEvent(100, (100/totalCount) * count);
       System.Threading.Thread.Sleep(100);
    }
  }
}

        //        {

效果图:

威尼斯国际官方网站 ,        //            return doImport(strExcelFileName);

威尼斯国际官方网站 5

        //        }

 

        /**//// <summary>

  以上是我前段时间自己编的部分程序,考虑从内存空间和效率上都存在不足,本篇主要是让大家了解事件式实时更新滚动条数据的编程思路,不足之处,请留言赐教。
  A young idler  ~  an old beggar !

        /// 从选择的Excel文件导入

        /// </summary>

        /// <returns>DataSet</returns>

        public DataSet ImportFromExcel()

        {

            DataSet ds=new DataSet();

            if (openFileDlg.ShowDialog() == System.Windows.Forms.DialogResult.OK) 

                ds=doImport(openFileDlg.FileName);

            return ds;

        }

        /**//// <summary>

        /// 从指定的Excel文件导入

        /// </summary>

        /// <param name="strFileName">Excel文件名</param>

        /// <returns></returns>

        public DataSet ImportFromExcel(string strFileName)

        {

            DataSet ds=new DataSet();

            ds=doImport(strFileName);

            return ds;

        }

        /**//// <summary>

        /// 执行导入

        /// </summary>

        /// <param name="strFileName">文件名</param>

        /// <returns>DataSet</returns>

        private DataSet doImport(string strFileName)

        {

            if (strFileName=="") return null;

              

            strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" +

                "Data Source=" +  strFileName + ";" +

                "Extended Properties=Excel 8.0;";

            OleDbDataAdapter ExcelDA = new OleDbDataAdapter("SELECT * FROM [Sheet1$]", strConn);

            DataSet ExcelDs = new DataSet();

            try

            {

                ExcelDA.Fill(ExcelDs, "ExcelInfo");

                

            }

            catch(Exception err)

            {

                System.Console.WriteLine( err.ToString() );

            }

            return ExcelDs;

            

            

        

        }

        #endregion

        从DataSet到出到Excel#region 从DataSet到出到Excel

        /**//// <summary>

        /// 导出指定的Excel文件

        /// </summary>

        /// <param name="ds">要导出的DataSet</param>

        /// <param name="strExcelFileName">要导出的Excel文件名</param>

        public void ExportToExcel(DataSet ds,string strExcelFileName)

        {

            if (ds.Tables.Count==0 || strExcelFileName=="") return;

            doExport(ds,strExcelFileName);

    

        }

        /**//// <summary>

        /// 导出用户选择的Excel文件

        /// </summary>

        /// <param name="ds">DataSet</param>

        public void ExportToExcel(DataSet ds)

        {

            if (saveFileDlg.ShowDialog() == System.Windows.Forms.DialogResult.OK) 

                doExport(ds,saveFileDlg.FileName);

            

        }

        /**//// <summary>

        /// 执行导出

        /// </summary>

        /// <param name="ds">要导出的DataSet</param>

        /// <param name="strExcelFileName">要导出的文件名</param>

        private void doExport(DataSet ds,string strExcelFileName)

        {

            

本文由威尼斯国际官方网站发布于威尼斯国际官方网站,转载请注明出处:威尼斯国际官方网站事件式实时下载更新滚动条

关键词: