【发布时间】:2020-09-30 02:49:33
【问题描述】:
我正在创建一个 C# WPF 应用程序,我在其中以编程方式为存储在 SQLite 数据库中的每个类别创建按钮。每个按钮都包含一个 Font Awesome 图标和文本。
表格
创建按钮
public static void LoadSidePanelButtons(StackPanel stackPanel)
{
DataTable NavigationTable = new DataTable();
string query = "SELECT * FROM Navigation ORDER BY Name ASC";
DatabaseConnection.PopulateDataTable(NavigationTable, query);
foreach (DataRow row in NavigationTable.Rows)
{
ToggleButton toggleButton = new ToggleButton();
toggleButton.Name = "id" + row["navigationID"].ToString();
toggleButton.Content = row["Name"].ToString();
toggleButton.Tag = row["Icon"].ToString();
toggleButton.Style = (Style)stackPanel.Resources["SidePanelButton"];
toggleButton.Click += new RoutedEventHandler(MainWindow.sidePanelButton_onClick);
stackPanel.RegisterName(toggleButton.Name, toggleButton);
stackPanel.Children.Add(toggleButton);
}
}
按钮模板
<StackPanel.Resources>
<Style x:Key="SidePanelButton" TargetType="ToggleButton">
<Setter Property="Height" Value="50" />
<Setter Property="Width" Value="230" />
<Setter Property="Margin" Value="0 0 0 10" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="ToggleButton">
<Border x:Name="Border" CornerRadius="3" Background="Transparent">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="60" />
<ColumnDefinition Width="170" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="*" />
</Grid.RowDefinitions>
<TextBlock x:Name="Icon" Grid.Column="0" Grid.Row="0" FontSize="18" Foreground="#FF8B939C" FontFamily="{StaticResource FontAwesomeRegular}" HorizontalAlignment="Center" VerticalAlignment="Center">
<ContentPresenter x:Name="IconContent" Content="{TemplateBinding Tag}" />
</TextBlock>
<TextBlock x:Name="Title" Grid.Column="1" Grid.Row="0" FontSize="14" Foreground="#FF8B939C" FontFamily="{StaticResource Roboto}" HorizontalAlignment="Left" VerticalAlignment="Center">
<ContentPresenter x:Name="TitleContent" Content="{TemplateBinding Content}" />
</TextBlock>
</Grid>
</Border>
<ControlTemplate.Triggers>
<Trigger Property="IsChecked" Value="True">
<Setter Property="Background" TargetName="Border" Value="#FF19BDD2" />
<Setter Property="Foreground" TargetName="Icon" Value="#FFFFFF" />
<Setter Property="Foreground" TargetName="Title" Value="#FFFFFF" />
<Setter TargetName="spbtBorder" Property="Border.Effect">
<Setter.Value>
<DropShadowEffect BlurRadius="14" Color="Black" Opacity="0.25" ShadowDepth="4" Direction="-90" />
</Setter.Value>
</Setter>
</Trigger>
<Trigger Property="IsMouseOver" Value="True">
<Setter Property="Background" TargetName="Border" Value="#FF19BDD2" />
<Setter Property="Foreground" TargetName="Icon" Value="#FFFFFF" />
<Setter Property="Foreground" TargetName="Title" Value="#FFFFFF" />
<Setter TargetName="Border" Property="Border.Effect">
<Setter.Value>
<DropShadowEffect BlurRadius="14" Color="Black" Opacity="0.25" ShadowDepth="4" Direction="-90" />
</Setter.Value>
</Setter>
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</StackPanel.Resources>
问题是:
toggleButton.Tag = row["Icon"].ToString();
当我使用它添加图标时,按钮将“\uf022”显示为纯文本。
但是……
toggleButton.Tag = "\uf022";
当我把它改成这个时,它显示的图标没有任何问题。
我目前找不到从数据库加载到字符串的 unicode 仍然是纯文本但手动创建的带有 unicode 的字符串显示为图标的原因。
【问题讨论】:
-
你试过删除
.ToString()吗? -
@RandRandom 是的,我试过了,结果是一样的。
-
试试这个
Regex.Unescape(row["Icon"].ToString());- 您最有可能面临的问题是您的字符串实际上是"\\uf022"而不是"\uf022"。 - docs.microsoft.com/en-us/cpp/c-language/escape-sequences - 所以你正在处理的字符串转义了反斜杠而不是 unicode 字符 - 所以你得到一个“正常”反斜杠后跟“正常”字符 -
查看stackoverflow.com/questions/323640 以获得不同的想法以获得您想要的结果
-
@RandRandom 感谢您的想法和文档链接。第一个解决方案就像一个魅力。我也会看看其他的。
标签: c# wpf unicode font-awesome