當前位置: 首頁>>代碼示例>>C#>>正文


C# BackgroundWorker.ReportProgress方法代碼示例

本文整理匯總了C#中BackgroundWorker.ReportProgress方法的典型用法代碼示例。如果您正苦於以下問題:C# BackgroundWorker.ReportProgress方法的具體用法?C# BackgroundWorker.ReportProgress怎麽用?C# BackgroundWorker.ReportProgress使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在BackgroundWorker的用法示例。


在下文中一共展示了BackgroundWorker.ReportProgress方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: ReportProgressNonBusy

 public void ReportProgressNonBusy()
 {
     var b = new BackgroundWorker<object, object, object>
                 {
                     WorkerReportsProgress = true
                 };
     Assert.IsFalse(b.IsBusy);
     b.ReportProgress(0);
 }
開發者ID:GTuritto,項目名稱:ngenerics,代碼行數:9,代碼來源:BackgroundWorkerTest.cs

示例2: TestBackgroundWorkerBasic

        public void TestBackgroundWorkerBasic()
        {
            var orignal = SynchronizationContext.Current;
            try
            {
                SynchronizationContext.SetSynchronizationContext(null);

                const int expectedResult = 42;
                const int expectedReportCallsCount = 5;
                int actualReportCallsCount = 0;
                var worker = new BackgroundWorker() { WorkerReportsProgress = true };
                var progressBarrier = new Barrier(2, barrier => ++actualReportCallsCount);
                var workerCompletedEvent = new ManualResetEventSlim(false);

                worker.DoWork += (sender, e) =>
                {
                    for (int i = 0; i < expectedReportCallsCount; i++)
                    {
                        worker.ReportProgress(i);
                        progressBarrier.SignalAndWait();
                    }

                    e.Result = expectedResult;
                };
                worker.RunWorkerCompleted += (sender, e) =>
                {
                    try
                    {
                        Assert.Equal(expectedResult, (int)e.Result);
                        Assert.False(worker.IsBusy);
                    }
                    finally
                    {
                        workerCompletedEvent.Set();
                    }
                };
                worker.ProgressChanged += (sender, e) =>
                {
                    progressBarrier.SignalAndWait();
                };

                worker.RunWorkerAsync();

                // wait for singal from WhenRunWorkerCompleted
                Assert.True(workerCompletedEvent.Wait(TimeoutLong));
                Assert.False(worker.IsBusy);
                Assert.Equal(expectedReportCallsCount, actualReportCallsCount);
            }
            finally
            {
                SynchronizationContext.SetSynchronizationContext(orignal);
            }
        }
開發者ID:noahfalk,項目名稱:corefx,代碼行數:53,代碼來源:BackgroundWorkerTests.cs

示例3: TestReportProgressSync

        public void TestReportProgressSync()
        {
            var bw = new BackgroundWorker() { WorkerReportsProgress = true };
            var expectedProgress = new int[] { 1, 2, 3, 4, 5 };
            var actualProgress = new List<int>();

            bw.ProgressChanged += (sender, e) =>
            {
                actualProgress.Add(e.ProgressPercentage);
            };

            foreach (int i in expectedProgress)
            {
                bw.ReportProgress(i);
            }

            Assert.Equal(expectedProgress, actualProgress);
        }
開發者ID:noahfalk,項目名稱:corefx,代碼行數:18,代碼來源:BackgroundWorkerTests.cs

示例4: GetPlayers

        public static ObservableCollection<Player> GetPlayers(BackgroundWorker worker = null)
        {
            ObservableCollection<Player> players = new ObservableCollection<Player>();

            OracleConnection cn = null;
            OracleCommand cmd = null;
            OracleDataReader rdr = null;
            DataTable tbl = null;

            int i = 0;

            try
            {
                List<Tidbit> tidbits = GetAllPlayerTidbitsSDR();

                cn = createConnectionSDR();

                if (cn != null)
                {
                    String sql = "";

                    switch (ConfigurationManager.AppSettings["DraftType"].ToUpper())
                    {
                        case "LHN":
                        case "NFL":
                            sql = "select a.*, b.*, c.* ";
                            sql += "from espnews.draftplayers a left join espnews.news_teams b on a.schoolid = b.team_id left join espnews.draftorder c on a.pick = c.pick order by a.pick asc, lastname asc, firstname asc";
                            break;
                        case "NBA":
                            sql = "select a.*, b.*, c.*, (select text from espnews.drafttidbits where referencetype = 1 and referenceid = a.playerid and tidbitorder = 999) as tradetidbit ";
                            sql += "from espnews.draftplayers a left join espnews.news_teams b on a.schoolid = b.team_id left join espnews.draftorder c on a.pick = c.pick order by a.pick asc, lastname asc, firstname asc";
                            break;
                    }

                    cmd = new OracleCommand(sql, cn);
                    rdr = cmd.ExecuteReader();

                    tbl = new DataTable();

                    tbl.Load(rdr);

                    rdr.Close();
                    rdr.Dispose();

                    foreach (DataRow row in tbl.Rows)
                    {
                        Player player = createPlayerModel(row, tidbits);

                        players.Add(player);

                        i++;

                        int percent = Convert.ToInt32(((double)i / tbl.Rows.Count) * 100);

                        if (worker != null)
                        {
                            worker.ReportProgress(percent);
                        }
                    }
                }
                else
                {
                    System.Windows.MessageBox.Show("There was a problem connecting to the SDR database");
                }
            }
            finally
            {
                if (cmd != null) cmd.Dispose();
                if (tbl != null) tbl.Dispose();
                if (cn != null) cn.Close(); cn.Dispose();
            }

            return players;
        }
開發者ID:Sandy4321,項目名稱:draft-admin,代碼行數:74,代碼來源:DbConnection.cs

示例5: ImportTeams


//.........這裏部分代碼省略.........
                                {
                                    row = tbl.Rows.Add();
                                    row["referencetype"] = 2;
                                    row["referenceid"] = xmlRow["teamid"];
                                    row["tidbitorder"] = 20;

                                }
                                else
                                {
                                    row = tbl.Rows[0];
                                }

                                row["text"] = xmlRow["record"].ToString();
                                row["enabled"] = 1;

                                adp.Update(tbl.GetChanges());
                                tbl.AcceptChanges();

                                cmd.Dispose();
                                adp.Dispose();
                                bldr.Dispose();
                                tbl.Dispose();

                                #endregion

                                #region Lineup

                                sql = "select * from espnews.drafttidbits where referencetype = 2 and tidbitorder = 30 and referenceid = " + xmlRow["teamid"];
                                cmd = new OracleCommand(sql, cn);
                                adp = new OracleDataAdapter(cmd);
                                bldr = new OracleCommandBuilder(adp);

                                tbl = new DataTable();

                                adp.Fill(tbl);

                                if (tbl.Rows.Count == 0)
                                {
                                    row = tbl.Rows.Add();
                                    row["referencetype"] = 2;
                                    row["referenceid"] = xmlRow["teamid"];
                                    row["tidbitorder"] = 30;

                                }
                                else
                                {
                                    row = tbl.Rows[0];
                                }

                                row["text"] = xmlRow["lineup"].ToString();
                                row["enabled"] = 1;

                                adp.Update(tbl.GetChanges());
                                tbl.AcceptChanges();

                                cmd.Dispose();
                                adp.Dispose();
                                bldr.Dispose();
                                tbl.Dispose();

                                #endregion
                            }

                            teamsImported++;
                        }

                        worker.ReportProgress(teamsImported / teamsToImport);

                    } //foreach team

                } //try
                catch (Exception ex)
                {
                    importErrors++;
                }
                finally
                {
                    if (cmd != null) cmd.Dispose();
                    if (adp != null) adp.Dispose();
                    if (bldr != null) bldr.Dispose();
                    if (rdr != null) rdr.Dispose();
                    if (cn != null) cn.Close(); cn.Dispose();
                    //log.Close();
                }

            }; //dowork

            worker.RunWorkerCompleted += delegate(object s, RunWorkerCompletedEventArgs args)
            {
                SetStatusBarMsg(teamsImported.ToString() + " of " + teamsToImport.ToString() + " teams successfully imported at " + DateTime.Now.ToLongTimeString(), "Green");
                GlobalCollections.Instance.LoadTeams();
            };

            worker.ProgressChanged += delegate(object s, ProgressChangedEventArgs args)
            {
                SetStatusBarMsg(teamsImported.ToString() + " of " + teamsToImport.ToString() + " teams imported.", "Yellow");
            };

            worker.RunWorkerAsync(file);
        }
開發者ID:Sandy4321,項目名稱:draft-admin,代碼行數:101,代碼來源:DbConnection.cs

示例6: ImportPlayers


//.........這裏部分代碼省略.........

                                if (ConfigurationManager.AppSettings["DraftType"].ToString().ToUpper() == "NBA")
                                {
                                    noteCount = 2;
                                }
                                else
                                {
                                    noteCount = 4;
                                }

                                for (int i = 1; i <= noteCount; i++)
                                {
                                    if (xmlRow.Table.Columns["matrixnote" + i.ToString()] != null)
                                    {
                                        if (xmlRow["matrixnote" + i.ToString()].ToString().Trim() != "")
                                        {
                                            sql = "select * from espnews.drafttidbits where referenceid = " + xmlRow["playerid"] + " and referencetype = 1 and tidbitorder = " + i;
                                            cmd = new OracleCommand(sql, cn);
                                            adp = new OracleDataAdapter(cmd);
                                            bldr = new OracleCommandBuilder(adp);

                                            tblTids = new DataTable();
                                            DataRow rowTids = null;

                                            adp.Fill(tblTids);

                                            if (tblTids.Rows.Count == 0)
                                            {
                                                rowTids = tblTids.Rows.Add();
                                                rowTids["referenceid"] = xmlRow["playerid"];
                                                rowTids["referencetype"] = 1;
                                                rowTids["tidbitorder"] = i;
                                                rowTids["enabled"] = 1;
                                            }
                                            else
                                            {
                                                rowTids = tblTids.Rows[0];
                                            }

                                            rowTids["text"] = xmlRow["matrixnote" + i.ToString()].ToString();

                                            adp.Update(tblTids.GetChanges());
                                            tblTids.AcceptChanges();

                                            cmd.Dispose();
                                            adp.Dispose();
                                            bldr.Dispose();
                                            tblTids.Dispose();
                                        }
                                    }
                                }
                            }
                            finally
                            {
                                if (tblTids != null) tblTids.Dispose();
                            }

                            playersImported++;

                            worker.ReportProgress(playersImported / playersToImport);

                        } //playerid > 0
                        else
                        {
                            playersNotFound++;
                        //    //write to report file with this player, not found
                        //    log.WriteLine(DateTime.Now + " --- Not found: " + xmlRow["firstname"].ToString() + " " + xmlRow["lastname"].ToString());
                        }
                    } //foreach player

                } //try
                catch (Exception ex)
                {
                    importErrors++;
                }
                finally
                {
                    if (cmd != null) cmd.Dispose();
                    if (adp != null) adp.Dispose();
                    if (bldr != null) bldr.Dispose();
                    if (rdr != null) rdr.Dispose();
                    if (cn != null) cn.Close(); cn.Dispose();
                    //log.Close();
                }

            }; //dowork

            worker.RunWorkerCompleted += delegate(object s, RunWorkerCompletedEventArgs args)
            {
                SetStatusBarMsg(playersImported.ToString() + " of " + playersToImport.ToString() + " players successfully imported at " + DateTime.Now.ToLongTimeString() + ".  Players not found by ID:  " + playersNotFound.ToString() + ".  Errors importing " + importErrors.ToString() + ".", "Green");
                GlobalCollections.Instance.LoadPlayers();
            };

            worker.ProgressChanged += delegate(object s, ProgressChangedEventArgs args)
            {
                SetStatusBarMsg(playersImported.ToString() + " of " + playersToImport.ToString() + " players imported.", "Yellow");
            };

            worker.RunWorkerAsync(file);
        }
開發者ID:Sandy4321,項目名稱:draft-admin,代碼行數:101,代碼來源:DbConnection.cs

示例7: ReportProgressNoReportingSupported

 public void ReportProgressNoReportingSupported()
 {
     var b = new BackgroundWorker<object, object, object>();
     Assert.IsFalse(b.IsBusy);
     b.ReportProgress(0);
 }
開發者ID:GTuritto,項目名稱:ngenerics,代碼行數:6,代碼來源:BackgroundWorkerTest.cs

示例8: ReadAirAsiaDetails

        private void ReadAirAsiaDetails(BackgroundWorker worker, string filename, out DateTime flightDate, out string flightNo, out List<PAUPassenger> passangers)
        {
            flightDate = DateTime.Now;
            flightNo = "";
            passangers = new List<PAUPassenger>();

            using (StreamReader reader = new StreamReader(filename))
            {
                char[] separator = { ',', '/' };
                string line;

                string fno = "";
                DateTime flight_date = DateTime.MinValue;
                string num = "", pnr = "", last_name = "", first_name = "";
                string gender = "", dob = "", nat = "";

                bool start = false;
                bool parse = false;
               // bool found_first = false;

                BeaCukai cukai = new BeaCukai();
                
                int lineNo = 1;
                while ((line = reader.ReadLine()) != null)
                {
                    if (worker != null)
                    {
                        worker.ReportProgress(lineNo, line);
                    }
                    lineNo++;

                    if (line.Contains("Pax Verification"))
                    {
                        start = true;
                        continue;
                    }

                    if (line.Contains("------------------") && start)
                    {
                        parse = true;
                        continue;
                    }

                    if (line.Trim() == "")
                    {
                        parse = false;
                    }

                    if (line.Contains("Flight") && line.Contains("Date:"))
                    {
                        int flightPos = line.IndexOf("Flight#:") + 8;
                        int datePos = line.IndexOf("Date:") + 5;
                        fno = line.Substring(flightPos, 6).Trim();
                        string fdate = line.Substring(datePos, 14).Trim();
                        string[] dates = fdate.Split(separator);
                        if (dates.Count() > 0)
                        {
                            ConvertPAXStringToDate(dates[0], out flightDate);
                            ConvertPAXStringToDate(dates[0], out flight_date);
                        }
                        flightNo = fno;
                        continue;
                    }

                    if (parse)
                    {
                        
                        int number = -1;
                        try
                        {
                            number = Int32.Parse(line.Substring(0, 3).Trim());
                        }
                        catch (Exception)
                        {
                            number = -1;
                        }

                        if (number > -1)
                        {
                            pnr = line.Substring(5, 6).Trim();
                            last_name = line.Substring(12, 25).Trim();
                            first_name = line.Substring(37, line.Length - 37).Trim();
                            num = number.ToString();

                            if ((line = reader.ReadLine()) != null)
                            {

                                //found_first = false;
                                char[] sep = { ' ' };
                                //string[] datas = line.Split(sep);
                                gender = line.Substring(11, 2).Trim();
                                dob = line.Substring(13, 6).Trim();
                                nat = line.Substring(22, 3).Trim();
                                //MessageBox.Show(line+#13);
                                PAUPassenger pass = null;
                                try
                                {
                                     pass = (from p in cukai.PAUPassenger select p).Where(p => p.FirstName.ToLower() == first_name.ToLower()).
                                                Where(p => p.LastName.ToLower() == last_name.ToLower()).
                                                Where(p => p.FlightNo.ToLower() == fno.ToLower()).
//.........這裏部分代碼省略.........
開發者ID:azanium,項目名稱:PAU-WPF,代碼行數:101,代碼來源:MainController.cs

示例9: GetProTeams

        public static ObservableCollection<Team> GetProTeams(BackgroundWorker worker = null)
        {
            ObservableCollection<Team> teams = new ObservableCollection<Team>();

            MySqlConnection cn = null;
            MySqlCommand cmd = null;
            MySqlDataReader rdr = null;
            DataTable tbl = null;

            int i = 0;

            try
            {
                cn = createConnectionMySql();

                String sql = "select * from teams where league = '" + ConfigurationManager.AppSettings["DraftType"].ToString() + "' order by city asc, name asc";

                cmd = new MySqlCommand(sql, cn);
                rdr = cmd.ExecuteReader();

                tbl = new DataTable();

                tbl.Load(rdr);

                rdr.Close();
                rdr.Dispose();

                Team team;

                foreach (DataRow row in tbl.Rows)
                {
                    team = new Team();
                    team.ID = Convert.ToInt32(row["id"]);
                    team.FullName = row["city"].ToString() + " " + row["name"].ToString();
                    team.Tricode = row["tricode"].ToString();
                    team.City = row["city"].ToString();
                    team.Name = row["name"].ToString();

                    if (ConfigurationManager.AppSettings["LoadTeamLogos"].ToString().ToUpper() == "TRUE" || ConfigurationManager.AppSettings["LoadTeamLogos"].ToString().ToUpper() == "YES")
                    {
                        team.LogoTga = new Uri(row["logo"].ToString());
                        team.SwatchTga = new Uri(row["swatch"].ToString());
                    }

                    team.OverallRecord = row["overallrecord"].ToString();
                    team.ConferenceRecord = row["conferencerecord"].ToString();
                    team.Hashtag = row["hashtag"].ToString();

                    if (row["lotterypctrank"] != DBNull.Value)
                    {
                        team.LotteryPctRank = Convert.ToInt16(row["lotterypctrank"].ToString());
                    }

                    if (row["lotteryorder"] != DBNull.Value)
                    {
                        team.LotteryOrder = Convert.ToInt16(row["lotteryorder"].ToString());
                    }

                    if (ConfigurationManager.AppSettings["DraftType"].ToString().ToUpper() == "NBA")
                    {
                        team.PickPlateTga = new Uri(ConfigurationManager.AppSettings["PickPlateDirectory"].ToString() + "\\NBA.tga");
                    }
                    else
                    {
                        team.PickPlateTga = new Uri(ConfigurationManager.AppSettings["PickPlateDirectory"].ToString() + "\\" + row["name"].ToString().ToUpper() + ".tga");
                    }

                    if (ConfigurationManager.AppSettings["LoadTeamTidbits"].ToString().ToUpper() == "TRUE" || ConfigurationManager.AppSettings["LoadTeamTidbits"].ToString().ToUpper() == "YES")
                    {
                        if (ConfigurationManager.AppSettings["TeamTidbitsDatabase"].ToString().ToUpper() == "MYSQL")
                        {
                            team.Tidbits = GetTidbitsMySql(2, Convert.ToInt32(row["id"]));
                        }
                        else
                        {
                            team.Tidbits = GetTidbitsSDR(2, Convert.ToInt32(row["id"]));
                        }
                    }

                    teams.Add(team);

                    i++;

                    int percent = Convert.ToInt32(((double)i / tbl.Rows.Count) * 100);

                    if (worker != null)
                    {
                        worker.ReportProgress(percent);
                    }
                }
            }
            finally
            {
                if (cmd != null) cmd.Dispose();
                if (tbl != null) tbl.Dispose();
                if (cn != null) cn.Close(); cn.Dispose();
            }

            return teams;
        }
開發者ID:Sandy4321,項目名稱:draft-admin,代碼行數:100,代碼來源:DbConnection.cs

示例10: UISave

    public void UISave()
    {
        var bw = new BackgroundWorker();

        bw.WorkerReportsProgress = true;

        bw.DoWork += delegate(object o, DoWorkEventArgs args)
        {
            var b = o as BackgroundWorker;
            Thread.Sleep(4000);
            saveSettings();
            bw.ReportProgress(100);
        };

        bw.RunWorkerCompleted += delegate { uiSaveDelay = false; };

        bw.RunWorkerAsync();
    }
開發者ID:ZedsTed,項目名稱:BOSS_Remastered,代碼行數:18,代碼來源:BOSS.cs

示例11: PackCachedId

        public virtual void PackCachedId(int start, int end,BackgroundWorker worker=null)
        {
            if (start == end || start > end)
            {
                throw new ArgumentOutOfRangeException("Invalid range");
            }

            int range = end - start;
            if( SpawnGroups.Count() > range)
            {
                throw new ArgumentOutOfRangeException("Range specified not large enough");
            }

            IEnumerable<SpawnGroup> sorted = SpawnGroups.OrderBy(x => x.Id);
            int i = start;
            var updates = new List<Spawn2>();

            foreach (var spawn in sorted)
            {
                //if we are going to potentially re-insert them all somewhere we might as well delete them
                //the update query generates the delete queries first so this works
                //create a spawn that keeps track of the identifier so we can delete it
                var copy = CreateSpawnGroup();
                copy.Id = spawn.Id;
                NeedsDeleted.Add(copy);

                //spawngroups are associated with 0-n spawn2 entries so these will need updated

                foreach (var s2 in copy.GetLinkedSpawn2())
                {
                    //force it to be dirtied
                    s2.Created();
                    s2.SpawnGroupId = i;
                    updates.Add(s2);
                }

                spawn.UnlockObject();
                spawn.Id = i;
                spawn.Created();

                i += 1;

                if (worker != null)
                {
                    double x = i - start;
                    double y = SpawnGroups.Count();

                    double percent = x / y * 100;
                    worker.ReportProgress((int)percent);
                }
            }

            _updateSpawn2 = updates;
        }
開發者ID:Unchated,項目名稱:pogee-3d-editor,代碼行數:54,代碼來源:SpawnGroupAggregator.cs

示例12: BackgroundWorker_RunWorkerAsync_ReportsProgress

        public void BackgroundWorker_RunWorkerAsync_ReportsProgress()
        {
            using (UnitTestContext context = GetContext())
              {
            BackgroundWorkerSyncContextHelper.DoTests(() =>
            {

              var UIThreadid = Thread.CurrentThread.ManagedThreadId;
              int numTimesProgressCalled = 0;

              BackgroundWorker target = new BackgroundWorker();
              target.DoWork += (o, e) =>
                              {
                                // report progress changed 10 times
                                for (int i = 1; i < 11; i++)
                                {
                                  target.ReportProgress(i*10);
                                }
                                e.Result = new object();
                              };
              target.WorkerReportsProgress = true;
              target.ProgressChanged += (o, e) =>
                                      {
                                        context.Assert.IsTrue(Thread.CurrentThread.ManagedThreadId == UIThreadid);
                                        numTimesProgressCalled++;
                                      };
              target.RunWorkerCompleted += (o, e) =>
                                          {
                                            context.Assert.IsTrue(Thread.CurrentThread.ManagedThreadId == UIThreadid);
                                            context.Assert.IsNull(e.Error);
                                            context.Assert.IsTrue(numTimesProgressCalled == 10,"ReportProgress has been called 10 times");
                                            context.Assert.Success();
                                          };
              target.RunWorkerAsync(null);

              while (target.IsBusy)
              {
            // this is the equvalent to Application.DoEvents in Windows Forms
            BackgroundWorkerSyncContextHelper.PumpDispatcher();
              }

              context.Complete();
            });
              }
        }
開發者ID:BiYiTuan,項目名稱:csla,代碼行數:45,代碼來源:BackgroundWorkerTests.cs

示例13: BackgroundWorker_DoWork_ThrowsInvalidOperationExcpetionWhenWorkerReportsProgressIsFalse

        public void BackgroundWorker_DoWork_ThrowsInvalidOperationExcpetionWhenWorkerReportsProgressIsFalse()
        {
            UnitTestContext context = GetContext();

              int numTimesProgressCalled = 0;

              BackgroundWorker target = new BackgroundWorker();
              target.DoWork += (o, e) =>
              {
            // report progress changed 10 times
            for (int i = 1; i < 11; i++)
            {
              target.ReportProgress(i * 10);
            }
              };
              target.WorkerReportsProgress = false;
              target.ProgressChanged += (o, e) =>
              {
            numTimesProgressCalled++;
              };
              target.RunWorkerCompleted += (o, e) =>
              {
            //  target does not support ReportProgress we shold get a System.InvalidOperationException from DoWork
            context.Assert.IsTrue(e.Error is System.InvalidOperationException);
            context.Assert.Success();
              };
              target.RunWorkerAsync(null);
              context.Complete();
        }
開發者ID:BiYiTuan,項目名稱:csla,代碼行數:29,代碼來源:BackgroundWorkerTests.cs

示例14: GetAllDocuments

        public static void GetAllDocuments(BackgroundWorker worker)
        {
            GestionConnection.StopAllTimers(false);
            ClearLocalDatabase();
            ClearLuceneIndex();
            ClearLocalStorage();
            Dictionary<string, object> arg = new Dictionary<string, object>();
            arg.Add("@subdivision", Properties.Settings.Default.subdivisionTablette);
            string cmd = @"SELECT idDocument FROM Documents WHERE (subdivision = @subdivision";
            if (Properties.Settings.Default.documentsDeService) // Pour récupérer également les documents de service
            {
                cmd += " OR subdivision = 'Service') ";
            }
            else
            {
                cmd += ") ";
            }
            cmd += "ORDER BY idDocument ASC;";
            MySqlDataReader Reader = ConnectorMySql.ExecCommand(cmd, arg);
            if(Reader == null){
                return;
            }

            List<UInt32> idsDoc = new List<UInt32>();
            while (Reader.Read())
            {
                idsDoc.Add(Reader.GetUInt32("idDocument"));
            }
            ConnectorMySql.Close(Reader);
            totalDocument = idsDoc.Count;
            nbDocCopied = 0;

            foreach (uint id in idsDoc)
            {
                nbDocCopied++;
                Document monDocument = new Document(id);
                if (monDocument.typeDocument == "DocNormales" && monDocument.subdivision != "Service")
                {
                    Properties.Settings.Default.flagRefreshDocuments = true;
                    Properties.Settings.Default.flagRefreshAccueil = true;
                }
                if (monDocument.typeDocument == "DocNormales" && monDocument.subdivision == "Service")
                {
                    Properties.Settings.Default.flagRefreshAccueil = true;
                    Properties.Settings.Default.flagRefreshNotes = true;
                }
                if (monDocument.typeDocument == "Consignes")
                {
                    Properties.Settings.Default.flagRefreshAccueil = true;
                    Properties.Settings.Default.flagRefreshConsignes = true;
                }
                if (monDocument.typeDocument == "TachesJournalieres")
                {
                    Properties.Settings.Default.flagRefreshAccueil = true;
                    Properties.Settings.Default.flagRefreshTachesJournalieres = true;
                }
                if (monDocument.typeDocument == "Verifications")
                {
                    Properties.Settings.Default.flagRefreshAccueil = true;
                    Properties.Settings.Default.flagRefreshVerifications = true;
                }
                Properties.Settings.Default.Save();
                worker.ReportProgress(nbDocCopied * 100 / totalDocument, id);
                monDocument.AjoutLocal();
                //Mise en pause du thread pendant 1ms pour la mise à jour des autres threads
                System.Threading.Thread.Sleep(0);
            }
            Reader = ConnectorMySql.ExecCommand(@"SELECT idDocLogs FROM DocLogs
                                                    ORDER BY idDocLogs DESC
                                                    LIMIT 1;");
            if (Reader == null)
            {
                return;
            }
            if(Reader.Read())
            {
                Properties.Settings.Default.lastIdCheckDocLog = Reader.GetUInt32("idDocLogs");
                Properties.Settings.Default.Save();
            }
            ConnectorMySql.Close(Reader);
            SetInformationsInServerAboutUpdate();

            App.Current.Dispatcher.BeginInvoke(
                System.Windows.Threading.DispatcherPriority.Normal,
                new Action(
                    delegate()
                    {
                        ((MainWindow)App.Current.MainWindow).RefreshUCs();
                    }
                )
            );
            GestionConnection.LookingForUpdate();
        }
開發者ID:0ups,項目名稱:dOnuts-InterfaceTablette,代碼行數:93,代碼來源:GestionDocuments.cs

示例15: UpdateDocuments

        public static void UpdateDocuments(BackgroundWorker worker, UInt32 LastId)
        {
            //Préparation SQL : récupérer tous les docs logs à partir du dernier checké
            //                  récupérer pour la sub et si activé pour le service
            Dictionary<string, object> arg = new Dictionary<string, object>();
            arg.Add("@LastId", LastId);
            arg.Add("@subdivision", Properties.Settings.Default.subdivisionTablette);
            string cmd = @"SELECT * FROM DocLogs
                        WHERE idDocLogs > @LastId
                        AND (subdivision = @subdivision ";
            if (Properties.Settings.Default.documentsDeService) // Pour récupérer également les documents de service
            {
                cmd += "OR subdivision = 'Service') ";
            }
            else
            {
                cmd += ") ";
            }
            cmd += "ORDER BY idDocLogs ASC;";

            MySqlDataReader Reader = ConnectorMySql.ExecCommand(cmd, arg);

            List<DocLog> listDocLogs = new List<DocLog>();
            if (Reader != null)
            {
                //Stockage dans une list du résultat de la requête
                while (Reader.Read())
                {
                    listDocLogs.Add(new DocLog(Reader));
                }
                ConnectorMySql.Close(Reader);
            }
            else
            {
                worker.ReportProgress(0, false);
            }

            if (listDocLogs.Count == 0)
            {
                SetInformationsInServerAboutUpdate();
                return;
            }
            //Avant le nettoyage on récupère le dernier index idDocLogs et on le stocke
            UInt32 dernierIndex = listDocLogs.Last().idDocLogs;
            Properties.Settings.Default.lastIdCheckDocLog = dernierIndex;
            Properties.Settings.Default.Save();
            ////Nettoyage des logs du serveur : ADD + DEL = NULL
            //for (int i = 0; i < listDocLogs.Count - 1; i++)
            //{
            //    DocLog docLogToCompare = listDocLogs[i];
            //    for (int j = i + 1; j < listDocLogs.Count; j++)
            //    {
            //        DocLog docLogCible = listDocLogs[j];
            //        if (docLogToCompare.isReductible(docLogCible))
            //        {
            //            if (docLogCible.typeModification == "DEL")
            //            {
            //                listDocLogs.Remove(docLogToCompare);
            //            }
            //            listDocLogs.Remove(docLogCible);

            //            //A revoir, pour optimisation, après suppression, je remet les indexes à 0 pour ne
            //            // rater aucun doublon useless...
            //            i = 0;
            //            if (listDocLogs.Count > 0)
            //            {
            //                //On met à jour le docLogToCompare avec le nouvel index 0
            //                docLogToCompare = listDocLogs[0];
            //            }
            //            j = 0;
            //        }
            //    }
            //}
            listDocLogs = OptimiseDocLogList(listDocLogs);
            //J'ai maintenant une liste de DocLogs : listDocLogs qui ne contient que les actions à réellement effectuer sur la doc
            totalDocument = listDocLogs.Count;
            nbDocCopied = 0;
            foreach (DocLog unDocLog in listDocLogs)
            {
                nbDocCopied++;
                //Mise en pause du thread pendant 1ms pour la mise à jour des autres threads
                System.Threading.Thread.Sleep(0);
                unDocLog.applyChange();
                worker.ReportProgress(nbDocCopied * 100 / totalDocument, true);
            }
            SetInformationsInServerAboutUpdate();

            App.Current.Dispatcher.BeginInvoke(
                    System.Windows.Threading.DispatcherPriority.Send,
                        new Action(
                            delegate()
                            {
                                ((MainWindow)App.Current.MainWindow).RefreshUCs();
                            }
                        )
                    );
        }
開發者ID:0ups,項目名稱:dOnuts-InterfaceTablette,代碼行數:97,代碼來源:GestionDocuments.cs


注:本文中的BackgroundWorker.ReportProgress方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。