快捷搜索:
来自 计算机编程 2019-08-17 19:21 的文章
当前位置: 67677新澳门手机版 > 计算机编程 > 正文

事件式实时下载更新滚动条进程数据

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

            openFileDlg.Filter= "xml文件 (*.xml)|*.xml";

 

        {

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

        /// </summary>

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.Application excel= new Excel.Application();

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

        

  (3)自定义控件:DownLoading

            return ds;

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

        /// <returns>DataSet</returns>

 

        //        public DataSet ImportFromExcel(string strExcelFileName)

  (1)主程序入口:

        //            return doImport(strExcelFileName);

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

        private DataSet doImport(string strFileName)

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

        /**//// <summary>

  (2)DownLoader类:

            return ds;

private static long GetRowCounts(System.Data.DataSet ds)
{
  long count = 0;
67677新澳门手机版 ,  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;
}

        {

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

            return ExcelDs;

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

                "Data Source="  strFileName ";"

67677新澳门手机版 1

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

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

            saveFileDlg.Filter= "xml文件 (*.xml)|*.xml";

效果图:

            foreach(DataRow row in table.Rows)

67677新澳门手机版 2

        /// </summary>

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

        public DataSet ImportFromExcel(string strFileName)

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

        /**//// <summary>

  •   关于WebService的引用大致分为组件引用和网址引用,如图:67677新澳门手机版 3
  •   关于WebService的部署和发布,结合本地IIS方式,如图:

            

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

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

  67677新澳门手机版 4

        }

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

        /// 执行导出

//同步更新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()

        /// <returns></returns>

67677新澳门手机版 5

            

  (4)DownLoadHelper帮助类:

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

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

                colIndex ;    

        

        }

            {ds.WriteXml(strXMLFileName,System.Data.XmlWriteMode.WriteSchema );}

            return ds;

        /**//// <summary>

        /// <returns>DataSet</returns>

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

        /// </summary>

        }

        {

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

                excel.Cells[1,colIndex]=col.ColumnName;                

        {

            

        /// </summary>

                {

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

            excel.Quit();

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

        /**//// <summary>

        //        }

    {

            if (strFileName=="") return null;

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

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

            }

            System.Data.DataTable table=ds.Tables[0] ;

            //            obj.SaveAs("c:zn.xls",Excel.XlFileFormat.xlExcel9795,null,null,false,false,Excel.XlSaveAsAccessMode.xlNoChange,null,null,null,null);

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

        }

            catch(Exception err)

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

        /// <returns></returns>

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

            saveFileDlg.DefaultExt="xml";

        private string strConn ;

        /// </summary>

                    colIndex ;

            {

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

        {

        public DataSet ImportFromExcel()

        /// </summary>

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

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

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

            //wkbNew.SaveAs strBookName

        #endregion

            openFileDlg.DefaultExt="xml";

            excel.Application.Workbooks.Add(true);

        //        /// </summary>

        }

        //        /// <summary>

        public void ExportToExcel(DataSet ds,string strExcelFileName)

        {

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

                colIndex=0;

                "Extended Properties=Excel 8.0;";

    

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

            doExportXML(ds,strXMLFileName);

        private void doExport(DataSet ds,string strExcelFileName)

    }

        }

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

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

            

            }

        从DataSet导出到XML#region 从DataSet导出到XML

                ds=doImport(openFileDlg.FileName);

            DataSet ds=new DataSet();

            excel.ActiveWorkbook.SaveAs(strExcelFileName ".XLS",Excel.XlFileFormat.xlExcel9795,null,null,false,false,Excel.XlSaveAsAccessMode.xlNoChange,null,null,null,null);

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

        }

            //            Excel.Workbook obj=new Excel.WorkbookClass();

            //

            doExport(ds,strExcelFileName);

            

        /// </summary>

本文由67677新澳门手机版发布于计算机编程,转载请注明出处:事件式实时下载更新滚动条进程数据

关键词: