利用C#生成一个简单的TIN三角网

2024-04-24 10:18

本文主要是介绍利用C#生成一个简单的TIN三角网,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

###输入TXT数据

private void inputbutton_Click(object sender, EventArgs e){OpenFileDialog opg = new OpenFileDialog();opg.Title = "选择文本数据";opg.Filter = "Txt数据(*.txt)|*.txt";opg.ShowDialog();strName = opg.FileName;if (strName == "") return;inputBox.Text = strName;FileStream fs = new FileStream(strName, FileMode.Open);StreamReader sr = new StreamReader(fs, Encoding.Default);string strLine = sr.ReadLine();while (strLine != "" && strLine != null){Lines.Add(strLine);Console.WriteLine(strLine);strLine = sr.ReadLine();}Point point = new Point();for (int i = 1; i < Lines.Count; i++){string[] strArray = Lines[i].Split(charArray);//point. = Convert.ToInt32(strArray[0]);point.X = Convert.ToInt32(strArray[1]);point.Y = Convert.ToInt32(strArray[2]);pointList.Add(point);}}

###生成TIN三角网

private void probutton_Click(object sender, EventArgs e){g = this.CreateGraphics();double ang;this.Refresh();ArrayList tinlines = new ArrayList();//定义与第一点最近的点double mindis = Distance((Point)pointList[0], (Point)pointList[1]);double dis;int count = 1;TinLine tl = new TinLine();for(int i = 1;i<pointList.Count ;i++){dis = Distance((Point)pointList[0], (Point)pointList[i]);if (dis < mindis){mindis = dis;count = i;}}//将第一条边反向已进行三角形扩展tl.Begin = (Point)pointList[0];tl.End = (Point)pointList[count];tinlines.Add(tl);TinLine line = new TinLine();Point a = ((TinLine)tinlines[0]).Begin;Point b = ((TinLine)tinlines[0]).End;line.Begin = b;line.End = a;tinlines.Add(line);//对每一条边进行扩展for (int j = 0; j < tinlines.Count; j++){double minang = 0;bool OK;OK = false;TinLine tling1 = new TinLine();TinLine tling2 = new TinLine();for (int i = 0; i < pointList.Count; i++){int youbian;//判断第三点与前两点的位置关系youbian = ZuoYou((Point)pointList[i], ((TinLine)tinlines[j]).Begin, ((TinLine)tinlines[j]).End);if (youbian == 1){//获取角度最大点ang = Angle((Point)pointList[i], ((TinLine)tinlines[j]).Begin, ((TinLine)tinlines[j]).End);if (ang > minang){minang = ang;count = i;}OK = true;}}if (OK == true){//将新生成两条边添加入集合中int t1 = 0;int t2 = 0;tling1.Begin = ((TinLine)tinlines[j]).Begin;tling1.End = (Point)pointList[count];tling2.Begin = (Point)pointList[count];tling2.End = ((TinLine)tinlines[j]).End;tinlines.Add(tling1);tinlines.Add(tling2);for (int i = 0; i < tinlines.Count - 2;i++ ){//判断新生成的两边是否与已生成的边重合if ((tling2.Begin == ((TinLine)tinlines[i]).Begin && tling2.End == ((TinLine)tinlines[i]).End)|| (tling2.Begin == ((TinLine)tinlines[i]).End && tling2.End == ((TinLine)tinlines[i]).Begin)){t2 = 1;}if ((tling1.Begin == ((TinLine)tinlines[i]).Begin && tling1.End == ((TinLine)tinlines[i]).End) || (tling1.Begin == ((TinLine)tinlines[i]).End && tling1.End == ((TinLine)tinlines[i]).Begin)){t1 = 1;}}//两条边都重合if (t2 == 1 && t1 == 1){for (int i = 0; i < 2;i++ ){tinlines.Remove(tinlines[tinlines.Count - 1]);}}//第二条边重合else if (t2 == 1){tinlines.Remove(tinlines[tinlines.Count - 1]);}//第一条边重合else if (t1 == 1){tinlines.Remove(tinlines[tinlines.Count - 2]);}                        }}tinlines.Remove(tinlines[0]);//将集合中的第一条边删除Pen pen = new Pen(Color.Red, 1);for (int i = 0; i <= tinlines.Count - 1; i++){g.DrawLine(pen, ((TinLine)tinlines[i]).Begin, ((TinLine)tinlines[i]).End);}g.Dispose();}

###程序中用到的自定义方法

public double Distance(Point a, Point b){double d;d = Math.Sqrt((b.X - a.X) * (b.X - a.X) + (b.Y - a.Y) * (b.Y - a.Y));return d;}
        public int ZuoYou(Point c, Point a, Point b){int youbian;double S;S = (a.X - c.X) * (b.Y - c.Y) - (a.Y - c.Y) * (b.X - c.X);if (S > 0){youbian = 1;}else if (S < 0){youbian = -1;}else{youbian = 0;}return youbian;}
        public double Angle(Point c, Point a, Point b){double ang;double l1 = Math.Sqrt((b.X - c.X) * (b.X - c.X) + (b.Y - c.Y) * (b.Y - c.Y));double l2 = Math.Sqrt((a.X - c.X) * (a.X - c.X) + (a.Y - c.Y) * (a.Y - c.Y));double l3 = Math.Sqrt((b.X - a.X) * (b.X - a.X) + (b.Y - a.Y) * (b.Y - a.Y));ang = Math.Acos((l1 * l1 + l2 * l2 - l3 * l3) / (2 * l1 * l2));return ang;}

这篇关于利用C#生成一个简单的TIN三角网的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/931472

相关文章

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

c# checked和unchecked关键字的使用

《c#checked和unchecked关键字的使用》C#中的checked关键字用于启用整数运算的溢出检查,可以捕获并抛出System.OverflowException异常,而unchecked... 目录在 C# 中,checked 关键字用于启用整数运算的溢出检查。默认情况下,C# 的整数运算不会自

C#实现获得某个枚举的所有名称

《C#实现获得某个枚举的所有名称》这篇文章主要为大家详细介绍了C#如何实现获得某个枚举的所有名称,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... C#中获得某个枚举的所有名称using System;using System.Collections.Generic;usi

C# 读写ini文件操作实现

《C#读写ini文件操作实现》本文主要介绍了C#读写ini文件操作实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录一、INI文件结构二、读取INI文件中的数据在C#应用程序中,常将INI文件作为配置文件,用于存储应用程序的

C#实现获取电脑中的端口号和硬件信息

《C#实现获取电脑中的端口号和硬件信息》这篇文章主要为大家详细介绍了C#实现获取电脑中的端口号和硬件信息的相关方法,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 我们经常在使用一个串口软件的时候,发现软件中的端口号并不是普通的COM1,而是带有硬件信息的。那么如果我们使用C#编写软件时候,如

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log