は、残念ながら、これへの組み込みの解決策がないように思えます。
私の提案する解決策は回避策に似ていますが、コードビハインドに設定されている場合はSelectedProperty
を適切にビジュアル選択する必要があります。あなたは簡単に次の操作を行うことができ、この後
public static class Extensions {
public static T GetDescendantByType<T>(this Visual element) where T : class {
if (element == null) {
return default(T);
}
if (element.GetType() == typeof(T)) {
return element as T;
}
T foundElement = null;
if (element is FrameworkElement) {
(element as FrameworkElement).ApplyTemplate();
}
for (var i = 0; i < VisualTreeHelper.GetChildrenCount(element); i++) {
var visual = VisualTreeHelper.GetChild(element, i) as Visual;
foundElement = visual.GetDescendantByType<T>();
if (foundElement != null) {
break;
}
}
return foundElement;
}
public static void BringItemIntoView(this ItemsControl itemsControl, object item) {
var generator = itemsControl.ItemContainerGenerator;
if (!TryBringContainerIntoView(generator, item)) {
EventHandler handler = null;
handler = (sender, e) =>
{
switch (generator.Status) {
case GeneratorStatus.ContainersGenerated:
TryBringContainerIntoView(generator, item);
break;
case GeneratorStatus.Error:
generator.StatusChanged -= handler;
break;
case GeneratorStatus.GeneratingContainers:
return;
case GeneratorStatus.NotStarted:
return;
default:
break;
}
};
generator.StatusChanged += handler;
}
}
private static bool TryBringContainerIntoView(ItemContainerGenerator generator, object item) {
var container = generator.ContainerFromItem(item) as FrameworkElement;
if (container != null) {
container.BringIntoView();
return true;
}
return false;
}
}
:すべての
まず、我々はいくつかの拡張を必要と最後に魔法のように強調ん
//Register to the SelectedPropertyItemChanged-Event
this._propertyGrid.SelectedPropertyItemChanged += this.PropertyGridSelectedPropertyItemChanged;
//Set any Property by index
this._propertyGrid.SelectedProperty = this._propertyGrid.Properties[3];
private void PropertyGridSelectedPropertyItemChanged(object sender, RoutedPropertyChangedEventArgs<PropertyItemBase> e) {
var pic = this._propertyGrid.GetDescendantByType<PropertyItemsControl>();
pic.BringItemIntoView(e.NewValue);
// UPDATE -> Move Focus to ValueBox
FocusManager.SetFocusedElement(pic,e.NewValue);
var xx = Keyboard.FocusedElement as UIElement;
xx?.MoveFocus(new TraversalRequest(FocusNavigationDirection.Next));
}
クロージャ
ここで重要なのは、すべてのプロパティを保持するItemsControlであるPropertyItemsControl
を知ることです。
希望すると便利です。
クレジット
Bring ItemsControl into view
Get Nested element from a Control
これは動作しますが、問題はまだある: – Suplanus
項目が選択されているが、私は直接キーボードで値を設定することはできませんので、私がTABキーを押す必要がありました – Suplanus
@Suplanus Iveはあなたのニーズに合わせて自分のコードを変更できます。バリューボックスはフォーカスされ、入力準備が整いました – lokusking