繁体   English   中英

在代码隐藏中使用时,Unicode字符(U + 1FXYZ)无法正确输出

[英]Unicode character (U+1FXYZ) not outputting correctly when used in code-behind

在我的代码隐藏中,我正在尝试返回unicode字符的十六进制代码。

我正在尝试输出Segoe UI Symbol字体中的任何一个字符: http//www.istartedsomething.com/uploads/emojisegoe.html 例如,“U + 1F60A”。

如果我通过我的xaml这样做,例如:

FontFamily="Segoe UI Symbol" Text="😊"

然后它工作正常。

但是如果我绑定值以通过.cs转换器类检索它,则不会出现正确的字符:

FontFamily="Segoe UI Symbol" Text="{Binding Pivot7Days.EmojiWeekendSummary, Converter={StaticResource EmoticonConverter}}"

转换器类:

switch (input)
{
    case "happy":
        return "\u1F60A";
    case "sad":
        return "\u1F60B";
    default:
        return "\u1F610";
}

我得到一个完全不同的字符,后跟返回字符串中的最后一个字符,例如'A','B'或'0'。 例如,当我看到一张带舌头的脸(U + 1F60B)时,我会得到以下内容:

在此输入图像描述

我在后面的代码中使用了不正确的转义序列吗?

超出U + FFFF的字符不能直接写成\\u....文字(如果你试过,只使用前四个十六进制数字,你得到一个错误的字符)但是作为代理对,或者更容易,使用8位\\U字面,例如U + 1F60A的'\\U0001F60A'

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM