2010-02-05 7 views

Répondre

40

J'utilise une méthode d'extension pour aplatir la hiérarchie de contrôle, puis appliquer des filtres, de sorte qu'elle utilise sa propre méthode récursive.

La méthode ressemble à ceci

public static IEnumerable<Control> FlattenChildren(this Control control) 
{ 
    var children = control.Controls.Cast<Control>(); 
    return children.SelectMany(c => FlattenChildren(c)).Concat(children); 
} 
+1

Pourriez-vous s'il vous plaît fournir un exemple de code? – abatishchev

+1

sûr, ajouté le code –

+1

Vraiment sympa morceau de code, merci pour le partage! –

1

Pour améliorer réponse ci-dessus, il serait logique de changer le type de retour à

//Returns all controls of a certain type in all levels: 
public static IEnumerable<TheControlType> AllControls<TheControlType>(this Control theStartControl) where TheControlType : Control 
{ 
    var controlsInThisLevel = theStartControl.Controls.Cast<Control>(); 
    return controlsInThisLevel.SelectMany(AllControls<TheControlType>).Concat(controlsInThisLevel.OfType<TheControlType>()); 
} 

//(Another way) Returns all controls of a certain type in all levels, integrity derivation: 
public static IEnumerable<TheControlType> AllControlsOfType<TheControlType>(this Control theStartControl) where TheControlType : Control 
{ 
    return theStartControl.AllControls().OfType<TheControlType>(); 
} 
1

J'utilise cette méthode récursive générique:

L'hypothèse de cette méthode est que si le contrôle est T que la méthode ne regarde pas dans ses enfants. Si vous avez également besoin de regarder à ses enfants, vous pouvez facilement le modifier en conséquence.

public static IList<T> GetAllControlsRecusrvive<T>(Control control) where T :Control 
{ 
    var rtn = new List<T>(); 
    foreach (Control item in control.Controls) 
    { 
     var ctr = item as T; 
     if (ctr!=null) 
     { 
      rtn.Add(ctr); 
     } 
     else 
     { 
      rtn.AddRange(GetAllControlsRecusrvive<T>(item)); 
     } 

    } 
    return rtn; 
}