作者:朱金燦
來源:http://blog.csdn.net/clever101
gdal庫支持很多圖像文件格式,具體見:https://www.gdal.org/formats_list.html。Create方法和CreateCopy方法是圖像驅動常用的方法,但是不是每個圖像驅動都支持這兩種方法。gdal提供了檢測圖像是否支持Create方法和CreateCopy方法的函數CSLFetchBoolean。下面是這個函數的示例用法:
int TestDriver(const char* pszFormat)
{
GDALAllRegister(); // 註冊驅動
// 獲取驅動指針
GDALDriver* poDriver = GetGDALDriverManager()->GetDriverByName(pszFormat);
if (!poDriver) {
fprintf(stderr, "get driver by name failed\n");
return -1;
}
char** papszMetadata = poDriver->GetMetadata();;
if (CSLFetchBoolean(papszMetadata, GDAL_DCAP_CREATE, FALSE))
fprintf(stderr, "Driver %s supports Create() method.\n", pszFormat);
if (CSLFetchBoolean(papszMetadata, GDAL_DCAP_CREATECOPY, FALSE))
fprintf(stderr, "Driver %s supports CreateCopy() method.\n", pszFormat);
if (!CSLFetchBoolean(papszMetadata, GDAL_DCAP_CREATECOPY, FALSE))
{
fprintf(stderr, "Driver %s don't supports CreateCopy() method.\n", pszFormat);
return -1;
}
return 0;
}
int _tmain(int argc, _TCHAR* argv[])
{
TestDriver("bmp");
TestDriver("png");
TestDriver("GTiff");
getchar();
return 0;
}
程序運行結果如下: