百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python坐标计算(python坐标轴位置)

off999 2024-10-24 12:34 79 浏览 0 评论

from math import radians, cos, sin, asin, sqrt,pi

class Get_new_gps():

def __init__(self):

# 地球半径

self.R = 6371 * 1000

pass



def geodistance(self, lng1, lat1, lng2, lat2):

"""计算两点间距离"""

"""

:param lng1: 120.12802999999997

:param lat1: 30.28708,115

:param lng2: 115.86572000000001

:param lat2: 28.7427

:return: 两点间距离

"""

lng1, lat1, lng2, lat2 = map(radians, [float(lng1), float(lat1), float(lng2), float(lat2)]) # 经纬度转换成弧度

dlon = lng2 - lng1

dlat = lat2 - lat1

a = sin(dlat / 2) ** 2 + cos(lat1) * cos(lat2) * sin(dlon / 2) ** 2

distance = 2 * asin(sqrt(a)) * self.R # 地球平均半径,6371km

distance = round(distance, 3)

return distance


def get_new_lat(self, lng1, lat1, dist=500):

"""计算点经纬度南500米的点的经纬度"""

"""

:param lng1: 120.12803

:param lat1: 20.28708

:param dist:

:return: (120.12803, 20.291576608029594)

"""

lat2 = lat1 - 180 * dist / (self.R * pi)

return (lng1, lat2)


"""计算点经纬度正东1000米点的经纬度"""


def get_new_lng(self, lng1, lat1, dist=1000):

"""计算点经纬度正东1000米点的经纬度"""

"""


:param lng1: 116.55272514141352

:param lat1: 30.28708

:param dist:

:return: (116.55272514141352,30.28708)

"""

lng2 = 180 * dist / (self.R * pi * cos(radians(lat1))) + lng1

return (lng2, lat1)


def get_new_lng_angle(self, lng1, lat1, dist=500, angle=30):

"""计算点东北方向与正东某夹角某距离的经纬度"""

"""


:param lng1:116.55272514141352

:param lat1:30.28708

:param dist:指定距离

:param angle:指定角度

:return:(0.0091871843081617/pi + 116.498079 0.0122339171779312/pi + 39.752304)

"""

lat2 = 180 * dist*sin(radians(angle)) / (self.R * pi) + lat1

lng2 = 180 * dist*cos(radians(angle)) / (self.R * pi * cos(radians(lat1))) + lng1

return (lng2, lat2)



functions = Get_new_gps()


if __name__ == '__main__':

functions = Get_new_gps()

lng1, lat1 = [117.317732, 36.565515]

# 计算正北的点

# lng2, lat2 = functions.get_new_lat(lng1, lat1)

# 计算正东的点

lng3, lat3 = functions.get_new_lng(lng1, lat1)

# # 计算该点与正东逆时针夹角45度,距离500米点的经纬度值

# lng4, lat4 = functions.get_new_lng_angle(lng1, lat1, dist=1000, angle=45)

print("原始点的经纬度坐标", lng1, lat1)

# print("正北500米坐标点为%f,%f,距离计算为%f米" % (lng2, lat2, functions.geodistance(lng1, lat1, lng2, lat2)))

print("正东1000米坐标点为%f,%f,距离计算为%f米" % (lng3, lat3, functions.geodistance(lng1, lat1, lng3, lat3)))

# print("东北方夹角,距离500米坐标点为%f,%f,距离计算为%f米" % (float(lng3), float(lat3), functions.geodistance(lng1, lat1, lng3, lat3)))

# print(functions.geodistance(lng3, lat3, lng4, lat4))


lng, lat = [117.774649, 36.005881]

lng2, lat2 = functions.get_new_lng(lng, lat)

print("原始点的经纬度坐标", lng, lat)

print("正东1000米坐标点为%f,%f,距离计算为%f米" % (lng2, lat2, functions.geodistance(lng, lat, lng2, lat2)))

更多学习资料请关注公众号“读书同友会”

相关推荐

win10更新卸载不了怎么办(win10更新后卸载更新失败)

右键桌面上“此电脑”—“管理”,或者按组合键“Windows+X”—计算机管理—服务和应用程序—服务,找到Windowsupdate和BackgroundIntelligentTransfe...

三星笔记本bios怎么设置(三星笔记本bios按哪个键)
  • 三星笔记本bios怎么设置(三星笔记本bios按哪个键)
  • 三星笔记本bios怎么设置(三星笔记本bios按哪个键)
  • 三星笔记本bios怎么设置(三星笔记本bios按哪个键)
  • 三星笔记本bios怎么设置(三星笔记本bios按哪个键)
pc浏览器是什么意思(pc模式的浏览器)

则是在电脑上使用的所有的浏览器。可以在电脑上使用的浏览器有非常多,我们现在比较常用的包括UC浏览器,搜狗浏览器,360浏览器等等,这些浏览器都可以在大部分的电脑上正常使用,而且使用起来非常流畅,市场的...

win10取消电脑开机密码(win10如何取消电脑开机密码取消)

取消Windows10开机密码的方法如下:1.在Windows10桌面上,按下WIN+R组合键,打开运行窗口。2.输入"netplwiz"然后按下回车键,这...

微信记录恢复助手(微信记录恢复助手安全吗)
  • 微信记录恢复助手(微信记录恢复助手安全吗)
  • 微信记录恢复助手(微信记录恢复助手安全吗)
  • 微信记录恢复助手(微信记录恢复助手安全吗)
  • 微信记录恢复助手(微信记录恢复助手安全吗)
五笔打字怎么打(曹五笔打字怎么打)

操作步骤:1、按住Ctrl+空格键切换到五笔输入法;2、在输入面板上面单击右键选择“软键盘”——特殊符号;3、在打开的软键盘上单击“☆”即可。五笔打字是指采用五笔字型输入法向电脑中输入汉字。这种输入...

内存不能为written修复工具(一直出现内存不能为written)
  • 内存不能为written修复工具(一直出现内存不能为written)
  • 内存不能为written修复工具(一直出现内存不能为written)
  • 内存不能为written修复工具(一直出现内存不能为written)
  • 内存不能为written修复工具(一直出现内存不能为written)
电脑高手24在线咨询(电脑高手联系方式)

现在的电脑一般都不要重启键了。如果死机的话,按住开关键五秒,自动关机。再开机就行。至于他们说的快速关机CTRL+ALT+ENT快速重启CTRL+ALT+HOME是GOHST版安装后自带的快捷键,你的系...

你的电脑未正确启动自动修复

1、试试“禁止驱动强制签名”能不能进入桌面在“疑难解答”->“高级选项”->“启动模式”中选择“禁止驱动强制签名”,如果这样能正常开启,那么就说明是某个驱动的问题2、把错误驱动删掉如果你安...

电脑开机弹出系统恢复选项(电脑开机经常出现系统恢复界面)

  这种情况一般都是系统引导出现问题,可以【F8】选择【最后一次正确配置】,重启后一般都能恢复;如果不行可以选择进入【安全模式】【恢复我的计算机到一个较早的时间】。以下是详细介绍:  1、开机时多次点...

手机版电脑模拟器下载(手机电脑模拟器下载的文件在哪)
手机版电脑模拟器下载(手机电脑模拟器下载的文件在哪)

  玩家们想要在电脑上畅快地玩真实手机,首先就需要先下载它的电脑版模拟器啦。在这里推荐大家使用的是电脑安卓模拟器,这是一款十分流畅好用的真实手机安卓模拟器,性能强悍,功能完备。  1、下载完真实手机安卓模拟器。  2、在电脑上进行安装,双击...

2026-01-01 16:03 off999

下载计算机到手机(手机下载计算机怎么下载)
  • 下载计算机到手机(手机下载计算机怎么下载)
  • 下载计算机到手机(手机下载计算机怎么下载)
  • 下载计算机到手机(手机下载计算机怎么下载)
  • 下载计算机到手机(手机下载计算机怎么下载)
u盘启动不了怎么回事(u盘启动也启动不了)

原因三:USB传输性能不佳导致;解决三:换个USB插口试试,建议将u盘插入到电脑机箱后置的USB插口处。原因四:u盘自身的质量问题导致;解决四:换一个u盘制作试一试。原因五:电脑系统问题导致;解决五:...

联想笔记本电脑键盘输入没反应

1.首先在可以进行输入的位置,长按下某个按键1秒以上,看看有没有反应。有反应看第2,没反应看第3。2.控制面板~轻松使用~轻松使用设置中心~更改键盘的工作方式~取消筛选键并应用即可。3.打开设备管理器...

软件管家电脑版下载官网(软件管家电脑版下载官网安装)

要下载和安装应用程序,您可以按照以下步骤使用电脑管家:1.打开电脑管家应用程序。2.在主界面上,您可以找到一个名为“应用中心”的选项,点击它。3.在应用中心中,您可以浏览各种应用程序的列表。您可...

取消回复欢迎 发表评论: