ArcToolbox每个工具执行之后,都会向Geoprocessor返回消息,包括操作何时开始,使用哪些参数,操作的进度,以及可能出现的问题和错误。消息的种类包括常规消息、警告、错误,GPMessage类可以包含消息的文本及严重等级。
首先,Geoprocessor.getMessage()方法可以捕获最后一个工具执行后返回的错误消息
String messages = gp.getMessages(2); System.out.println(messages);
如何使用GPMessage
// if there was an error then you want to loop the messages // returned by the geoprocessor to look for the error GPMessages gpMessages = (GPMessages)gp.getReturnMessages(); for( int i = 0; i gpMessages.getCount(); i++) { System.out.println(gpMessages.getMessage(i).getDescription()); }
可以看出,上面都是通过GeoProcessor的方法来获取消息,除此之外还可以使用IGeoProcessorResult接口,从功能上来说它们没有多少区别。
// Execute Union IGeoProcessorResult pResult = gp.execute(uniontool, null); if (pResult.getMessageCount() > 0) { for( int i = 0; i <= pResult.getMessageCount() - 1; i++){ System.out.println(pResult.getMessageCount()); } }
另外我们还可以自定义输出的方法,根据程序执行的过程,可以添加的方法有AddMessage、AddWarning、AddError。下面的示例将feature class从一个工作区复制到另外一个工作区,并跟踪显示每个文件复制的情况。
// Execute Union IGeoProcessorResult pResult = gp.execute(uniontool, null); if (pResult.getMessageCount() > 0) { for( int i = 0; i <= pResult.getMessageCount() - 1; i++){ System.out.println(pResult.getMessageCount()); } }