Bonjour,
Je développe une appli C# / WinForm, et j'ai un problème "étrange".
J'ai une liste d'items (DataGrid) dont l'affichage est fonction des données. J'utilise la fonction "CellFormating".
Tout fonctionne bien.
Cependant, sur une action liée à la sélection d'une ligne dans cette liste, je ne parviens pas à afficher une messageBox(), à moins de commenter le code de formatage, ou d'appuyer sur F10.
J'ai bien vu cette discussion tout à fait similaire à mon problème, mais je n'y ai pas trouvé de solution à mon problème.
https://www.developpez.net/forums/d1...ssagebox-show/

Le code concerné ci-dessous.
Si une des deux conditions est mise en commentaire, la MessageBox() est bien affichée, pas si j'ai la condition "else"
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
private void aDGViewEmployees_CellFormatting(object sender, DataGridViewCellFormattingEventArgs e)
        {
 
            // en rouge si archive
            // Rouge si archivé
            if (this.aDGViewEmployees.Columns[e.ColumnIndex].Name == "archive")
            {
                if (e.Value != null)
                {
                    bool bArchive = (bool)e.Value;
                    // Rouge 
                    if (bArchive)
                    {
                        aDGViewEmployees.Rows[e.RowIndex].DefaultCellStyle.BackColor = Color.FromArgb(197, 42, 40);
                    }
                }
            }
           /* else
            {
                // formating des lignes du tableau en fonction du type
                if (this.aDGViewEmployees.Columns[e.ColumnIndex].Name == "type_empl")
                {
                    if (e.Value != null)
                    {
                        String stringValue = (string)e.Value;
                        stringValue = stringValue.ToUpper();
                        // Bleu pour salarié Vert our candidat
                        if (stringValue == "SALARIE")
                        {
                            aDGViewEmployees.Rows[e.RowIndex].DefaultCellStyle.BackColor = Color.FromArgb(91, 161, 178);
                        }
                        else
                        {
 
                            aDGViewEmployees.Rows[e.RowIndex].DefaultCellStyle.BackColor = Color.FromArgb(163, 192, 57);
                        }
                    }
                }
            }*/
}
Merci pour votre aide