ボタンをクリックすると、ビジュアル ツリーをトラバースし、現在のウィンドウのすべての表示可能でフォーカス可能なコンポーネント コントロール (ボタン、画像、テキスト ボックスなど) を一覧表示し、TabIndex を何らかの値に設定しようとしています。ただし、いくつかのコントロールがリストされないか、tabIndexes が設定されません!
ここから採用した私のクラスはここにあります
public class TabIndexer
{
public IEnumerable<Control> FindVisualChildren(DependencyObject depObj)
{
if (depObj != null)
{
for (int i = 0; i < VisualTreeHelper.GetChildrenCount(depObj); i++)
{
DependencyObject child = VisualTreeHelper.GetChild(depObj, i);
if (child != null && child is Control)
{
yield return (Control)child;
}
foreach (var childOfChild in FindVisualChildren(child))
{
yield return (Control)childOfChild;
}
}
}
}
public T FindChild<T>(DependencyObject parent, string childName) where T : DependencyObject
{
// Confirm parent and childName are valid.
if (parent == null) return null;
T foundChild = null;
int childrenCount = VisualTreeHelper.GetChildrenCount(parent);
for (int i = 0; i < childrenCount; i++)
{
var child = VisualTreeHelper.GetChild(parent, i);
// If the child is not of the request child type child
T childType = child as T;
if (childType == null)
{
// recursively drill down the tree
foundChild = FindChild<T>(child, childName);
// If the child is found, break so we do not overwrite the found child.
if (foundChild != null) break;
}
else if (!string.IsNullOrEmpty(childName))
{
var frameworkElement = child as FrameworkElement;
// If the child's name is set for search
if (frameworkElement != null && frameworkElement.Name == childName)
{
// if the child's name is of the request name
foundChild = (T)child;
break;
}
}
else
{
// child element found.
foundChild = (T)child;
break;
}
}
return foundChild;
}
}
そして、ここにそれが呼ばれる方法があります
private void Button_Click(object sender, RoutedEventArgs e)
{
var children = new TabIndexer().FindVisualChildren(this).Where(o => o.Focusable && o.Visibility == Visibility.Visible);
int i = 0;
foreach (var item in children)
{
item.TabIndex = i;
++i;
}
MessageBox.Show("no="+i);
}