opencv代码内部使用的文件接口使用的字符编码是本地编码,如果是中文系统,打开中文文件名是没有问题的,但是如果中文系统打开韩文或日文文件名,就会失败。
为了兼容所有编码文件名,把文件打开接口修改为操作unicode的,然后再外部调用依然使用char*的类型,但是传入的不能再是ansi编码,而是utf8编码,这样就可以正常了。
修改方法:
下面是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
嗯,本文完毕。