修改opencv代码支持utf8文件名

发布时间:2023年12月20日

opencv代码内部使用的文件接口使用的字符编码是本地编码,如果是中文系统,打开中文文件名是没有问题的,但是如果中文系统打开韩文或日文文件名,就会失败。

为了兼容所有编码文件名,把文件打开接口修改为操作unicode的,然后再外部调用依然使用char*的类型,但是传入的不能再是ansi编码,而是utf8编码,这样就可以正常了。

修改方法:

  1. 封装一个打开文件接口,支持输入utf8,例如名称为ytopenu8;
  2. 把modules\imgcodecs\src下面所有使用fopen函数的代码,把fopen替换为ytopenu8;
  3. 重新编译opencv,然后编译install工程即可。

下面是ytopenu8的代码(注意只是windows下面有效):

#ifdef WIN32
class tytopenutf8 {public:
    static FILE *fopenutf8(const char* pfilename, const char* pmode) {
        if (!pfilename)
            return nullptr;
        int buffersize = (int)strlen(pfilename) * 3 + 3;
        wchar_t* unicodeString = new wchar_t[buffersize]; // 用于存储 Unicode 编码的字符串  
        int result = MultiByteToWideChar(CP_UTF8, 0, pfilename, -1, unicodeString, buffersize);
        if (result == 0) {
            return nullptr;
        }
        wchar_t* unicodeStringmode;
        if (pmode) {
            int buffersize2 = (int)strlen(pmode) * 3 + 3;
            unicodeStringmode = new wchar_t[buffersize2]; // 用于存储 Unicode 编码的字符串  
            result = MultiByteToWideChar(CP_UTF8, 0, pmode, -1, unicodeStringmode, buffersize2);
            if (result == 0) {
                return nullptr;
            }
        } else
            unicodeStringmode = nullptr;
        return _wfopen(unicodeString, unicodeStringmode);
    }
};
    #define ytopenu8 tytopenutf8::fopenutf8
#else
    #define ytopenu8 fopen
#endif

嗯,本文完毕。

文章来源:https://blog.csdn.net/henysugar/article/details/135109112
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。