`
helloandroid100
  • 浏览: 13677 次
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

java实现二十四节气计算

    博客分类:
  • java
阅读更多
import java.util.HashMap;
import java.util.Map;

/**
*@author:518ad-ccn
*date:Dec 13, 2011
*describe:24节气
*注:程序中使用到的计算节气公式、节气世纪常量等相关信息参照http://www.360doc.com/content/11/0106/22/5281066_84591519.shtml,
*程序的运行得出的节气结果绝大多数是正确的,有少数部份是有误差的
*/
public class _24SolarTerms {
private static final  double D = 0.2422;
private final static Map<String,Integer[]> INCREASE_OFFSETMAP = new HashMap<String, Integer[]>();//+1偏移
private final static Map<String,Integer[]> DECREASE_OFFSETMAP = new HashMap<String, Integer[]>();//-1偏移

/**24节气**/
private static enum SolarTermsEnum {
LICHUN,//--立春
YUSHUI,//--雨水
JINGZHE,//--惊蛰
CHUNFEN,//春分
QINGMING,//清明
GUYU,//谷雨
LIXIA,//立夏
XIAOMAN,//小满
MANGZHONG,//芒种
XIAZHI,//夏至
XIAOSHU,//小暑
DASHU,//大暑
LIQIU,//立秋
CHUSHU,//处暑
BAILU,//白露
QIUFEN,//秋分
HANLU,//寒露
SHUANGJIANG,//霜降
LIDONG,//立冬
XIAOXUE,//小雪
DAXUE,//大雪
DONGZHI,//冬至
XIAOHAN,//小寒
DAHAN;//大寒
}

static {
DECREASE_OFFSETMAP.put(SolarTermsEnum.YUSHUI.name(), new Integer[]{2026});//雨水
INCREASE_OFFSETMAP.put(SolarTermsEnum.CHUNFEN.name(), new Integer[]{2084});//春分
INCREASE_OFFSETMAP.put(SolarTermsEnum.XIAOMAN.name(), new Integer[]{2008});//小满
INCREASE_OFFSETMAP.put(SolarTermsEnum.MANGZHONG.name(), new Integer[]{1902});//芒种
INCREASE_OFFSETMAP.put(SolarTermsEnum.XIAZHI.name(), new Integer[]{1928});//夏至
INCREASE_OFFSETMAP.put(SolarTermsEnum.XIAOSHU.name(), new Integer[]{1925,2016});//小暑
INCREASE_OFFSETMAP.put(SolarTermsEnum.DASHU.name(), new Integer[]{1922});//大暑
INCREASE_OFFSETMAP.put(SolarTermsEnum.LIQIU.name(), new Integer[]{2002});//立秋
INCREASE_OFFSETMAP.put(SolarTermsEnum.BAILU.name(), new Integer[]{1927});//白露
INCREASE_OFFSETMAP.put(SolarTermsEnum.QIUFEN.name(), new Integer[]{1942});//秋分
INCREASE_OFFSETMAP.put(SolarTermsEnum.SHUANGJIANG.name(), new Integer[]{2089});//霜降
INCREASE_OFFSETMAP.put(SolarTermsEnum.LIDONG.name(), new Integer[]{2089});//立冬
INCREASE_OFFSETMAP.put(SolarTermsEnum.XIAOXUE.name(), new Integer[]{1978});//小雪
INCREASE_OFFSETMAP.put(SolarTermsEnum.DAXUE.name(), new Integer[]{1954});//大雪
DECREASE_OFFSETMAP.put(SolarTermsEnum.DONGZHI.name(), new Integer[]{1918,2021});//冬至

INCREASE_OFFSETMAP.put(SolarTermsEnum.XIAOHAN.name(), new Integer[]{1982});//小寒
DECREASE_OFFSETMAP.put(SolarTermsEnum.XIAOHAN.name(), new Integer[]{2019});//小寒

INCREASE_OFFSETMAP.put(SolarTermsEnum.DAHAN.name(), new Integer[]{2082});//大寒
}

//定义一个二维数组,第一维数组存储的是20世纪的节气C值,第二维数组存储的是21世纪的节气C值,0到23个,依次代表立春、雨水...大寒节气的C值
private static final double[][] CENTURY_ARRAY =
{{4.6295,19.4599,6.3826,21.4155,5.59,20.888,6.318,21.86,6.5,22.2,7.928,23.65,8.35,
23.95,8.44,23.822,9.098,24.218,8.218,23.08,7.9,22.6,6.11,20.84}
,{3.87,18.73,5.63,20.646,4.81,20.1,5.52,21.04,5.678,21.37,7.108,22.83,
7.5,23.13,7.646,23.042,8.318,23.438,7.438,22.36,7.18,21.94,5.4055,20.12}};

/**
*
* @param year 年份
* @param name 节气的名称
* @return 返回节气是相应月份的第几天
*/
public static int getSolarTermNum(int year,String name){

double centuryValue = 0;//节气的世纪值,每个节气的每个世纪值都不同
name = name.trim().toUpperCase();
int ordinal = SolarTermsEnum.valueOf(name).ordinal();

int centuryIndex = -1;
if(year>=1901 && year<=2000){//20世纪
centuryIndex = 0;
} else if(year>=2001 && year <= 2100){//21世纪
centuryIndex = 1;
} else {
throw new RuntimeException("不支持此年份:"+year+",目前只支持1901年到2100年的时间范围");
}
centuryValue = CENTURY_ARRAY[centuryIndex][ordinal];
int dateNum = 0;
/**
* 计算 num =[Y*D+C]-L这是传说中的寿星通用公式
* 公式解读:年数的后2位乘0.2422加C(即:centuryValue)取整数后,减闰年数
*/
int y = year%100;//步骤1:取年分的后两位数
if(year%4 == 0 && year%100 !=0 || year%400 ==0){//闰年
if(ordinal == SolarTermsEnum.XIAOHAN.ordinal() || ordinal == SolarTermsEnum.DAHAN.ordinal()
|| ordinal == SolarTermsEnum.LICHUN.ordinal() || ordinal == SolarTermsEnum.YUSHUI.ordinal()){
//注意:凡闰年3月1日前闰年数要减一,即:L=[(Y-1)/4],因为小寒、大寒、立春、雨水这两个节气都小于3月1日,所以 y = y-1
y = y-1;//步骤2
}
}
dateNum = (int)(y*D+centuryValue)-(int)(y/4);//步骤3,使用公式[Y*D+C]-L计算
dateNum += specialYearOffset(year,name);//步骤4,加上特殊的年分的节气偏移量
return dateNum;
}

/**
* 特例,特殊的年分的节气偏移量,由于公式并不完善,所以算出的个别节气的第几天数并不准确,在此返回其偏移量
* @param year 年份
* @param name 节气名称
* @return 返回其偏移量
*/
public static int specialYearOffset(int year,String name) {
int offset = 0;
offset += getOffset(DECREASE_OFFSETMAP,year,name,-1);
offset += getOffset(INCREASE_OFFSETMAP,year,name,1);

return offset;
}

public static int getOffset(Map<String,Integer[]> map,int year,String name,int offset){
int off = 0;
Integer[] years = map.get(name);
if(null != years){
for(int i:years){
if(i == year){
off = offset;
break;
}
}
}
return off;
}

public static String solarTermToString(int year) {
StringBuffer sb = new StringBuffer();
sb.append("---").append(year);
if(year%4 == 0 && year%100 !=0 || year%400 ==0){//闰年
sb.append(" 闰年");
} else {
sb.append(" 平年");
}

sb.append("\n")
.append("立春:2月").append(getSolarTermNum(year,SolarTermsEnum.LICHUN.name()))
.append("日,雨水:2月").append(getSolarTermNum(year,SolarTermsEnum.YUSHUI.name()))
.append("日,惊蛰:3月").append(getSolarTermNum(year,SolarTermsEnum.JINGZHE.name()))
.append("日,春分:3月").append(getSolarTermNum(year,SolarTermsEnum.CHUNFEN.name()))
.append("日,清明:4月").append(getSolarTermNum(year,SolarTermsEnum.QINGMING.name()))
.append("日,谷雨:4月").append(getSolarTermNum(year,SolarTermsEnum.GUYU.name()))
.append("日,立夏:5月").append(getSolarTermNum(year,SolarTermsEnum.LIXIA.name()))
.append("日,小满:5月").append(getSolarTermNum(year,SolarTermsEnum.XIAOMAN.name()))
.append("日,芒种:6月").append(getSolarTermNum(year,SolarTermsEnum.MANGZHONG.name()))
.append("日,夏至:6月").append(getSolarTermNum(year,SolarTermsEnum.XIAZHI.name()))
.append("日,小暑:7月").append(getSolarTermNum(year,SolarTermsEnum.XIAOSHU.name()))
.append("日,大暑:7月").append(getSolarTermNum(year,SolarTermsEnum.DASHU.name()))
.append("日,\n立秋:8月").append(getSolarTermNum(year,SolarTermsEnum.LIQIU.name()))
.append("日,处暑:8月").append(getSolarTermNum(year,SolarTermsEnum.CHUSHU.name()))
.append("日,白露:9月").append(getSolarTermNum(year,SolarTermsEnum.BAILU.name()))
.append("日,秋分:9月").append(getSolarTermNum(year,SolarTermsEnum.QIUFEN.name()))
.append("日,寒露:10月").append(getSolarTermNum(year,SolarTermsEnum.HANLU.name()))
.append("日,霜降:10月").append(getSolarTermNum(year,SolarTermsEnum.SHUANGJIANG.name()))
.append("日,立冬:11月").append(getSolarTermNum(year,SolarTermsEnum.LIDONG.name()))
.append("日,小雪:11月").append(getSolarTermNum(year,SolarTermsEnum.XIAOXUE.name()))
.append("日,大雪:12月").append(getSolarTermNum(year,SolarTermsEnum.DAXUE.name()))
.append("日,冬至:12月").append(getSolarTermNum(year,SolarTermsEnum.DONGZHI.name()))
.append("日,小寒:1月").append(getSolarTermNum(year,SolarTermsEnum.XIAOHAN.name()))
.append("日,大寒:1月").append(getSolarTermNum(year,SolarTermsEnum.DAHAN.name()));

return sb.toString();
}

public static void main(String[] args) {
for(int year=1901;year<2050;year++){
System.out.println(solarTermToString(year));
}
}
}


//##########输出###########
---2009 平年
立春:2月4日,雨水:2月18日,惊蛰:3月5日,春分:3月20日,清明:4月4日,谷雨:4月20日,立夏:5月5日,小满:5月21日,芒种:6月5日,夏至:6月21日,小暑:7月7日,大暑:7月23日,
立秋:8月7日,处暑:8月23日,白露:9月7日,秋分:9月23日,寒露:10月8日,霜降:10月23日,立冬:11月7日,小雪:11月22日,大雪:12月7日,冬至:12月22日,小寒:1月5日,大寒:1月20
---2010 平年
立春:2月4日,雨水:2月19日,惊蛰:3月6日,春分:3月21日,清明:4月5日,谷雨:4月20日,立夏:5月5日,小满:5月21日,芒种:6月6日,夏至:6月21日,小暑:7月7日,大暑:7月23日,
立秋:8月7日,处暑:8月23日,白露:9月8日,秋分:9月23日,寒露:10月8日,霜降:10月23日,立冬:11月7日,小雪:11月22日,大雪:12月7日,冬至:12月22日,小寒:1月5日,大寒:1月20
---2011 平年
立春:2月4日,雨水:2月19日,惊蛰:3月6日,春分:3月21日,清明:4月5日,谷雨:4月20日,立夏:5月6日,小满:5月21日,芒种:6月6日,夏至:6月22日,小暑:7月7日,大暑:7月23日,
立秋:8月8日,处暑:8月23日,白露:9月8日,秋分:9月23日,寒露:10月8日,霜降:10月24日,立冬:11月8日,小雪:11月23日,大雪:12月7日,冬至:12月22日,小寒:1月6日,大寒:1月20
---2012 闰年
立春:2月4日,雨水:2月19日,惊蛰:3月5日,春分:3月20日,清明:4月4日,谷雨:4月20日,立夏:5月5日,小满:5月20日,芒种:6月5日,夏至:6月21日,小暑:7月7日,大暑:7月22日,
立秋:8月7日,处暑:8月23日,白露:9月7日,秋分:9月22日,寒露:10月8日,霜降:10月23日,立冬:11月7日,小雪:11月22日,大雪:12月7日,冬至:12月21日,小寒:1月6日,大寒:1月20

.
.
.
分享到:
评论
1 楼 chslzhj 2015-02-09  
博主的数据都是从哪里采集到的

相关推荐

    基于Vue开发的二十四节气网站源码(Java课程设计).zip

    基于Vue开发的二十四节气网站源码(Java课程设计).zip基于Vue开发的二十四节气网站源码(Java课程设计).zip基于Vue开发的二十四节气网站源码(Java课程设计).zip基于Vue开发的二十四节气网站源码(Java课程设计).zip基于...

    Java万年历包含公历农历星期二十四节气

    Java万年历是一款功能丰富的日历应用,专为程序员和普通用户设计,提供从1800年至2100年间的日期展示,涵盖了公历、农历、星期以及二十四节气等多种时间信息。这款程序的核心在于其强大的日期计算和转换算法,能够...

    二十四节气计算日期

    计算二十四节气的算法一般涉及以下步骤: 1. **基础数据**:需要知道每个节气对应的黄经度,如立春为315°,春分为0°,夏至为90°等。 2. **太阳黄经计算**:根据公历日期,计算出该日期对应的儒略日(Julian Day ...

    java计算24节气

    综上所述,要实现“java计算24节气”的功能,我们需要熟悉Java的日期时间API,理解24节气的天文背景,编写算法或利用现有库,最后通过编程将这些元素整合起来,确保代码的正确性和效率。在实际项目中,还可以考虑...

    Android高级应用源码-精确计算农历二十四节气.rar

    2. **节气计算**:计算二十四节气通常需要结合地球公转的黄经角度和农历日期。开发者可能使用了中国古代的黄道十二宫或现代天文学方法,通过特定的公式计算节气。 3. **Android编程实践**:源码中会涉及到Android...

    Android 精确计算农历二十四节气-IT计算机-毕业设计.zip

    6. **二十四节气计算**:根据农历算法,计算出每年的二十四节气的具体日期。节气是根据地球在黄道上的位置来划分的,这涉及到天文知识和数学计算。 7. **事件触发与提醒**:当节气到来时,应用可以发送通知提醒用户...

    安卓天气日历时间选择倒计时相关-精确计算农历二十四节气.zip

    总结来说,这个压缩包为安卓开发者提供了一套计算农历二十四节气的工具,结合`JavaApk源码说明.txt`的指南,可以帮助他们实现天气、日历、倒计时等功能,并融入中国传统文化元素。对于想要提升应用独特性和用户体验...

    java 获取农历24节气时间

    Java 实现当前日期的农历日期显示以及节气显示,完美实现24节气

    Android代码-精确计算农历二十四节气.zip

    在Android开发中,有时我们需要实现一些特色功能,例如精确计算农历二十四节气。这个压缩包“Android代码-精确计算农历二十四节气.zip”提供了一种解决方案。它包含了一个名为SolarTerm.java的Java类,用于计算农历...

    java 节气 干支 源码

    在Java编程语言中,"java 节气 干支 源码"涉及的是中国古代天文历法的计算,主要包括节气(二十四节气)、干支纪年法以及农历的相关知识。下面将详细阐述这些概念及其在源码中的实现。 首先,让我们了解什么是干支...

    精确计算农历二十四节气.zip

    这个压缩包“精确计算农历二十四节气.zip”很可能包含了实现这一功能的源代码,这对于我们深入理解和运用Android开发,尤其是进行毕业设计或者Java编程项目,是非常有价值的。 首先,我们要知道农历二十四节气是...

    精确计算农历二十四节气.zip项目安卓应用源码下载

    这个安卓应用源码项目"精确计算农历二十四节气"是一个基于Android平台的程序,旨在提供准确的农历节气计算功能。对于开发者来说,无论是学生、个人还是公司团队,都可以从这个项目中学习到宝贵的编程技术和知识。...

    安卓Andriod源码——精确计算农历二十四节气.zip

    3. **节气计算算法**:二十四节气的计算涉及天文学知识,开发者可能采用了特定的公式或者算法来确定每个节气的具体日期。这些算法可能基于太阳黄经角度的变化,例如,春分点(立春)为黄经315度,清明为黄经15度等。...

    安卓Android源码——精确计算农历二十四节气.zip

    这个压缩包“安卓Android源码——精确计算农历二十四节气.zip”正是为实现这样的功能而提供的。其中包含了一个名为“SolarTerm.java”的源代码文件,这个文件是用于精确计算农历节气的核心部分。 首先,我们来理解...

    Android高级应用源码-精确计算农历二十四节气.zip

    总结来说,`Android高级应用源码-精确计算农历二十四节气.zip`中的`SolarTerm.java`文件很可能实现了从公历日期到农历节气的转换算法,并且提供了与Android系统集成的接口,使得用户能够方便地查看和了解节气信息。...

    超高仿华为日历功能,显示二十四节气和特殊节假日,日历可以伸缩。在此日历基础上可以实现备忘录等功能

    3. **二十四节气的计算**:二十四节气是中国传统的天文历法,开发者需要编写算法或利用开源库(如`chinese-calendar-utils`)来计算特定日期对应的节气,然后在日历上标记出来。 4. **节假日的获取**:节假日数据...

    二十四节气时间推算程序.zip

    对于这个"二十四节气时间推算程序",源码可能包括了计算节气算法的实现,可能涉及到了历法转换、天文计算等相关知识。下面我们将深入探讨这些关键知识点: 1. **农历与公历转换**:中国的二十四节气是基于农历制定...

    java公历转农历及计算节气的工具类

    输入公历可获取当日农历(包括属相)和节气

    获取农历、兔年之类的、节气的纯JAVA代码

    综上所述,实现获取农历、生肖和节气的Java代码需要对农历算法有深入理解,可能还需要引入第三方库。DEMO中的输出显示了这些信息的组合,实现时可以先计算农历日期和生肖,再判断当前节气,最后组合输出。文件`...

Global site tag (gtag.js) - Google Analytics