• ArcGIS Pro定制和开发-执行GP环境变量的设置


    var in_table = main_lyr;
    var out_table = Path.Combine(Project.Current.DefaultGeodatabasePath, GVar.FtrLyr + " Results");
    var statistics_fields = [["Shape_Area", "SUM"]]; //[['FEET', 'SUM']]";
    var case_field = "Diameter"; // "['Diameter']";
    var args = Geoprocessing.MakeValueArray(in_table, out_table, statistics_fields, case_field);
    var sp_ref = SpatialReferenceBuilder.CreateSpatialReference(102629); // NAD83 SP AL E FIPS 0101 Feet
    var envi = Geoprocessing.MakeEnvironmentArray(outputCoordinateSystem: sp_ref);
     
    Geoprocessing.ExecuteToolAsync("Statistics_analysis", args, envi, null, null, GPExecuteToolFlags.Default);
    private async Task<bool> ExecuteAddFieldTool(KeyValuePair<string, string> field, string fieldType, int? fieldLength = null, bool isNullable = true)  
            {  
                try  
                {  
                    var inTable = DeltaLayer.Name;  
                    var workspaceName = ((IInternalMapMember)DeltaLayer).WorkspaceName;  
      
      
                    var parameters = Geoprocessing.MakeValueArray(inTable, field.Key, fieldType.ToUpper(), null, null,  
                        fieldLength, field.Value, isNullable ? "NULABLE" : "NON_NULLABLE");  
                    var env = Geoprocessing.MakeEnvironmentArray(workspace: workspaceName);  
                    var cts = new CancellationTokenSource();  
                    var results = Geoprocessing.ExecuteToolAsync("management.AddField",  
                        parameters, env, cts.Token, (eventName, o) =>  
                        {  
                            switch (eventName)  
                            {  
                                case "OnValidate":  
                                    if (((IGPMessage[])o).Any(it => it.Type == GPMessageType.Warning))  
                                    {  
                                        var fieldExists = ((IGPMessage[])o).FirstOrDefault(it => it.ErrorCode == 12);  
                                        if (fieldExists != null)  
                                        {  
                                            //MessageBox.Show($"{fieldExists.Text}");  
                                            cts.Cancel();  
                                        }  
                                    }  
                                    break;  
                            }  
                        });  
                    await results;  
                    return true;  
                }  
                catch (Exception ex)  
                {  
                    System.Windows.MessageBox.Show(ex.ToString());  
                    return false;  
                }  
            }  
  • 相关阅读:
    给列表单元格加背景色
    Log4j最简入门及实例
    MySQL 按指定字段自定义列表排序
    MySQL逗号分割字段的列转行
    利用MySQL统计一列中不同值的数量方法示例
    使用docx4j编程式地创建复杂的Word(.docx)文档
    向Docx4j生成的word文档中添加布局--第二部分
    向Docx4j生成的word文档添加图片和布局--第一部分
    使用Docx4j创建word文档
    [简单]docx4j常用方法小结
  • 原文地址:https://www.cnblogs.com/gisoracle/p/12496316.html
Copyright © 2020-2023  润新知