A voir également:
- Windows modules installer worker c'est quoi
- Installer windows 10 sans compte microsoft - Guide
- Installer windows 11 sur pc non compatible - Accueil - Windows
- Installer chromecast - Guide
- Installer windows 10 gratuitement - Accueil - Mise à jour
- Windows store installer - Guide
3 réponses
Utilisateur anonyme
Modifié par Whismeril le 16/05/2015 à 23:49
Modifié par Whismeril le 16/05/2015 à 23:49
Bonsoir, il faut plusieurs choses qu'on ne voit pas dans ton extrait de code:
Malgré cela, il est possible que tu aies un problème interthread (ça arrive quand le backgroundworker est lancé par une classe qui n'est pas la form qui affiche la progressera), dans ce cas il te faudra ajouter un dispatcher
Modérer m'amène à intervenir dans de nombreux posts, mais les seuls langages que je connaisses sont le C# et un peu de VB. Pour vos codes pensez à la coloration.
Réponse trouvée ->Question Résolue
- que bw_unzip.ProgressChanged soit abonnée à l'événement ProgressChanged de bw_unzip
- que dans la méthode DoWork, tu demandes le déclenchement de la progression avec bw_unzip.ReportProgress(mettre ici une valeur)
Malgré cela, il est possible que tu aies un problème interthread (ça arrive quand le backgroundworker est lancé par une classe qui n'est pas la form qui affiche la progressera), dans ce cas il te faudra ajouter un dispatcher
Modérer m'amène à intervenir dans de nombreux posts, mais les seuls langages que je connaisses sont le C# et un peu de VB. Pour vos codes pensez à la coloration.
Réponse trouvée ->Question Résolue
Etant Debutant en C#, je ne sais pas du tout ce qu'est un Dispatcher.
Sinon j'ai bien ajoute l'evenement dans mon MainForm.Designer.cs
Et pour finir tout le DoWork est la. Je suppose que ce que j'ai mis est la "Methode".
Encore desole, je ne connais pas encore bien le vocabulaire.
Apres je suppose avoir fait une erreur. Mon BackgroundWorker n'est pas genere directement dans le code, il est genere par le Designer. C'est un probleme ? Et j'ai bien entendu mis "true" pour WorkerReportProgress.
Est-il possible de m'expliquer comment fonctionne ReportProgress ? Quelle valeur dois-je mettre ?
Merci d'avance.
Sinon j'ai bien ajoute l'evenement dans mon MainForm.Designer.cs
Et pour finir tout le DoWork est la. Je suppose que ce que j'ai mis est la "Methode".
Encore desole, je ne connais pas encore bien le vocabulaire.
Apres je suppose avoir fait une erreur. Mon BackgroundWorker n'est pas genere directement dans le code, il est genere par le Designer. C'est un probleme ? Et j'ai bien entendu mis "true" pour WorkerReportProgress.
Est-il possible de m'expliquer comment fonctionne ReportProgress ? Quelle valeur dois-je mettre ?
Merci d'avance.
Utilisateur anonyme
17 mai 2015 à 09:18
17 mai 2015 à 09:18
Bonjour,
alors de façon générale, ça n'est pas qu'une histoire de vocabulaire, mais bien de concept, la programmation objet n'a rien à voir avec la programmation procédurale, par conséquent, manipuler des méthodes, des événements et des propriétés (ou sous un autre nom pour un autre langage...) est la base pour des langages objets.
Je t'invite donc à commencer par la base, pour t'éviter de te retrouver face à un mur un jour.
Ce tuto (parmis d'autres) est bien
https://tahe.developpez.com/dotnet/csharp/
Pour ton problème voici un exemple
Enfin pour voir ce que le designer à écrit à ta placent quand tu poses le backgroundworker sur la form, et ensuite que tu double-cliques sur les événements dans le panneau de propriété, cherche InitializeComponent, fais une clic-droit/Atteindre la définition, et tu verras tous le code, que tu peux faire à la main si nécessaire, qui affiche les contrôles, lie les méthodes à un événement, etc...
alors de façon générale, ça n'est pas qu'une histoire de vocabulaire, mais bien de concept, la programmation objet n'a rien à voir avec la programmation procédurale, par conséquent, manipuler des méthodes, des événements et des propriétés (ou sous un autre nom pour un autre langage...) est la base pour des langages objets.
Je t'invite donc à commencer par la base, pour t'éviter de te retrouver face à un mur un jour.
Ce tuto (parmis d'autres) est bien
https://tahe.developpez.com/dotnet/csharp/
Pour ton problème voici un exemple
private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e) { for (int i = 0; i<1000000000;i++)//je compte de 0 à 999 999 999 { //tous les 10000000, j'avance la progressbar if (i % 10000000 == 0) backgroundWorker1.ReportProgress(i / 10000000); } } private void backgroundWorker1_ProgressChanged(object sender, ProgressChangedEventArgs e) { progressBar1.Value = e.ProgressPercentage; } private void backgroundWorker1_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e) { backgroundWorker1.ReportProgress(100);//à la fin du processus, je mets la progressbar à 100% }
Enfin pour voir ce que le designer à écrit à ta placent quand tu poses le backgroundworker sur la form, et ensuite que tu double-cliques sur les événements dans le panneau de propriété, cherche InitializeComponent, fais une clic-droit/Atteindre la définition, et tu verras tous le code, que tu peux faire à la main si nécessaire, qui affiche les contrôles, lie les méthodes à un événement, etc...
J'avais deja vu ce fichier, c'est d'ailleurs la que j'ai ajoute les events du BW.
Pour ce qui est du code que vous m'avez fournis, il ne fonctionne pas comme prevu car le ReportProgress apparait tout le temps, du coup les 99% sont atteints bien avant la fin du ExtractAll. Certains fichiers a extraire font 100 Mo comme d'autres font 35Go, du coup il me faut un vrai progress
Pour ce qui est du code que vous m'avez fournis, il ne fonctionne pas comme prevu car le ReportProgress apparait tout le temps, du coup les 99% sont atteints bien avant la fin du ExtractAll. Certains fichiers a extraire font 100 Mo comme d'autres font 35Go, du coup il me faut un vrai progress
J'ai reussi a trouver quelque chose qui fonctionne pas mal, et autrement. :
Seulement voila, une fois sur deux, le worker est deja utilise, pour une raison que je comprends pas parce que c'est le seul worker que j'utilise et je l'utilise uniquement pour unzip, du coup il n'est pas cense etre utilise.
D'ailleurs, ca fonctionne une fois sur deux...
EDIT: Précision du langage dans la coloration syntaxique.
string SelectedItem = cb_gameslist.SelectedItem.ToString(); worker.WorkerReportsProgress = true; worker.WorkerSupportsCancellation = true; worker.RunWorkerCompleted += new RunWorkerCompletedEventHandler(worker_RunWorkerCompleted); worker.ProgressChanged += (o, ee) => { pb_main.Value += 1; int Percent = pb_main.Value * 100 / pb_main.Maximum; lb_progress.Text = "Download Completed ! Installing... " + Percent + "%"; lb_progress.Refresh(); lb_speed.Text = pb_main.Value + " / " + pb_main.Maximum + " Files"; }; worker.DoWork += (o, ee) => { using (ZipFile zip = ZipFile.Read(@"data\zips\" + FileFetch.GetIdByName(SelectedItem) + ".zip")) { pb_main.Invoke((MethodInvoker)delegate { pb_main.Maximum = zip.Count; }); foreach (ZipEntry file in zip) { file.Extract(@"data\games\" + FileFetch.GetIdByName(SelectedItem), ExtractExistingFileAction.OverwriteSilently); worker.ReportProgress(1); } } }; while (worker.IsBusy) { button1.Text = "Busy !"; } worker.RunWorkerAsync();
Seulement voila, une fois sur deux, le worker est deja utilise, pour une raison que je comprends pas parce que c'est le seul worker que j'utilise et je l'utilise uniquement pour unzip, du coup il n'est pas cense etre utilise.
D'ailleurs, ca fonctionne une fois sur deux...
EDIT: Précision du langage dans la coloration syntaxique.
Heu là je ne suis pas sûr, les invoke j'ai pas trop joué avec, mais pour ce que j'en sais ça te crée un autre thread. Du coup ton backgroungworker ne finit pas forcément quand tu le penses, enfin il me semble.
Pour cette ligne
si cb_gameslist est un combobox,
Pour cette ligne
string SelectedItem = cb_gameslist.SelectedItem.ToString();
si cb_gameslist est un combobox,
cb_gameslist.Textdevrait sufire