修改opencv代码支持utf8文件名
2023-12-20 20:12:30
opencv代码内部使用的文件接口使用的字符编码是本地编码,如果是中文系统,打开中文文件名是没有问题的,但是如果中文系统打开韩文或日文文件名,就会失败。
为了兼容所有编码文件名,把文件打开接口修改为操作unicode的,然后再外部调用依然使用char*的类型,但是传入的不能再是ansi编码,而是utf8编码,这样就可以正常了。
修改方法:
- 封装一个打开文件接口,支持输入utf8,例如名称为ytopenu8;
- 把modules\imgcodecs\src下面所有使用fopen函数的代码,把fopen替换为ytopenu8;
- 重新编译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
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!