2010-02-05 3 views

Odpowiedz

40

Używam metody rozszerzającej do spłaszczenia hierarchii kontrolnej, a następnie zastosowania filtrów, więc używa ona własnej metody rekursywnej.

Metoda wygląda to

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

Czy możesz podać przykład kodu? – abatishchev

+1

pewnie, dodał kod –

+1

Naprawdę fajny kawałek kodu, dzięki za udostępnienie! –

1

Aby poprawić powyżej odpowiedzią byłoby sensowne, aby zmienić typ zwracany do

//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

używam Ta ogólna metoda rekurencyjna:

założeniu tej metody jest to, że jeśli kontrola jest T, to metoda nie wygląda na dzieci. Jeśli chcesz również spojrzeć na swoje dzieci, możesz je łatwo zmienić.

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; 
}