WPF —— 使用Font-Awesome图标字体

 

图标字体介绍
在介绍图标字体之前,不得不介绍图标格式ICON
ICON是一种图标格式,我们操作系统中各种应用程序都包含一个图标
比如QQ程序的图标是一个可爱的企鹅,我的电脑是一个显示器图标
----------------
一个图标文件是扩展名为.ICO或者ICON的文件
直到现在图标文件还是在计算机程序中随处可见
但有时候需要在不失真的情况下放大图标
因为ICON本身与JPEG\PNG格式的图形文件差异不大,也是非矢量图形
所以图标文件就很难满足这种需求
----------------
为了解决这种问题,就有作者把图形信息做到字体中去
我们今天要使用的Font-Awesome就是这种技术形式的一种实现
(当然还有其他办法解决这种问题,比如用css3绘制图标,但那种技术形式就比较难应用于客户端程序中了)
----------------
常见的图标字体有很多,但我认为Font-Awesome是迄今为止最出色的图标字体(没有之一)
图标多、图标美观、兼容各种应用场景是其最主要的有点
 
另外还可以到  http://fontstore.baidu.com/   搜索需要的图标自己下载下来使用,并且还可以在线编辑你的现有ttf文件。感兴趣的可以试试。
 

WPF中使用Font-Awesome图标字体

我曾经在Qt应用程序中使用过Font-Awesome图标字体,用起来非常方便,展现效果也一如预期
但在WPF应用程序中使用图标字体就会显示成一个方框,如下图
后来,才找到解决办法:
首先到Font-Awesome官方网站下载字体程序
下载到的压缩包,解压后获得图标字体文件
然后把字体文件拷贝到项目中
并设置“复制到输出目录”为“如果较新则复制”
然后编辑程序代码:
<Window x:Class="WpfApplication1.MainWindow" 
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
Title="MainWindow"> 
<Window.Resources> 
<Style x:Key="FontAwesome">
<Setter Property="TextElement.FontFamily" Value="pack://application:,,,/#FontAwesome" />
<Setter Property="TextBlock.Width" Value="100"></Setter>
<Setter Property="TextBlock.Height" Value="100"></Setter>
<Setter Property="TextBlock.TextAlignment" Value="Center"></Setter>
<Setter Property="TextBlock.FontSize" Value="60"></Setter>
<Setter Property="TextBlock.Foreground" Value="Green"></Setter>
</Style>
</Window.Resources> 
<WrapPanel Margin="12"> 
<TextBlock Text="&#xf01a;" Style="{DynamicResource FontAwesome}" />
<TextBlock Text="&#xf01a;" Style="{DynamicResource FontAwesome}" />
<TextBlock Text="&#xf01a;" Style="{DynamicResource FontAwesome}" />
<TextBlock Text="&#xf01a;" Style="{DynamicResource FontAwesome}" />
<TextBlock Text="&#xf01a;" Style="{DynamicResource FontAwesome}" />
<TextBlock Text="&#xf01a;" Style="{DynamicResource FontAwesome}" />
<TextBlock Text="&#xf01a;" Style="{DynamicResource FontAwesome}" />
<TextBlock Text="&#xf01a;" Style="{DynamicResource FontAwesome}" />
<TextBlock Text="&#xf01a;" Style="{DynamicResource FontAwesome}" />
<TextBlock Text="&#xf01a;" Style="{DynamicResource FontAwesome}" />
</WrapPanel> 
</Window>
运行程序,看到图标,大功告成
 
 

修改记录

2015-12-26:编写样例程序,完成部分文章内容
2014-12-29:修改部分内容,修改文档格式
 

参考资料

  
 

 

出处:http://www.cnblogs.com/liulun/p/4217664.html

posted on   jack_Meng  阅读(970)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2018-02-28 微信开发系列——微信订阅号前端开发利器:WeUI
2018-02-28 Android - 传统蓝牙通信聊天
2018-02-28 在AD中存取照片
2018-02-28 在IE7+ 中弹出窗口并关闭本身窗口的脚本(备忘)
2018-02-28 打造基于jQuery的智能选择输入框
2018-02-28 打造html右键菜单
2018-02-28 打造基于jQuery的日期选择控件

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示

喜欢请打赏

扫描二维码打赏

支付宝打赏

主题色彩