使用libgdal从文件中获取地形的轮廓
Get contours of the terrain from file with libgdal
我正在尝试使用C++和libgdal
库将GeoTIFF图像转换为GEOJson数据。
我可以这样做:
gdal_contour -i <shift> -snodata 32767 -f "GeoJSON" -a height <input.file> <output.file>
文件说:
此实用程序的功能可以通过 C 和
GDALContourGenerate()
完成。
这个函数有一组相当明确的参数,除了两个:GDALRasterBandH hBand
和void *hLayer
.据我了解,这实际上是输入和输出。但是,我不知道如何初始化这两个对象。
我试着这样做:
OGRLayerH *lr = new OGRLayerH;
if (GDALContourGenerate(GDALOpen("/file/path.tif", GA_ReadOnly), 10, 0, 0, nullptr, false, 0, lr, -1, -1, nullptr, nullptr) == CE_None)
{
printf("success");
}
else
{
printf("fail");
}
但我认为我犯了一些错误。你能建议一下吗?
您需要从图像文件中读取波段。nBandIn
是带有波段号的整数值。然后,您可以在代码中使用hBand
。也不要忘记打电话给GDALAllRegister();
ro能够读取文件
GDALDatasetH hSrcDS = GDALOpen("/file/path.tif", GA_ReadOnly);
if( hSrcDS == nullptr )
exit( 2 );
GDALRasterBandH hBand = GDALGetRasterBand( hSrcDS, nBandIn );
if( hBand == nullptr )
{
CPLError( CE_Failure, CPLE_AppDefined,
"Band %d does not exist on dataset.",
nBandIn );
exit(2);
}
相关文章:
- C++为构建时间获取QDateTime的可靠方法
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 如何使用 < 和 > 命令获取 c++ 中的输入和输出?
- 使用指针从C++中的数组中获取最大值
- 如何获取std::result_of函数的返回类型
- 如何在openssl-ecc中获取十六进制格式的私钥
- 使用Unreal C++获取VR耳机的世界位置/方向
- 获取日期异步信号安全吗?如果在信号处理程序中使用,它会导致死锁吗
- 从C字符串中获取奇怪的字符串长度
- 为什么我的for循环不能正确获取argv
- 从python中调用C++函数并获取返回值
- 如何获取一个数字的前3位
- 获取字符串的长度并将其分配给数组
- 无法获取菜单选择以运行函数.C++
- 数组长度,为什么从命令行获取时不能使用它?
- Boost Spirit,获取迭代器内部语义动作
- 尝试通过OCI例程从Oracle获取blob数据,但出现错误:ORA-01008:并非所有变量都绑定
- 具有默认值的引用获取函数
- 使用libgdal从文件中获取地形的轮廓
- OpenCV在轮廓中获取点