资源简介
本代码已经在项目中应用。
压缩包里附送 日升日落时间计算(2.0版).xls
代码片段和文件信息
using System;
namespace Tools.TimeAbout
{
///
/// 日出日落时间类
///
public static class SunTimes
{
#region 公共方法
///
/// 计算日长
///
/// 日期
/// 经度
/// 纬度
/// 日长
///
/// 注:日期最小为2000.1.1号
///
public static double GetDayLength(DateTime date double longitude double latitude)
{
double result = DayLen(date.Year date.Month date.Day longitude latitude -35.0 / 60.0 1);
return result;
}
///
/// 计算日出日没时间
///
/// 日期
/// 经度
/// 纬度
/// 日落日出时间
///
/// 注:日期最小为2000.1.1号
///
public static SunTimeResult GetSunTime(DateTime date double longitude double latitude)
{
double start = 0;
double end = 0;
SunRiset(date.Year date.Month date.Day longitude latitude -35.0 / 60.0 1 ref start ref end);
DateTime sunrise = ToLocalTime(date start);
DateTime sunset = ToLocalTime(date end);
return new SunTimeResult(sunrise sunset);
}
#endregion
#region 私有方法
#region 时间转换
private static DateTime ToLocalTime(DateTime time double utTime)
{
int hour = Convert.ToInt32(Math.Floor(utTime));
double temp = utTime - hour;
hour += 8;//转换为东8区北京时间
temp = temp * 60;
int minute = Convert.ToInt32(Math.Floor(temp));
try
{
return new DateTime(time.Year time.Month time.Day hour minute 0);
}
catch
{
return new DateTime(time.Year time.Month time.Day 0 0 0);
}
}
#endregion
#region 与日出日落时间相关计算
private static double DayLen(int year int month int day double lon double lat
double altit int upper_limb)
{
double d /* Days since 2000 Jan 0.0 (negative before) */
obl_ecl /* Obliquity (inclination) of Earth‘s axis */
//黄赤交角,在2000.0历元下国际规定为23度26分21.448秒,但有很小的时间演化。
sr /* Solar distance astronomical units */
slon /* True solar longitude */
sin_sdecl /* Sine of Sun‘s declination */
//太阳赤纬的正弦值。
cos_sdecl /* Cosine of Sun‘s declination */
sradius /* Sun‘s apparent radius */
t; /* Diurnal arc */
/* Compute
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 14797 2010-06-12 23:33 SunTimes.cs
文件 199680 2014-05-04 17:43 日升日落时间计算(2.0版).xls
相关资源
- C# 调用win32 api函数-user32.dll详细说明
- C# 调用BarTender打印条码DEMO
- 大型比赛竞赛抽签系统 可打印 c# vs
- C#编写的Gerber查看器
- lua C# .Net4.0 vs2010 LuaInterface
- C#十六进制编辑器
- 明华URF-35H读卡器 C#读写源码 为大家
- C#文件流读取CSV文件
- c#读写PDF文件sql
- C# winform Socket大文件传输
- c#车牌识别系统附30张测试图片
- 《C#面向对象程序设计》源代码(CS)
- 金旭亮《C#面向对象程序设计》教案
- 试题库管理系统毕业论文(C#)源程序
- 学校网站原代码(C#.NET)
- C#-数据库操作技术-员工管理系统
- c#web开发入门经典
- C#与Matlab混合编程的几种方式
- c# 开发与 mysql数据库实现的增删改查
- C#异步操作 异步查询数据库 异步处理
- Basler相机通过IO触发源码
- [源代码] 《领域驱动设计 (C# 2008 实
- 松下PLC与C#通讯串口调试入门教程.z
- USB 继电器控制器 LCUS-1 保证能用 c#
- C# AES加密解密小工具
- C#圆形按钮,非常漂亮动态~~
- [精]C#仿QQ右下角弹出提示框()
- C#进程间通信-共享内存代码
- 有史以来最简单的三层(C#)
- vb调用c#编写的串口DLL文件(vb源码
评论
共有 条评论