
【测绘程序设计】实验指导书.doc
18页wd?测绘遥感程序设计?实验指导书〔Visual C++.net〕〔供测绘工程专业用〕〔2021 年修订〕戴吾蛟 编二零一五年三月中南大学测绘与遥感科学系前言测绘遥感程序设计上机实验是学习本门课程的重要环节之一,实验的设置是为了配合课堂教学,使学生熟练掌握和深入理解课堂教学内容,进一步强化测绘程序设计、测量学及测量平差原理的理解,掌握利用Visual C++.net进展常用的测量程序以及控制网的间接平差程序设计实验内容本门课程必做的实验有〔在Visual C++.net 2021环境下〕:1. Visual C++.net环境、根本控件及简单程序设计(三角形面积计算)2. 控制构造程序设计〔方位角计算、地心坐标至大地坐标转换〕3. 数组、指针〔多边形面积计算〕4. 函数〔交会定点函数设计、高斯投影正反算程序设计〕5. 类的创立〔大地四边形类设计、角度类设计〕6. 文件〔Cass测量数据整理〕7. 图形程序设计〔位移序列曲线图形程序设计〕8. 常用测量计算〔无定向导线简易计算程序设计〕9. 平差程序设计〔水准网间接平差程序设计〕修订说明:由于2021版培养方案增加了8课时,实验课时也相应增加了4课时。
为此,本实验指导书将高斯投影正反算提前,并要求以函数的形式编写增加了大地四边形类设计以及无定向导线简易计算程序设计实验1Visual C++.net环境和简单程序设计一、实验目的· 掌握Visual S的安装和启动· 了解VC++ 2021的菜单系统、工具栏和各种根本窗体· 理解VC++.net开发应用程序的步骤· 掌握基于对话框的程序设计· 掌握按钮、文本框和标签框的根本使用方法· 掌握使用MSDN帮助文档二、实验内容1. 启动与退出VC++.net,熟悉VC++.net的开发环境,通过向导生成基于对话框的应用程序使用MSDN查看命令按钮、标签和文本框的主要属性和方法2. 翻开Microsoft visual studio 2021 文档,浏览“Visual studio 文档〞目录下的内容,并从“Visual studio 文档->Visual C++->例如〞目录下下载一个程序,编译并运行之3. 设计一个三边边长计算三角形面积的程序计算模型如下:海伦公式:,其中提示:(1)在【文件】菜单上执行【新建】,然后选择“工程〞 2)在【工程类型】窗格中,选择【Visual C++】下的“MFC〞项。
在【模板】窗格中,选择“MFC应用程序〞模板,输入应用程序名称“××××〞按向导创立名为“×××××〞的MFC应用程序3)在窗体上放置4个文本框、4个静态框、3个命令按钮〔其中两个缺省〕;(4)设置控件属性,如Static1的Caption属性设置成“a=〞,用于提示Edit框的输入边长a;(5)把“取消〞按钮的Caption属性改为“退出〞;双击前两个按钮,生成Click消息函数,注释掉重载函数“OnOK()〞6)为4个Edit控件添加绑定变量〔7〕在相应的函数中添加代码;〔8〕运行和调试程序;(9)保存应用程序实验2 控制构造程序设计一、实验目的· 掌握VC++.net语言的根本语法;· 理解顺序构造、选择构造和循环构造程序设计的特点及应用;· 掌握对基于对话框的MFC应用程序设计方法;· 掌握一些简单算法二、实验内容1.编写一个方位角计算程序提示:先使用反正切函数计算,然后利用坐标增量的符号来判断所在的象限2.设计同一参考椭球下的三维地心坐标〔笛卡儿坐标系〕与大地坐标系转换的程序〔提示:用do…while迭代,B、H初始为0进展迭代,直到H的精度到达0.00001米〕 注意:东经0~180〔Y>0〕,西经:0~-180(Y<0)式中,B、L、H为椭球面上的大地纬度、大地经度、大地高;X、Y、Z为空间直角坐标;N为卯酉圈曲率半径,e为椭球的偏心率,a为椭球的长半径,b为椭球的短半径。
〔WGS84椭球参数:长半径a=6378137m,扁率α=1/298.257223563〕实验3 数组与指针一、实验目的· 掌握函数的定义、引用及应用方法二、实验内容1.编写一个求任意多边形面积的程序提示:通过界面输入数据,并把数据保存在一个二维数组或一个一维的自定义构造体类型的数组中,然后再进展计算要求计算局部写成函数的形式,使计算程序与界面无关动态数组创立动态数组l 构造体的定义 多边形面积计算原理及算法 计算原理:例如上图:面积计算的算法: 经整理后得:实验4 函数一、实验目的· 掌握函数的定义、引用及应用方法二、实验内容1.交会定点计算函数设计把前方交会、测边交会、前方交会程序写成函数的形式,然后再通过主程序调用提示:前方交会计算函数设计思路〔1〕根本原理及计算公式假设将Pa、Pb、Pc看成权,那么P点的坐标即为三个点的加权平均值〔2〕计算程序设计步骤①设计界面,用于输入3个点的坐标和三个观测角a、b和g,以及用于输出待定点坐标的文本框〔12个〕、静态标签框和Button按钮;②定义文本框控件变量〔Value〕;③创立前方交会定点计算函数,函数的输入为三个观测角和三个点的坐标,输出为待定点坐标,输出可以用引用参数的方式输出,具体计算步骤;a.根据点计算三个内角A、B、C;b.计算Tan(a)、Tan(b)、Tan(g)、Tan(A)、Tan(B)、Tan(C);c.计算Pa、Pb、Pc;d.计算待定点坐标Xp、Yp。
④创立“计算〞Button按钮的Click事件函数,在该事件函数中调用前方交会计算函数,并在相应的文本框中显示计算结果2.高斯投影正反算计算函数设计编写高斯投影正算与反算的两个函数,并设计简单界面对函数计算的正确性进展测试 正算公式:是弧度转换为秒的转换单位,是经度L同当前带中央子午线的差值,单位为秒X 为当前点到赤道的子午线长度长半轴第一偏心率反算公式:是要求的点到中央子午线的经度差,为底点纬度 下标“f〞表示与有关的量 即,y=0时 x 所对应道的子午弧长注意:高斯投影正反算公式比拟复杂,编写程序时变量定义一定要十分的清晰实验5类的创立一、实验目的1. 掌握面向对象编程根本思想2. 掌握VC++.net中创立类3. 掌握建立和使用对象4. 掌握运算符号重载5. 理解类的继承和多态性二、 实验内容1.大地四边形类设计要求:设计一个大地四边形类,注意大地四边形的根本属性,功能上只要求能够设置和返回点坐标、8个观测角度、待定点近似坐标计算以及闭合差的计算提示:大地四边形〔如下图〕以AB为基线,具有对角线的四边形,它是建立桥梁控制网常用的形式,一般采用条件平差进展计算,本实验中仅要求采用前方交会的方法计算C和D点的近似坐标。
大地四边形 三角形闭合差 极条件闭合差2.角度类设计要求该类具有度分秒至度的换算、度至度分秒的换算、度与弧度的换算等功能提示:设置一个角度大小属性,并设定该属性为缺省属性;另设一个状态属性,表示当前设置的角度大小的形式;度分秒、度、弧度间的相互转换的方法;定义运算符号〔加、减〕方法,使得角度类能够像一种普通的数据类型样的方便使用;用设计好的角度类重新编写前方交会定点程序实验6文 件一、实验目的· 掌握文件对话框的使用方法· 掌握C++文件操作的一般步骤及实现方法· 了解MFC文件操作的特点及使用方法二、实验内容1. 编制简单的Cass数据文件进展数据整理的程序整理后的数据文件中要求无重复点数据,且数据按点号大小的升序进展排序要求整理后的数据按与原始数据文件同样的格式保存为另外一个文件例如数据“民用园燃气.dat〞文件数据格式:总点数点号,编码,X,Y,H…例如:要求: a.用SaveFileDialog和OpenFileDialog控件获取文件翻开或保存的文件名b.自定义一个测量点数据构造体,其元素包括:点号,编码,X,Y,Hc.用文本框显示原始数据和整理后的数据d..按编程标准进展编码提示: a. 读数据、保存数据、判断一个点数据是否已经存在、排序、在文本框中显示文件内容等可以分别定义成一个子过程或函数。
b.根本流程:翻开文件获得总点数根据点数调整数组的大小逐行读取数据,判断该点是否已经存在数组中,假设不存在,那么把该数据存放在数组中根据删除重复点后的总点数,重新调整数组大小按点号大小的升序排序按原数据格式输出到另外一个文件c.编程技巧实验7图形程序设计一、实验目的· 掌握VC++.net 坐标系和各项设置方法· 掌握GDI绘图方法· 理解交互式图形程序设计二、实验内容1.以下数据为一变形监测点的24期位移监测结果〔分别为X,Y,H〕,编制程序绘制出该点的变形曲线图,每个方向一个位移序列图变形曲线示意图2432.5801 -52.7876 0.136932.5786 -52.7892 0.138032.5784 -52.7845 0.141132.5812 -52.7852 0.139332.5782 -52.7863 0.139432.5791 -52.7852 0.135432.5788 -52.7841 0.141432.5788 -52.7817 0.137532.5745 -52.7833 0.135932.5815 -52.7854 0.132732.5822 -52.7841 0.135832.5839 -52.7826 0.136132.5820 -52.7852 0.133932.5800 -52.7863 0.132532.5792 -52.7845 0.141632.5807 -52.7834 0.139532.5778 -52.7846 0.141232.5792 -52.7843 0.137132.5794 -52.7833 0.140632.5806 -52.7841 0.141132.5800 -52.7863 0.138032.5785 -52.7840 0.136832.5811 -52.7848 0.141232.5828 -52.7863 0.1356实验8常用测量程序设计一、实验目的· 稳固类的创立与使用· 掌握数组参数的传递· 掌握常用测绘程序设计的技巧二、实验内容1.设计一个无定向导线简易计算的程序。
要求自己定义文件格式,把以下图中数据编写至文件中,然后通过读取文件的形式获取所有数据,计算结果也写入结果文件中无定向导线计算根本步骤:实验9平差程序设计根底一、实验目的· 稳固过程的定义与调用· 稳固类的创立与使用· 稳固间接平差模型及平差计算· 掌握平差程序设计的根本技巧与步骤二、实验内容水准网平差程序设计设计一个水准网平差的程序,要求数据从文件中读取,计算局部与界面无关1.水准网间接平差模型:2.计算例如:3.水准网平差计算一般步骤(1)读取观测数据和数据;(2)计算未知点高程近似值;(3)列高差观测值误差方程;(4)根据水准路。












