常用的gis计算方法有哪些

技术常用的gis计算方法有哪些这篇文章主要为大家展示了“常用的gis计算方法有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“常用的gis计算方法有哪些”这篇文章吧。在系统

本文主要向您展示“常用的gis计算方法有哪些”,简单易懂,组织清晰,希望能帮您解决疑惑。让边肖带领大家学习《常用的gis计算方法有哪些》一文。

在系统开发过程中,有时会用到一些常用的空间算法,引用一些类库就可以解决问题,但有时类库运行效率较慢,参考文献较多。如果需要的方法不多,可以写一些简单的计算方法。

以下是一些常见的地理信息系统计算方法:

//确定该点是否在平面内。

公共bool IsPointInPolygon(ListCVector poly,CVector point)

{

int i,j;

bool c=false

对于(i=0,j=poly。计数-1;我是保利。计数;j=i)

{

if ((((poly[i]。VY=点。VY(点。VY保利[j]。VY)

|| ((poly[j])。VY=点。VY(点。VY保利[i]。VY))

(点。VX(保利[j])。VX -保利[i]。VX) *(重点。VY -保利[i]。VY)

/(聚[j]。VY -保利[i]。VY)保利[i]。VX)

{

c=!c .

}

}

返回c;

}

//计算弧度

公共双Rad(双d)

{

返回d *数学。PI/180.0;

}

//计算角度

公共静态双RAngle(双d)

{

返回d * 180.0/Math。PI;

}

//计算两个坐标的中心点

public double[] ComputeMidPoint(双lat1,双lat 1,双lat2,双long2)

{

lat 1=Rad(lat 1);

long 1=Rad(long 1);

lat 2=Rad(lat 2);

long 2=Rad(long 2);

var Bx=数学。Cos(lat2) *数学。cos(long 2-long 1);

sp;   var By = Math.Cos(lat2) * Math.Sin(long2 - long1);

            var _rlat = Math.Atan2(Math.Sin(lat1) + Math.Sin(lat2), Math.Sqrt((Math.Cos(lat1) + Bx) * (Math.Cos(lat1) + Bx) + By * By));

            var _rlong = long1 + Math.Atan2(By, Math.Cos(lat1) + Bx);

            return new double[] { _rlat, _rlong };

        }   

//计算一批点的四至坐标

 public OCExtent GetPointsExtent(List<CVector> PList)

        {

            OCExtent cET = new OCExtent();

            for (int i = 0; i < PList.Count; i++)

            {

                CVector aP = PList[i];

                if (i == 0)

                {

                    cET.minX = aP.VX;

                    cET.maxX = aP.VX;

                    cET.minY = aP.VY;

                    cET.maxY = aP.VY;

                }

                else

                {

                    if (cET.minX > aP.VX)

                    {

                        cET.minX = aP.VX;

                    }

                    else if (cET.maxX < aP.VX)

                    {

                        cET.maxX = aP.VX;

                    }

                    if (cET.minY > aP.VY)

                    {

                        cET.minY = aP.VY;

                    }

                    else if (cET.maxY < aP.VY)

                    {

                        cET.maxY = aP.VY;

                    }

                }

            }

            return cET;

        }

以上是“常用的gis计算方法有哪些”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/128599.html

(0)

相关推荐

  • SQL查询语句怎么写

    技术SQL查询语句怎么写这篇文章主要为大家展示了“SQL查询语句怎么写”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“SQL查询语句怎么写”这篇文章吧。查询所有列Select

    攻略 2021年11月11日
  • 什么是微软total熔毁漏洞分析和预警?

    技术微软TotalMeltdown漏洞分析预警是怎样的这期内容当中小编将会给大家带来有关微软TotalMeltdown漏洞分析预警是怎样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

    攻略 2021年12月20日
  • 扫一扫翻译,手机智能扫一扫都能做什么

    技术扫一扫翻译,手机智能扫一扫都能做什么1、第一个功能为扫一扫翻译:扫词翻译。对准你需要翻译的单词,点击拍照键锁定单词,之后就会出现该单词的基本释义。2、第二个功能:拍照翻译。拍照翻译类似于扫词翻译,不过拍照翻译就好像一

    生活 2021年10月19日
  • q开头的姓氏,百家姓里读音是‘qu’的有哪些

    技术q开头的姓氏,百家姓里读音是‘qu’的有哪些百家姓里读音是‘qu’的有q开头的姓氏:瞿 曲 屈 屈 [Qū]〈名〉 古邑名 。春秋晋地。在今山西省吉县北,盛产良马 姓。春秋楚王族三姓之一。曲[ qū ]姓 拼 音:[

    生活 2021年10月23日
  • html中如何设置边框上下居中(html怎么让td显示的文字靠左)

    技术HTML如何设置td内容居中这篇文章主要讲解了“HTML如何设置td内容居中”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“HTML如何设置td内容居中”吧!

    攻略 2021年12月23日
  • hadoop命令有哪些

    技术hadoop命令有哪些这篇文章主要为大家展示了“hadoop命令有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“hadoop命令有哪些”这篇文章吧。查看:hadoop

    攻略 2021年11月20日