窗体设计:

代码:

private void button_src_Click(object sender, EventArgs e)
{

OpenFileDialog openFile = new OpenFileDialog();
openFile.Title = "请选择待校正影像";
openFile.Multiselect = false;
if (openFile.ShowDialog() != DialogResult.OK) return;

if (m_SrcLayer != null) mapControl_src.FocusMap.DeleteLayer(m_SrcLayer);
m_SrcLayer = LayerFactory.CreateDefaultLayer(openFile.FileName);
if (m_SrcLayer == null) return;

//添加图层
mapControl_src.FocusMap.AddLayer(m_SrcLayer);
mapControl_src.ActiveView.PartialRefresh(ViewDrawPhaseType.ViewAll);
textBox_srcImg.Text = openFile.FileName;
}

private void button_dst_Click(object sender, EventArgs e)
{
SaveFileDialog saveFile = new SaveFileDialog();
saveFile.Filter = "栅格影像|*.tiff;*.tif";
if (saveFile.ShowDialog() != DialogResult.OK) return;

textBox_dst.Text = saveFile.FileName;
}

private void button_run_Click(object sender, EventArgs e)
{
//string inFile = textBox_srcImg.Text;
//string outFile = textBox_dst.Text;
/// <summary>
///大气校正算法测试,本算法实现了将GF1_PMS1_E116.5_N39.4_20131127_L1A0000117600-MSS1.tiff进行大气校正
///大气模式为系统自动选择大气模式,气溶胶类型为大陆性气溶胶,初始能见度为40km,逐项元反演气溶胶为是
/// </summary>
#region 1、参数设置
PIE.CommonAlgo.DataProcess_AtmCor_Info info = new PIE.CommonAlgo.DataProcess_AtmCor_Info();

info.InputFile = textBox_srcImg.Text;
info.InputXML = textBox1.Text ;
info.OutputSR = textBox_dst.Text ;

info.AtmModel = comboBox1.SelectedIndex;
info.AerosolType = comboBox2.SelectedIndex+1;

info.InitialVIS = Convert.ToInt32(textBox2.Text ) ;
//info.AeroRetrieval = comboBox3.SelectedIndex;
if (comboBox3.Text == "是")
{
info.AeroRetrieval = 1;
}
else if (comboBox3.Text == "否")
{
info.AeroRetrieval = 0;
}
else
{
MessageBox.Show("请选择逐像元反演气溶胶");
}
info.FileTypeCode = "Gtiff";
if (checkBox1.Checked == true)
{
info.DataType = 1;
}
else if (checkBox2.Checked == true)
{
info .DataType =2;
}
else if (checkBox3.Checked == true)
{
info .DataType =3;
}
else
{
MessageBox .Show("请选择数据类型!");
}

PIE.SystemAlgo.ISystemAlgo algo = PIE.SystemAlgo.AlgoFactory.Instance().CreateAlgo("PIE.CommonAlgo.dll", "PIE.CommonAlgo.AtmosphericCorrectionAlgo");
if (algo == null) return;
#endregion

//2、算法执行
PIE.SystemAlgo.ISystemAlgoEvents algoEvents = algo as PIE.SystemAlgo.ISystemAlgoEvents;
algo.Name = "大气校正";
algo.Params = info;
bool result = PIE.SystemAlgo.AlgoFactory.Instance().ExecuteAlgo(algo);

//添加图层
String filePath = textBox_dst.Text;
ILayer layer = PIE.Carto.LayerFactory.CreateDefaultLayer(filePath);
mapControl_dst.ActiveView.FocusMap.AddLayer(layer);
mapControl_dst.ActiveView.PartialRefresh(ViewDrawPhaseType.ViewAll);
}

private void checkBox1_CheckedChanged(object sender, EventArgs e)
{
// checkBox1.Text = "1";
}

private void checkBox2_CheckedChanged(object sender, EventArgs e)
{
// checkBox2.Text = "2";
}

private void checkBox3_CheckedChanged(object sender, EventArgs e)
{
// checkBox3.Text = "3";
}

private void button1_Click(object sender, EventArgs e)
{
OpenFileDialog openFile = new OpenFileDialog();
openFile.Filter = "xml数据|*.XML;*.XML";
if (openFile.ShowDialog() != DialogResult.OK)
return;
//OpenFileDialog openFile = new OpenFileDialog();
//openFile.Title = "请选择元数据文件";
//openFile.Multiselect = false;
//if (openFile.ShowDialog() != DialogResult.OK) return;
//添加图层

// mapControl_src.FocusMap.AddLayer(m_SrcLayer);
// mapControl_src.ActiveView.PartialRefresh(ViewDrawPhaseType.ViewAll);

textBox1.Text = openFile.FileName;

}

private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
{
/*if (comboBox1.Text == "系统自动选择大气模式")
{
comboBox1.SelectedIndex = 0;
}
else if (comboBox1.Text == "热带大气模式")
{
comboBox1.SelectedIndex = 1;
}
else if (comboBox1.Text == "中纬度夏季大气模式")
{
comboBox1.SelectedIndex = 2;
}
else if (comboBox1.Text == "中纬度冬季大气模式")
{
comboBox1.SelectedIndex = 3;
}
else if (comboBox1.Text == "副极地夏季大气模式")
{
comboBox1.SelectedIndex = 4;
}
else if (comboBox1.Text == "副极地冬季大气模式")
{
comboBox1.SelectedIndex = 5;
}
else if (comboBox1.Text == "美国1962大气模式")
{
comboBox1.SelectedIndex = 6;
}
/*else
{
MessageBox.Show("请选择大气模式");
}*/

}

private void comboBox2_SelectedIndexChanged(object sender, EventArgs e)
{
/* if (comboBox2.Text == "大陆型气溶胶")
{
comboBox2.SelectedIndex = 1;
}
else if (comboBox2.Text == "海洋型气溶胶")
{
comboBox2.SelectedIndex = 2;
}
else if (comboBox2.Text == "城市型气溶胶")
{
comboBox2.SelectedIndex = 3;
}
else if (comboBox2.Text == "沙尘型气溶胶")
{
comboBox2.SelectedIndex = 4;
}
else if (comboBox2.Text == "煤烟型气溶胶")
{
comboBox2.SelectedIndex = 5;
}
else if (comboBox2.Text == "平流层型气溶胶")
{
comboBox2.SelectedIndex = 6;
}
/* else
{
MessageBox.Show("请选择气溶胶类型");
}*/
}

private void comboBox3_SelectedIndexChanged(object sender, EventArgs e)
{
/* if (comboBox3.Text == "是")
{
comboBox3.SelectedIndex = 1;
}
else
{
comboBox3.SelectedIndex = 0;
}*/
}

private void textBox2_KeyPress(object sender, KeyPressEventArgs e)
{
if (e.KeyChar == 0x20) e.KeyChar = (char)0; //禁止空格键
if ((e.KeyChar == 0x2D) && (((TextBox)sender).Text.Length == 0)) return; //处理负数
if (e.KeyChar > 0x20)
{
try
{
double.Parse(((TextBox)sender).Text + e.KeyChar.ToString());
}
catch
{
e.KeyChar = (char)0; //处理非法字符
}
}

}

}

PIE二次开发——大气校正的更多相关文章

  1. PIE SDK大气校正

    1. 算法功能简介 大气校正的目的消除大气对太阳和来自目标的辐射产生吸收和散射作用的 影响,从而获得目标反射率.辐射率.地表温度等真实物理模型参数.大多数情 况下,大气校正同时也是反演地物真实反射率的 ...

  2. PIE 插件式开发小笔记__PIESDK学习体会

    基于PIE.NET-SDK插件式二次开发文档笔记:  PIE 插件式开发配置文件: 它里面一行如下:      理解上一行'Item'关系->    library:为插件类名(程序集名称+后缀 ...

  3. PIESDKDoNet二次开发配置注意事项

    在安装完PIESDK进行二次开发的过程中会遇到下面几种常见的开发配置问题,就写一个文档总结一下. 1.    新建项目无PIESDK模板问题 关于新建项目时候,找不到下图中的PIEMainApplic ...

  4. PIESDK二次开发基础视频

    第0讲:PIESDKNet二次开发环境配置 第1讲:PIE产品简介及开发介绍 第2讲:PIE架构及常用控件介绍 第3讲:PIESDK常用功能实践 第4讲:XML插件配置及组件式开发界面搭建 第5讲:地 ...

  5. Navisworks API 简单二次开发 (自定义工具条)

    在Navisworks软件运行的时候界面右侧有个工具条.比较方便.但是在二次开发的时候我不知道在Api那里调用.如果有网友知道请告诉我.谢谢. 我用就自己设置一个工具.界面比较丑!没有美工. 代码: ...

  6. [连载]《C#通讯(串口和网络)框架的设计与实现》- 12.二次开发及应用

    目       录 第十二章     二次开发及应用... 2 12.1        项目配制... 3 12.2        引用相关组件... 4 12.3        构建主程序... 5 ...

  7. OBS-Studio二次开发记录

    OBS-Studio 是一款跨平台的,开源的视频直播客户端软件. 公司需要对他进行二次开发,开发的目的是使用它的录屏功能. 开发的要求是:定制全新的界面,所见即所得,window系统兼容要好. 开发步 ...

  8. 小猪cms微信二次开发之怎样分页

    $db=D('Classify'); $zid=$db->where(array('id'=>$this->_GET('fid'),'token'=>$this->tok ...

  9. 承接 AutoCAD 二次开发 项目

    本人有多年的CAD开发经验,独立完成多个CAD二次开发项目.熟悉.net及Asp.net开发技术,和Lisp开发技术. 现在成立了工作室,独立承接CAD二次开发项目.结项后提供源码及开发文档,有需要的 ...

随机推荐

  1. Visual Studio 2019更新到16.2.1

    Visual Studio 2019更新到16.2.1   此次更新,包含以下修改: (1)支持Xcode 10.3. (2)修复了Forms项目中,预览Android界面效果bug. (3)修复am ...

  2. ThreadPoolExecutor 定制线程池参数

    在 java 开发中经常需要执行一些“规格化”的任务,此时可以使用 java 线程池.节省创建线程时间,任务来时即可执行,高效. java 包是 java.util.concurrent .创建线程池 ...

  3. mysql 安装参考

    https://blog.csdn.net/qq_38756992/article/details/84929787 https://www.cnblogs.com/joyny/p/10991194. ...

  4. Python3基础 运算 加减乘除、取余数

             Python : 3.7.3          OS : Ubuntu 18.04.2 LTS         IDE : pycharm-community-2019.1.3    ...

  5. 如何:创建返回 UI 的外接程序

    https://msdn.microsoft.com/zh-cn/library/bb909849(v=vs.100).aspx

  6. 【Java】分布式自增ID算法---雪花算法 (snowflake,Java版)

    一般情况,实现全局唯一ID,有三种方案,分别是通过中间件方式.UUID.雪花算法. 方案一,通过中间件方式,可以是把数据库或者redis缓存作为媒介,从中间件获取ID.这种呢,优点是可以体现全局的递增 ...

  7. python locust--Setups, Teardowns, on_start, and on_stop .

    创建一个locust测试脚本,如下: from locust import HttpLocust, TaskSet, task class UserBehavior(TaskSet): def set ...

  8. PAT 甲级 1067 Sort with Swap(0, i) (25 分)(贪心,思维题)*

    1067 Sort with Swap(0, i) (25 分)   Given any permutation of the numbers {0, 1, 2,..., N−1}, it is ea ...

  9. EasyNVR是怎么做到Web浏览器播放RTSP摄像机直播视频延时控制在一秒内的

    背景说明 由于互联网的飞速发展,传统安防摄像头的视频监控直播与互联网直播相结合也是大势所趋.传统安防的直播大多在一个局域网内,在播放的客户端上也是有所限制,一般都是都需要OCX Web插件进行直播.对 ...

  10. LINUX 安装 VMware-Tools(附常见问题)

    mkdir /cdrom #创建光驱挂载目录 mount /dev/cdrom /cdrom # 加载光驱 tar -zxvf /cdro/VMwareTools**********.tar.gz ~ ...