我有一个应用程序,我使用caliburn.micro,我观察到一些奇怪的行为。我有一个有两个列的网格,它们设置得同样宽。在这个网格中,有两个ListBox(见下图)。
现在,如果一个项目被添加到一个ListBox而另一个项目是空的,那么带有该项目的ListBox会与该项目一样宽,另一个项目变得更小,这意味着两个ListBox都不是同样宽泛的了。
现在出现了故事的奇怪部分。如果我在添加项目之前调整窗口大小一次,一切都按预期工作。
我从一个更大的应用程序中提取了这个例子,我在其中观察到与ItemControlls和TreeViews相同的行为。在我的研究中,我用纯WPF重建了这个示例应用程序,一切正常。所以我认为这个问题必须与caliburn.micro相关联。
这是MainView的XAML:
<UserControl x:Class="WpfResizeErrorTest.Views.MainView"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
mc:Ignorable="d" Background="#FF3D3A3A">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="*" />
<RowDefinition Height="Auto" />
</Grid.RowDefinitions>
<ListBox Name="LeftItems" Grid.Column="0" Grid.Row="0" Margin="0,0,5,0" />
<ListBox Name="RightItems" Grid.Column="1" Grid.Row="0" Margin="5,0,0,0"/>
<Button Grid.Row="1" Grid.Column="0" Grid.ColumnSpan="2" Name="AddItem" Height="30" Margin="5,5,5,5" Content="Add Item" />
</Grid>
</UserControl>
相应视图模型的代码:
public class MainViewModel : Screen
{
public MainViewModel()
{
this.LeftItems = new BindableCollection<string>();
this.RightItems = new BindableCollection<string>();
}
public BindableCollection<string> LeftItems { get; set; }
public BindableCollection<string> RightItems { get; set; }
public void AddItem()
{
this.LeftItems.Add("This is a long text which is usually longer than the list box it comes in.");
}
}
有谁知道问题可能是什么?
答案 0 :(得分:1)
我的一位同事找到了解决方案。 Caliburn.micro更改SizeToContent
对象的Window
属性的值。你必须在引导程序中执行此操作:
public class Bootstrapper : BootstrapperBase
{
public Bootstrapper()
{
this.Initialize();
}
protected override void OnStartup(object sender, StartupEventArgs e)
{
base.OnStartup(sender, e);
var settings = new Dictionary<string, object>
{
{ "SizeToContent", SizeToContent.Manual }
};
this.DisplayRootViewFor<MainViewModel>(settings);
}
}
一切都按预期工作。