4

我试图在 ncurses 中打印盲文字符。

这是我的代码:

#include <ncurses.h>

char *str = 
    " ⠁⠂⠃⠄⠅⠆⠇⠈⠉⠊⠋⠌⠍⠎⠏\n"
    "⠐⠑⠒⠓⠔⠕⠖⠗⠘⠙⠚⠛⠜⠝⠞⠟\n"
    "⠠⠡⠢⠣⠤⠥⠦⠧⠨⠩⠪⠫⠬⠭⠮⠯\n"
    "⠰⠱⠲⠳⠴⠵⠶⠷⠸⠹⠺⠻⠼⠽⠾⠿\n";


int main(int argc, const char *argv[]) {
    initscr();
    printw("%s", str);
    getch();
    printf("%s", curses_version());
    endwin();
    printf("%s", str);
    return 0;
}

输出是:

 ?~A?~B?~C?~D?~E?~F?~G?~H?~I?~J?~K?~L?~M?~N?~O
?~P?~Q?~R?~S?~T?~U?~V?~W?~X?~Y?~Z?~[?~\?~]?~^?~_
⠠⠡⠢⠣⠤⠥⠦⠧⠨⠩⠪⠫⠬⠭⠮⠯
⠰⠱⠲⠳⠴⠵⠶⠷⠸⠹⠺⠻⠼⠽⠾⠿

如何正确输出所有字符?

更新:我也尝试过printf似乎可行的方法,addstr产生与printw.

如果我更改语言环境,setlocale(LC_ALL, "");我会得到输出:

  A B C D E F G H I J K L M N O
 P Q R S T U V W X Y Z [ \ ] ^ _
⠠⠡⠢⠣⠤⠥⠦⠧⠨⠩⠪⠫⠬⠭⠮⠯
⠰⠱⠲⠳⠴⠵⠶⠷⠸⠹⠺⠻⠼⠽⠾⠿
4

1 回答 1

2

通过一些实验,我发现可能是错误的:

  1. 您的程序C默认使用区域设置。这假定 ASCII 编码。当您使用 输出多字节字符时,这不是问题stdio,因为这些函数只是将字节按原样传送到控制台。但ncurses实际上使用的是语言环境,所以它可以知道一个字符有多少字节(对于精确定位很重要)等。改变你的程序如下:

    #include <curses.h>
    #include <locale.h>
    
    int main(int argc, char *argv[])
    {
        // initialize locale to system's default:
        setlocale(LC_ALL, "");
    
        // now init and use curses ...
    
  2. 如果你仍然得到乱码输出,你的系统libncurses不处理 unicode。在这种情况下,链接ncursesw而不是ncurses你应该完成。

于 2017-08-16T11:16:27.613 回答