Sco*_*ker 8 wpf ribbon ribbon-control windows-ribbon-framework ribboncontrolslibrary
我有一个RibbonComboBox用于设置字体大小.它有一个RibbonGallery列出各种字体大小,显示在适当的FontSize:
<r:RibbonComboBox DataContext="{x:Static vm:RibbonDataModel.FontSizeComboBoxData}"
SelectionBoxWidth="30">
<r:RibbonGallery MaxColumnCount="1"
Command="{Binding Command}"
CommandParameter="{Binding SelectedItem}">
<r:RibbonGallery.GalleryItemTemplate>
<DataTemplate>
<Grid>
<TextBlock Text="{Binding}"
FontSize="{Binding}" />
</Grid>
</DataTemplate>
</r:RibbonGallery.GalleryItemTemplate>
</r:RibbonGallery>
</r:RibbonComboBox>
Run Code Online (Sandbox Code Playgroud)
编辑这是我的ViewModel:
public static RibbonDataModel
{
public static GalleryData<object> FontSizeComboBoxData
{
get
{
lock (LockObject)
{
const string key = "Font Size";
if (!DataCollection.ContainsKey(key))
{
var value = new GalleryData<object>
{
Command = HtmlDocumentCommands.ChangeFontSize,
Label = "Change Font Size",
ToolTipDescription = "Set the font to a specific size.",
ToolTipTitle = "Change Font Size",
};
var fontSizes = new GalleryCategoryData<object>();
var i = 9.0;
while (i <= 30)
{
fontSizes.GalleryItemDataCollection.Add(i);
i += 0.75;
}
value.CategoryDataCollection.Add(fontSizes);
DataCollection[key] = value;
}
return DataCollection[key] as GalleryData<object>;
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
一切都按预期工作,但在我从图库中选择一个项目后,它会显示在库中RibbonComboBox使用的相同的巨大(或微小)FontSize.
FontSize当它显示在RibbonComboBox?时,如何将所选项目的"重置"设置为默认值?
在RibbonComboBox使用ContentPresenter以显示您在选择该项目RibbonGallery.而且,ContentPresenter采用了相同的ItemTemplate您在声明RibbonGallery.这是您问题的"核心"原因.
因此,您可以选择两种解决方案来解决问题.
第一个解决方案(最快的解决方案)
您只需将IsEditableRibbonComboBox 的属性设置为"true"即可.通过这种方式,RibbonComboBox用TextBox替换ContentPresenter,而不使用任何ItemTemplate.然后字体将具有正确的大小.
第二个解决方案(最好的一个恕我直言)
由于ItemTemplate在RibbonComboBox的ContentPresenter和RibbonGallery中同时使用,因此我们可以尝试解决问题.olny的区别在于,当DataTemplate放置在RibbonGallery中时,其父级是a RibbonGalleryItem.因此,如果其父级不是a RibbonGalleryItem,则会自动知道DataTemplate被放置在ContentPresenter中.你可以写一个简单的处理这种情况DataTrigger.我们在代码中看到所有内容.
我写了一个简化的ViewModel:
namespace WpfApplication1
{
public class FontSizes
{
private static FontSizes instance = new FontSizes();
private List<double> values = new List<double>();
public FontSizes()
{
double i = 9.0;
while (i <= 30)
{
values.Add(i);
i += 0.75;
}
}
public IList<double> Values
{
get
{
return values;
}
}
public static FontSizes Instance
{
get
{
return instance;
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
那是我的观点:
<Window x:Class="WpfApplication1.Window1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:ribbon="http://schemas.microsoft.com/winfx/2006/xaml/presentation/ribbon"
xmlns:vm="clr-namespace:WpfApplication1"
Title="Window1" Height="300" Width="300">
<Window.Resources />
<DockPanel>
<ribbon:RibbonComboBox Label="Select a font size:"
SelectionBoxWidth="62"
VerticalAlignment="Center">
<ribbon:RibbonGallery MaxColumnCount="1">
<ribbon:RibbonGalleryCategory DataContext="{x:Static vm:FontSizes.Instance}" ItemsSource="{Binding Path=Values, Mode=OneWay}">
<ribbon:RibbonGalleryCategory.ItemTemplate>
<DataTemplate>
<Grid>
<TextBlock Name="tb" Text="{Binding}" FontSize="{Binding}" />
</Grid>
<DataTemplate.Triggers>
<DataTrigger Binding="{Binding RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=ribbon:RibbonGalleryItem, AncestorLevel=1}}"
Value="{x:Null}">
<Setter TargetName="tb" Property="FontSize" Value="12" />
</DataTrigger>
</DataTemplate.Triggers>
</DataTemplate>
</ribbon:RibbonGalleryCategory.ItemTemplate>
</ribbon:RibbonGalleryCategory>
</ribbon:RibbonGallery>
</ribbon:RibbonComboBox>
</DockPanel>
</Window>
Run Code Online (Sandbox Code Playgroud)
正如您所看到的,DataTrigger是"组件",它构成了"脏工作".
现在,您只需要了解自己喜欢哪种解决方案.
| 归档时间: |
|
| 查看次数: |
1724 次 |
| 最近记录: |