美文网首页其它技术点iOS Developer代码片段
根据经纬度和日期计算日出日落时间

根据经纬度和日期计算日出日落时间

作者: Ziggear | 来源:发表于2017-05-25 02:29 被阅读389次

直接计算日出和日落时间会比较复杂,可以通过计算当地的“正午”时间、当地的“白天”时长,用正午时间平分白天时长,得到当地的日出时间和日落时间。

计算正午时间

一个地方的正午时间,可以通过当地经度与当地所属时区经度的差计算得到。全世界有24个时区,每个时区相隔1小时,因此每个时区之间相差的经度是 360 / 24 = 15°。已北京为例,北京所属时区为东8区,东8区的中心经度是15 * 8 = 120°(因此东8区的范围是112.5° - 127.5°)。

北京的经度是116.46,与东8区中心相差 120 - 116.46 = 3.54,又因为1小时相当于15°,可得

时差 = 3.54 * 1 / 15 = 0.236 小时 = 14.16 分钟

地球是自西向东旋转,因此经度小于时区中心的位置,正午来得比时区中心要晚,正午时间是12:00 + 时差

因此北京的正午时间应该是 12 + 0.236 = 12.236 小时(约12:14)

计算白天的时长

图1

一个地方白天的时长,可以由一定角度下的太阳光照射出的昼夜分隔线(上图经过B点的斜线),切割这个地方的纬线比例得到。纬线一圈是24小时,根据切割比例就可以得出当地的白天时长。

图2

用直观一点的图2来解释,太阳以一定角度斜射地球,A地点此刻是正午,白天是B1-A-B2,夜晚是B1-C-B2,因此A点的白天时间为B1-A-B2所占的角度在24小时中的占比。

先来看图2的左边,假设上图中阳光入射角为α,A点的纬度为θ,根据三角函数可得:

O‘B / O'O = tanα 

O'O / AO = sinθ

所以 O'O = AO * sin θ  ,O'B = O'O * tanα = AO * sin θ * tanα (AO是地球半径)

再看图2的右边,是这个纬度截面的平面图:

已知 O'B = r * sin θ * tanα

O'B1 是这个纬度截面的圆的半径 r',这个半径的计算方法在上篇计算经纬度距离的文章中已经给出:r' = r * cosθ

因此 O'B1 与 O'B 的夹角 cosβ = O'B / O'B1,这样我们就能计算出β

最终可以得到:A点的白天角度 = (360 - β * 2)  A点的白天时间 = A点的白天角度 / 360 * 24

为了进行上面这些计算,需要知道A点阳光入射角为α

计算阳光入射角α

阳光入射角α是太阳光线与地球赤道面的夹角,春分和秋分时α = 0,夏至时α = 23°27′,冬至时α = - 23°27′。因为1年有365天(暂时忽略闰年的误差),春分(3月20日)、夏至(6月22日)、秋分(9月20日)、冬至(12月22日)把365天分为4个部分,因此可以根据具体日期,得到这个日期的α。

最后,举个例子

以北京,5月25日为例,落在春分到夏至的区间内,是春分过后65天。而春分到夏至一共有92天,这个区间已经过去了65%,因此可以计算得出5月25日的 α = 23°27′ * 0.71 = 16.65

北京的经度:116.46,纬度:39.92,5月25日太阳光与赤道的夹角 α = 16.65

代入上面的公式:

O'B = r * sin θ * tanα = r * sin 39.92 * tan 16.65

O'B1 = r' =  r * cosθ = r * cos 39.92

cosβ = O'B / O'B1 ; β = arccos(O'B / O'B1) = arccos(r * sin 39.92 * tan 16.65 / r * cos 39.92)

北京白天在纬度切面所占的角度 = (360 - β * 2)

北京白天在纬度切面所占的时间 = (360 - β * 2) / 360 * 24 = 208.96 / 360 * 24 = 13.93 h

又根据上面的计算,北京的实际正午时间是 12.236小时

日出时间 = 12.236 + 13.93 / 2 = 5.27,大约是 05:16

日落时间= 12.236 - 13.93 / 2 = 19.201,大约是 19:12

备注

以上方法只能得到一个粗略的日出日落时间,与实际时间有比较大的误差,仅用于理解日出日落时间的计算方法。

相关文章

  • 根据经纬度和日期计算日出日落时间

    直接计算日出和日落时间会比较复杂,可以通过计算当地的“正午”时间、当地的“白天”时长,用正午时间平分白天时长,得到...

  • js根据经纬度计算日出日落时间

    直接上代码,简单粗暴calcnew函数中的参数意思type:1日出2日落latitude:纬度longitude:...

  • iOS定位功能

    小序: 本文包括三个内容:①:定位功能的实现②:知道城市名拿到经纬度③:根据经纬度拿到日出日落时间关于定位我们要添...

  • 地址转换为经纬度,经纬度距离计算

    根据已知地址,将地址经纬度计算出来,不多说直接上代码 根据经纬度计算两点之间的距离

  • 经纬度坐标间的距离

    参考: 【Python学习】指定两点地理位置经纬度的距离计算 经纬度计算小工具 Python根据经纬度求两点间距离...

  • 通过经纬度计算日升日落时间

    // 通过经纬度获取日出日落时间 // 纬度、精度、时区 computeSunRiseSunSet(Latitu...

  • 根据日期计算星期

    基姆拉尔森计算公式: W= (days + 2 * month + 3 * (month + 1) / 5 + y...

  • 根据日期计算星座

    在app中,展示个人信息时,有时候服务器只返回一个生日,然后要在个人信息里展示相应的星座名称和图标,这时候就需要客...

  • JS日期计算

    一、工具函数 二、日期计算 1)根据给定年份计算周时间段列表: 2)根据给定年份计算月时间段列表: 3)根据给定年...

  • 可根据时间自动计算日期的datePicker

    主要就是简单封装了一下datePickerView,当其显示时间时,同时显示该天是周几,当然加上了一下,简单的显示...

网友评论

本文标题:根据经纬度和日期计算日出日落时间

本文链接:https://www.haomeiwen.com/subject/kmlaxxtx.html