1 保存文件的代码封装之后有一些bug,虽然没有报错,但是保存之后文件夹里没有文件,这是因为但是保存文件的代码写文件的工作空间(IRasterWorkSpace)是从输入的工作空间来的,输入和输出分别封装之后,写文件的代码就不工作了。
修改之后加上了工作空间,就可以正常运行了。
private void SaveRasterToFile(IRaster raster)
{
if (raster == null)
{
MessageBox.Show("栅格数据为空,无法保存。");
return;
}
// 保存结果
ISaveAs2 pSaveAs = (ISaveAs2)raster;
pSaveAs = (ISaveAs2)raster;
// 创建 SaveFileDialog 对话框
SaveFileDialog saveFileDialog = new SaveFileDialog();
// 设置对话框的标题和文件类型
saveFileDialog.Title = "保存为";
saveFileDialog.Filter = "TIFF 文件 (*.tif)|*.tif|所有文件 (*.*)|*.*";
saveFileDialog.FilterIndex = 1; // 默认选择TIFF格式
// 显示对话框并等待用户选择
if (saveFileDialog.ShowDialog() == DialogResult.OK)
{
// 获取用户选择的文件名和路径
string saveFileName = saveFileDialog.FileName;
// 使用工作空间工厂打开 TIFF 文件
IWorkspaceFactory workspaceFactory = new RasterWorkspaceFactory();
// 设置输出工作空间
string directory = System.IO.Path.GetDirectoryName(saveFileName);
IWorkspace pWorkspace = workspaceFactory.OpenFromFile(directory, 0);
// 保存结果为用户指定的文件名和TIFF格式
pSaveAs.SaveAs(saveFileName, pWorkspace, "TIFF");
}
}
2输入文件后,点击取消报错
这个输入tif数据的代码有一些问题,无论是点击取消还是直接关闭都会报错。
这是因为之前封装打开文件代码之后,如果返回值为null,就无法做后续操作,所以我们要处理一下返回值为null的情况。
private void 输入tif数据ToolStripMenuItem_Click(object sender, EventArgs e)
{
IRasterDataset rasterDataset = OpenTiffFile();
// 检查返回的栅格数据集是否为null
if (rasterDataset == null)
{
MessageBox.Show("未选择任何TIFF文件或者打开文件失败。");
return;
}
IRasterLayer rasterLayer = new RasterLayerClass();
rasterLayer.CreateFromDataset(rasterDataset);
// 将栅格图层添加到地图控件中
axMapControl1.AddLayer(rasterLayer);
// 刷新地图控件
axMapControl1.Refresh();
}
3 当我们进行指数、对数、加常数等操作时,如果点击取消或者直接关闭就会报错。
其实原因和输入tif文件时的错误是一样的。也是因为没有处理null值,修改方法也是一样的。
private void 栅格除常数ToolStripMenuItem_Click(object sender, EventArgs e)
{
IRasterDataset rasterDataset = OpenTiffFile();
// 检查返回的栅格数据集是否为null
if (rasterDataset == null)
{
MessageBox.Show("未选择任何TIFF文件或者打开文件失败。");
return;
}
IRaster processedRaster = MapAlgebraOperationDIVIDE(rasterDataset);
IRasterLayer rasterLayer = new RasterLayerClass();
rasterLayer.CreateFromRaster(processedRaster);
rasterLayer.Name = "DIVIDE";
axMapControl2.AddLayer((ILayer)rasterLayer, 0);
axMapControl2.ActiveView.Refresh();
SaveRasterToFile(processedRaster);
}
4 当我们进行K值计算时,如果在选择文件时,取消或者关闭也会报错,修改方法也是一样的。
private void sandToolStripMenuItem_Click(object sender, EventArgs e)
{
// 自定义的提示信息
string customMessage1 = "请输入砂粒含量百分数栅格";
// 显示自定义提示信息
MessageBox.Show(customMessage1, "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
IRasterDataset rasterDataset1 = OpenTiffFile();
if (rasterDataset1 == null)
{
MessageBox.Show("未选择任何TIFF文件或者打开文件失败。");
return;
}
// 自定义的提示信息
string customMessage2 = "请输入粉粒含量百分数栅格";
// 显示自定义提示信息
MessageBox.Show(customMessage2, "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
IRasterDataset rasterDataset2 = OpenTiffFile();
if (rasterDataset2 == null)
{
MessageBox.Show("未选择任何TIFF文件或者打开文件失败。");
return;
}
IRaster processedRaster = MapAlgebraOperationSAND(rasterDataset1, rasterDataset2);
IRasterLayer rasterLayer = new RasterLayerClass();
rasterLayer.CreateFromRaster(processedRaster);
rasterLayer.Name = "SAND";
axMapControl2.AddLayer((ILayer)rasterLayer, 0);
axMapControl2.ActiveView.Refresh();
SaveRasterToFile(processedRaster);
}