我使用RibbonSplitButton在其下拉列表中使用menuitems来模仿visual studio的undo redo按钮。 我们有undo redo stacks,我有一个dependencypropertychanged事件处理程序,它将根据堆栈更新UI。问题是,splitbutton的items属性正在使用Collection,即使它的项集合的顺序正确,它也不会显示它们,因为它们是按索引排序的。
我将在下面提供一些示例来更好地解释这一点:
代码:
private static void UndoRedoUpdated(DependencyObject obj, DependencyPropertyChangedEventArgs args)
{
VO3Main main = (VO3Main)Application.Current.MainWindow;
MenuItem item;
int dif;
if (main.UndoCommands != null)
{
dif = main.UndoCommands.Count - main._undoMenu.Items.Count;
if (dif > 0)
{
for (int i = dif - 1; i >= 0; i--)
{
item = new MenuItem();
item.Header = main.UndoCommands[i].Name;
item.Click += new RoutedEventHandler(main.undoMenu_Click);
main._undoMenu.Items.Insert(0, item);
}
}
else if (dif < 0)
{
for (int i = 0; i < -dif; i++)
main._undoMenu.Items.RemoveAt(0);
}
}
if (main.RedoCommands != null)
{
dif = main.RedoCommands.Count - main._redoMenu.Items.Count;
if (dif > 0)
{
for (int i = dif - 1; i >= 0; i--)
{
item = new MenuItem();
item.Header = main.RedoCommands[i].Name;
item.Click += new RoutedEventHandler(main.redoMenu_Click);
main._redoMenu.Items.Insert(0, item);
}
}
else if (dif < 0)
{
for (int i = 0; i < -dif; i++)
main._redoMenu.Items.RemoveAt(0);
}
}
}
XAML:
<r:RibbonGroup GroupSizeDefinitions="{StaticResource RibbonLayoutSmall}">
<r:RibbonGroup.Command>
<r:RibbonCommand LabelTitle="Editing"/>
</r:RibbonGroup.Command>
<r:RibbonSplitButton Name="_undoMenu" Command="me:AppCommands.Undo" MaxHeight="50"/>
<r:RibbonSplitButton Name="_redoMenu" Command="me:AppCommands.Redo" MaxHeight="50"/>
</r:RibbonGroup>
P.S。即使我将0处的插入更改为添加,因此它将添加到集合的最后一个而不是第一个,它似乎没有什么区别... 如果有人能给我一些关于正在发生什么以及如何解决这个问题的信息,我将不胜感激。 提前谢谢。
答案 0 :(得分:0)
我通常在RibbonSplitButton中使用绑定。所以没有看到你的问题。您可以在RibbonSplitButton中尝试RibbonGallery并查看它是否有效。
或者像这样使用绑定:
RSB.ItemsSource = new Collection<object> { new { Name = "Paste" }, new { Name = "InsertGlyph" } };
<rb:RibbonGroup Header="ABC">
<rb:RibbonSplitButton x:Name="RSB">
<rb:RibbonSplitButton.ItemTemplate>
<DataTemplate>
<TextBlock Text="{Binding Name}" />
</DataTemplate>
</rb:RibbonSplitButton.ItemTemplate>
</rb:RibbonSplitButton>
</rb:RibbonGroup>