03、矢量图形查询工具(Symbol Unicode)
目前的软件开发中,很多地方都使用到了矢量图标,在 Metro app 的开发中,可以使用 Windows
系统图标(02、Universal app 中按钮图标使用 ),包括 Segoe UI Symbol、Segoe MDL2 Assets(Windows10 新添加
MDL : microsoft design language)、Segoe UI Emoji 等。
不过在开发中,遇到了一个问题,就是系统自带的 “字符映射表” 中很多图标太小了,又不能调整大小
,不方便浏览,于是自己动手写了一个矢量图形的 Unicode 查询工具(使用 WPF 写的),涉及到了 Unicode
转码的一些技术。
系统自带的 “字符映射表” :

1、"矢量图形查询工具" 运行效果:
1)主窗口:

2) 可以同时打开 Segoe UI Emoji 窗口:

Segoe UI Symbol 窗口:

Segoe MDL2 Assets 窗口:

2、不同编码,占用的字节关系:
1)ASCII码:一个英文字母(不分大小写)占一个字节的空间,一个中文汉字占两个字节的空间。
UTF-8编码:一个英文字符等于一个字节,一个中文(含繁体)等于三个字节。
Unicode编码:一个英文等于两个字节,一个中文(含繁体)等于两个字节。
符号:英文标点占一个字节,中文标点占两个字节。举例:英文句号“.”占1个字节的大小,中文句号“。”占2个字节的大小。
2)示例:在代码和 xml 中表示 unicode:
<Label Content="示例:" Grid.Row="5"/>
<StackPanel Orientation="Horizontal" Grid.Row="5" Grid.Column="1">
<!--将字符的 Unicode 的写在 xml 文件中时,需要使用转码格式-->
<TextBlock FontFamily="Segoe UI Symbol" Text=""/> <!--在 C# 页面中,用代码赋值-->
<TextBlock FontFamily="Segoe UI Symbol" x:Name="txtSample" Margin="30,0,0,0"/>
</StackPanel>
在 C# 代码中(与 C++ 表示方式相同),unicode 书写的格式为以 '\u' 开头(注意 u 为小写),后面是大于4位的 十六进制数,格式需要正确:
txtSample.Text = "\uE189";
显示效果:

如果格式不对,不会通过编译:

3、遍历当前 Windows系统上安装的所有字体:
1)首页 MainWindow.xaml 中的代码:
<Label Content="所有字体:" Grid.Row="1"/>
<ComboBox x:Name="fullFamily" Grid.Row="1" Grid.Column="1">
<ComboBox.ItemsPanel>
<ItemsPanelTemplate>
<VirtualizingStackPanel/>
</ItemsPanelTemplate>
</ComboBox.ItemsPanel>
<ComboBox.ItemTemplate>
<DataTemplate>
<TextBlock Text="{Binding}" Margin="30,5,0,0" Background="Transparent"/>
</DataTemplate>
</ComboBox.ItemTemplate>
</ComboBox> <Label Content="打开查询窗口:" Grid.Row="3"/>
<ListBox x:Name="listBox" Grid.Row="3" Grid.Column="1">
<ListBox.ItemTemplate>
<DataTemplate>
<TextBlock Text="{Binding}" MouseLeftButtonDown="TextBlock_MouseLeftButtonDown" Margin="30,5,0,0" Background="Transparent"/>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>
2)C# 页面代码:
private void MainWindow_Loaded(object sender, RoutedEventArgs e)
{
FontFamilyMapCollection ffCollection; // 遍历当前系统上的所有字体。参考 MSDN:
// https://msdn.microsoft.com/zh-cn/library/system.windows.media.fontfamily.aspx
foreach (FontFamily fontFamily in Fonts.SystemFontFamilies)
{
// 这里把 “图标字体”显示到 ListBox 中,“所有字体” 显示到 ComboBox 中
if (fontFamily.Source == "Segoe UI Symbol" || fontFamily.Source == "Segoe MDL2 Assets" || fontFamily.Source == "Segoe UI Emoji")
{
ffCollection = fontFamily.FamilyMaps; listBox.Items.Add(fontFamily.Source);
} fullFamily.Items.Add(fontFamily.Source);
}
} // 选中相应 “图标字体” 后,跳转到 “查看窗口”
private void TextBlock_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
{
string fontName = (sender as TextBlock).Text; SymbolWindow sw = new SymbolWindow(); // 使用静态属性,作为参数传递
SymbolWindow.CurrentFontFamily = new FontFamily(fontName); // 选中的字体 sw.Show();
}
4、浏览窗口:
1)SymbolWindow.xaml 文件 ,窗口的 x:Name 设置为 myWindow :
<ListView x:Name="listBox" ItemTemplate="{StaticResource template}">
<ListView.ItemsPanel>
<ItemsPanelTemplate>
<!--Items 面板的宽度与窗口宽度绑定,根据窗口改变排列。防止显示为单行-->
<WrapPanel Orientation="Horizontal" Width="{Binding ActualWidth,ElementName=myWindow}"/>
</ItemsPanelTemplate>
</ListView.ItemsPanel>
</ListView>
2)在 this.Loaded 事件中,调用 FontItem.EnumeratorFontFamily(CurrentFontFamily) 静态方法,把相关字体中
包含的所有 Unicode 编码转换为相应的 字符:
/// <summary>
/// 作为从 MainWindow.xaml 传递来的参数
/// </summary>
public static FontFamily CurrentFontFamily; private void Segoe_UI_Symbol_Loaded(object sender, RoutedEventArgs e)
{
// FontFamily ff = new FontFamily("Segoe MDL2 Assets"); if (CurrentFontFamily != null)
{
this.FontFamily = CurrentFontFamily; this.Title = " 当前字体 : " + CurrentFontFamily.Source; listBox.ItemsSource = FontItem.EnumeratorFontFamily(CurrentFontFamily);
}
}
5、FontItem 类定义,用来显示绑定和 Unicode 的转码:
1)把十六进制 unicode 转换为 byte 数组,再调用 Encoding.Unicode.GetChars(array); 方法,转换为
相应字符:
// Unicode 转换为 “符号” 字符表示
// 例如,0xE189 转换为 byte[]{ 137, 225 }
byte[] bytes = new byte[]
{
(byte) Key,
(byte) (Key >> )
}; string Character = ByteToString(bytes);
// 把二进制数转换成字符
public static string ByteToString(byte[] array)
{
var enc = Encoding.Unicode;
var chars = enc.GetChars(array);
return new string(chars);
}
FontItem.cs 文件 全部代码:
class FontItem
{
public string key { set; get; }
public string value { get; set; } public string font { set; get; } public static List<FontItem> EnumeratorFontFamily(FontFamily family)
{
Dictionary<int, FontItem> fonts = new Dictionary<int, FontItem>(); var typefaces = family.GetTypefaces();
foreach (Typeface typeface in typefaces)
{
// 对应字体文件中包含的物理字体
GlyphTypeface glyph; typeface.TryGetGlyphTypeface(out glyph); // 根据字体“CMAP”表的定义获取 Unicode 码位与标志符号索引之间的名义映射。
IDictionary<int, ushort> characterMap = glyph.CharacterToGlyphMap; foreach (KeyValuePair<int, ushort> kvp in characterMap)
{
// Console.WriteLine(String.Format("{0}:{1}", kvp.Key, kvp.Value)); int Key = kvp.Key; // 没有用到 kvp.Value // 如果大于 0xffff(为空字符,显示为小方框),则跳出循环
if (Key > 0xffff) // 0 ~ 65535
{
break;
} // 方法 1: Unicode 转换为 “符号” 字符表示
// 例如,0xE189 转换为 byte[]{ 137, 225 }
byte[] bytes = new byte[]
{
(byte) Key,
(byte) (Key >> )
}; string Character = ByteToString(bytes); // 方法 2:Unicode 转换为 “符号” 字符
// 可以用来转换 Key= 65535 以下的 Unicode,如果大于 65535,则会抛出:
// “ System.OverflowException:值对于字符太大或太小” 的异常
// char c = Convert.ToChar(Key);
// string Character = c.ToString(); // 过滤掉空字符
if (!string.IsNullOrEmpty(Character) &&
!string.IsNullOrWhiteSpace(Character) &&
!fonts.Keys.Contains(Key)// 去掉重复的
)
{ fonts.Add(Key, new FontItem { key = Key.ToString("X4"), font = Character });
}
}
} return fonts.Values.ToList();
} // 把二进制数转换成字符
public static string ByteToString(byte[] array)
{
var enc = Encoding.Unicode;
var chars = enc.GetChars(array);
return new string(chars);
}
}
工具直接下载 (基于 .net framework 4.5)
参考及相关阅读:
How to: Enumerate Installed Fonts
03、矢量图形查询工具(Symbol Unicode)的更多相关文章
- C# Winform实现手机号码归属地查询工具
摘要:本文介绍使用C#开发基于Winform的手机号码归属地查询工具,并提供详细的示例代码供参考. 一.需求描述 输入正确的手机号码,查询该号码的归属地和其他相关信息. 二.需求分析 1.实现手机号码 ...
- Python3实现火车票查询工具
Python 实现火车票查询工具 一. 实验介绍 通过python3实现一个简单的命令行版本的火车票查询工具,用实际中的例子会更感兴趣,不管怎么样,既练习了又可以自己使用. 1. 知识点: Pyth ...
- 域名解析服务查询工具dnstracer
域名解析服务查询工具dnstracer 在访问网站过程中,当用户输入网址后,通常是先解析域名,获取该网站的IP地址.然后,根据IP地址访问对应的网站服务器.所以,域名解析服务器保证域名指向正确的网 ...
- 【T-SQL基础】03.子查询
以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化. 本系列[T-SQL基础]主要是针对T-SQL基础的总结. [T-SQL基础]01.单表查询-几道sql查询题 ...
- dig 常用的域名查询工具
dig 命令是常用的域名查询工具,可以用来测试域名系统工作是否正常. 语法: dig (选项) (参数) 选项: @<服务器地址>: 指定进行域名解析的域名服务器: -b: 当主机具有多个 ...
- 第三方br查询工具害人不浅
第三方br查询工具害人不浅,查询的时候会大批量调用百度的数据库,为什么说是大批量查询呢? 首先是自己查询,心急的站长恨不得下一次刷新br时数值会有所提高,不是那么急的也会一天查一次或几天一次,记录网站 ...
- 强大的数据库查询工具Database.NET 9.4.5018.42
原文:强大的数据库查询工具Database.NET 9.4.5018.42 强大的数据库查询工具Database.NET 9.4.5018.42 两个工具的下载地址,两个软件都是绿色免安装的,直接双击 ...
- 微信小程序+OLAMI(欧拉蜜)自然语言API接口制作智能查询工具--快递、聊天、日历等
微信小程序最近比较热门,再加上自然语义理解也越来越被人关注,于是我想赶赶潮流,做一个小程序试试.想来想去快递查询应该是一种比较普遍的需求. 如果你也在通过自然语言接口做点什么,希望我的这篇博客能帮到你 ...
- Python 实现火车票查询工具
注意:由于 12306 的接口经常变化,课程内容可能很快过期,如果遇到接口问题,需要根据最新的接口对代码进行适当修改才可以完成实验. 一.实验简介 当你想查询一下火车票信息的时候,你还在上 12306 ...
随机推荐
- 世界围棋人机大战、顶峰对决第二战:围棋世界冠军Lee Sedol(李世石,围棋职业九段)对战Google DeepMind AlphaGo围棋程序,AlphaGo再次胜出!
感觉在哔哩哔哩(bilibili)上看比赛直播比较好,一直可以看到比赛的直播画面,还能听到英文解说和中文主持人的解说.YouTube上是不错,但是一方面爬梯子比较卡,另一方面只能听到英文解说. 韩国著 ...
- FreeBSD与Linux十个本质上的区别
Linux的标志是一只十分可爱的小企鹅,而FreeBSD的标志是一个拿着叉子的小恶魔.你是否经常会听到人们把 Linux及 BSD 系统混为一谈?是的,我有时会经常听到一些新手,甚至于媒体都这么说.当 ...
- 如何从头开始确定虚拟SharePoint服务器场的配置(compute resource, network和storage)
让我们来设想一下, 假设你被上级要求设计一个SharePoint场, 用于满足自己公司的需求. 那么, 你会怎么做呢? 首先, 摆在你面前的是一系列的问题: 1. 用实体机搭建还是选用虚拟机平台? ...
- .net维护的一些心得
做了三个月的.net的开发,其实一直在做一个维护加二次开发的工作.现在这个项目告一段落,就此总结下我的所学所感吧.总的来说,.net和JAVA还是有许多地方是不同的,比如.net中的数据绑定问题,已经 ...
- vue刷新当前路由:router-view 复用组件时不刷新的3种解决方案总结
vue-router是Vue.js官方的路由插件,它和vue.js是深度集成的,适合用于构建单页面应用.vue的单页面应用是基于路由和组件的,路由用于设定访问路径,并将路径和组件映射起来.传统的页面应 ...
- 解决Ubuntu Ping网关Destination Host Unreachable错误
ifconfig 检查了配置,没问题,是ok的, 检查了防火墙,是关闭的,邪乎了,是什么问题呢 各种尝试,最后,将 ip 搞成自动获取就 可以ping通了,但为啥手动设置就不行呢? 最后看了这个朋友的 ...
- C#控件一览表
C#控件一览表 .窗体 .常用属性 ()Name属性:用来获取或设置窗体的名称,在应用程序中可通过Name属性来引用窗体. () WindowState属性: 用来获取或设置窗体的窗口状态. 取值有三 ...
- 浅谈PHP数据结构之栈
今天開始进阶自己的PHP,首先一切的编程语言都须要修炼自己的"内功",何为程序猿的"内功",我想大概就是数据结构和算法了吧 .毕竟是灵魂,是普通程序猿到高级程序 ...
- 总结一些Android好用的开源库
1.android-viewFlow https://github.com/pakerfeldt/android-viewflow 2. android-viewbadger https://gith ...
- Servlet 异常处理
当一个 Servlet 抛出一个异常时,Web 容器在使用了 exception-type 元素的 web.xml 中搜索与抛出异常类型相匹配的配置.您必须在 web.xml 中使用 error-pa ...