金沙澳门官网事件式实时下载更新滚动条进度数

作者: 网络编程  发布:2019-07-11

  关于下载更新数据于滚动条类似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)

        {

            

本文由金沙澳门官网发布于网络编程,转载请注明出处:金沙澳门官网事件式实时下载更新滚动条进度数

关键词: 金沙澳门官网

上一篇:开源一款强大的文件服务组件,安装说明
下一篇:没有了