diff --git a/README.md b/README.md index 872b6b6..c54d5fb 100644 --- a/README.md +++ b/README.md @@ -16,7 +16,7 @@ lunar是一款无第三方依赖的公历(阳历)、农历(阴历、老黄历) cn.6tail lunar - 1.3.3 + 1.3.4 ``` diff --git a/README_EN.md b/README_EN.md index afe6358..82f59bf 100644 --- a/README_EN.md +++ b/README_EN.md @@ -12,7 +12,7 @@ lunar is a calendar library for Solar and Chinese Lunar. cn.6tail lunar - 1.3.3 + 1.3.4 ``` diff --git a/pom.xml b/pom.xml index 6fac81e..0580c4d 100644 --- a/pom.xml +++ b/pom.xml @@ -7,7 +7,7 @@ cn.6tail lunar jar - 1.3.3 + 1.3.4 ${project.groupId}:${project.artifactId} https://github.com/6tail/lunar-java a calendar library for Solar and Chinese Lunar diff --git a/src/main/java/com/nlf/calendar/EightChar.java b/src/main/java/com/nlf/calendar/EightChar.java index cf2a491..efbba81 100644 --- a/src/main/java/com/nlf/calendar/EightChar.java +++ b/src/main/java/com/nlf/calendar/EightChar.java @@ -185,8 +185,7 @@ public class EightChar { } private String getDiShi(int zhiIndex) { - int offset = CHANG_SHENG_OFFSET.get(getDayGan()); - int index = offset + (getDayGanIndex() % 2 == 0 ? zhiIndex : -zhiIndex); + int index = CHANG_SHENG_OFFSET.get(getDayGan()) + (getDayGanIndex() % 2 == 0 ? zhiIndex : -zhiIndex); if (index >= 12) { index -= 12; } diff --git a/src/main/java/com/nlf/calendar/Foto.java b/src/main/java/com/nlf/calendar/Foto.java index c41868a..3bc5678 100644 --- a/src/main/java/com/nlf/calendar/Foto.java +++ b/src/main/java/com/nlf/calendar/Foto.java @@ -74,6 +74,10 @@ public class Foto { return lunar.getDayInChinese(); } + /** + * 获取因果犯忌 + * @return 因果犯忌 + */ public List getFestivals() { List l = new ArrayList(); List fs = FotoUtil.FESTIVAL.get(getMonth() + "-" + getDay()); @@ -83,6 +87,19 @@ public class Foto { return l; } + /** + * 获取纪念日 + * @return 纪念日 + */ + public List getOtherFestivals() { + List l = new ArrayList(); + List fs = FotoUtil.OTHER_FESTIVAL.get(getMonth() + "-" + getDay()); + if (null != fs) { + l.addAll(fs); + } + return l; + } + /** * 是否月斋 * diff --git a/src/main/java/com/nlf/calendar/Lunar.java b/src/main/java/com/nlf/calendar/Lunar.java index 853117b..8445fc6 100644 --- a/src/main/java/com/nlf/calendar/Lunar.java +++ b/src/main/java/com/nlf/calendar/Lunar.java @@ -1776,9 +1776,7 @@ public class Lunar { * @return 值日天神 */ public String getDayTianShen() { - String monthZhi = getMonthZhi(); - int offset = LunarUtil.ZHI_TIAN_SHEN_OFFSET.get(monthZhi); - return LunarUtil.TIAN_SHEN[(dayZhiIndex + offset) % 12 + 1]; + return LunarUtil.TIAN_SHEN[(dayZhiIndex + LunarUtil.ZHI_TIAN_SHEN_OFFSET.get(getMonthZhi())) % 12 + 1]; } /** @@ -1787,9 +1785,7 @@ public class Lunar { * @return 值时天神 */ public String getTimeTianShen() { - String dayZhi = getDayZhiExact(); - int offset = LunarUtil.ZHI_TIAN_SHEN_OFFSET.get(dayZhi); - return LunarUtil.TIAN_SHEN[(timeZhiIndex + offset) % 12 + 1]; + return LunarUtil.TIAN_SHEN[(timeZhiIndex + LunarUtil.ZHI_TIAN_SHEN_OFFSET.get(getDayZhiExact())) % 12 + 1]; } /** diff --git a/src/main/java/com/nlf/calendar/LunarMonth.java b/src/main/java/com/nlf/calendar/LunarMonth.java index 2374716..01a9755 100644 --- a/src/main/java/com/nlf/calendar/LunarMonth.java +++ b/src/main/java/com/nlf/calendar/LunarMonth.java @@ -31,6 +31,10 @@ public class LunarMonth { */ private final double firstJulianDay; + private final int index; + + private final int zhiIndex; + /** * 初始化 * @@ -39,11 +43,13 @@ public class LunarMonth { * @param dayCount 天数 * @param firstJulianDay 初一的儒略日 */ - public LunarMonth(int lunarYear, int lunarMonth, int dayCount, double firstJulianDay) { + public LunarMonth(int lunarYear, int lunarMonth, int dayCount, double firstJulianDay, int index) { this.year = lunarYear; this.month = lunarMonth; this.dayCount = dayCount; this.firstJulianDay = firstJulianDay; + this.index = index; + this.zhiIndex = (index - 1 + LunarUtil.BASE_MONTH_ZHI_INDEX) % 12; } /** @@ -93,6 +99,31 @@ public class LunarMonth { return dayCount; } + public int getIndex() { + return index; + } + + public int getZhiIndex() { + return zhiIndex; + } + + public int getGanIndex() { + int offset = (LunarYear.fromYear(year).getGanIndex() + 1) % 5 * 2; + return (index - 1 + offset) % 10; + } + + public String getGan() { + return LunarUtil.GAN[getGanIndex() + 1]; + } + + public String getZhi() { + return LunarUtil.ZHI[zhiIndex + 1]; + } + + public String getGanZhi() { + return getGan() + getZhi(); + } + /** * 获取初一的儒略日 * @@ -102,6 +133,46 @@ public class LunarMonth { return firstJulianDay; } + public String getPositionXi() { + return LunarUtil.POSITION_XI[getGanIndex() + 1]; + } + + public String getPositionXiDesc() { + return LunarUtil.POSITION_DESC.get(getPositionXi()); + } + + public String getPositionYangGui() { + return LunarUtil.POSITION_YANG_GUI[getGanIndex() + 1]; + } + + public String getPositionYangGuiDesc() { + return LunarUtil.POSITION_DESC.get(getPositionYangGui()); + } + + public String getPositionYinGui() { + return LunarUtil.POSITION_YIN_GUI[getGanIndex() + 1]; + } + + public String getPositionYinGuiDesc() { + return LunarUtil.POSITION_DESC.get(getPositionYinGui()); + } + + public String getPositionFu(int sect) { + return (1 == sect ? LunarUtil.POSITION_FU : LunarUtil.POSITION_FU_2)[getGanIndex() + 1]; + } + + public String getPositionFuDesc(int sect) { + return LunarUtil.POSITION_DESC.get(getPositionFu(sect)); + } + + public String getPositionCai() { + return LunarUtil.POSITION_CAI[getGanIndex() + 1]; + } + + public String getPositionCaiDesc() { + return LunarUtil.POSITION_DESC.get(getPositionCai()); + } + /** * 获取太岁方位 * @@ -121,7 +192,7 @@ public class LunarMonth { p = "坤"; break; default: - p = LunarUtil.POSITION_GAN[Solar.fromJulianDay(this.getFirstJulianDay()).getLunar().getMonthGanIndex()]; + p = LunarUtil.POSITION_GAN[Solar.fromJulianDay(getFirstJulianDay()).getLunar().getMonthGanIndex()]; } return p; } diff --git a/src/main/java/com/nlf/calendar/LunarTime.java b/src/main/java/com/nlf/calendar/LunarTime.java index a8f3339..812f942 100644 --- a/src/main/java/com/nlf/calendar/LunarTime.java +++ b/src/main/java/com/nlf/calendar/LunarTime.java @@ -206,9 +206,7 @@ public class LunarTime { * @return 值时天神 */ public String getTianShen() { - String dayZhi = lunar.getDayZhiExact(); - int offset = LunarUtil.ZHI_TIAN_SHEN_OFFSET.get(dayZhi); - return LunarUtil.TIAN_SHEN[(zhiIndex + offset) % 12 + 1]; + return LunarUtil.TIAN_SHEN[(zhiIndex + LunarUtil.ZHI_TIAN_SHEN_OFFSET.get(lunar.getDayZhiExact())) % 12 + 1]; } /** diff --git a/src/main/java/com/nlf/calendar/LunarYear.java b/src/main/java/com/nlf/calendar/LunarYear.java index c1ce26a..fe59c26 100644 --- a/src/main/java/com/nlf/calendar/LunarYear.java +++ b/src/main/java/com/nlf/calendar/LunarYear.java @@ -175,17 +175,20 @@ public class LunarYear { int y = prevYear; int m = 11; + int index = m; for (int i = 0, j = dayCounts.length; i < j; i++) { int cm = m; if (y == leapYear && i == leapIndex) { cm = -cm; } - this.months.add(new LunarMonth(y, cm, dayCounts[i], hs[i] + Solar.J2000)); + this.months.add(new LunarMonth(y, cm, dayCounts[i], hs[i] + Solar.J2000, index)); if (y != leapYear || i + 1 != leapIndex) { m++; } + index++; if (m == 13) { m = 1; + index = 1; y++; } } diff --git a/src/main/java/com/nlf/calendar/Solar.java b/src/main/java/com/nlf/calendar/Solar.java index 6e1257b..f49e01d 100644 --- a/src/main/java/com/nlf/calendar/Solar.java +++ b/src/main/java/com/nlf/calendar/Solar.java @@ -306,9 +306,10 @@ public class Solar { } List hours = new ArrayList(2); String timeZhi = timeGanZhi.substring(1); - for(int i = 0, j = LunarUtil.ZHI.length; i < j; i++){ + for(int i = 1, j = LunarUtil.ZHI.length; i < j; i++){ if(LunarUtil.ZHI[i].equals(timeZhi)){ hours.add((i - 1) * 2); + break; } } if ("子".equals(timeZhi)) { diff --git a/src/main/java/com/nlf/calendar/util/FotoUtil.java b/src/main/java/com/nlf/calendar/util/FotoUtil.java index 277baca..d30fe0e 100644 --- a/src/main/java/com/nlf/calendar/util/FotoUtil.java +++ b/src/main/java/com/nlf/calendar/util/FotoUtil.java @@ -262,6 +262,46 @@ public class FotoUtil { } }; + /** + * 纪念日 + */ + public static final Map> OTHER_FESTIVAL = new HashMap>() { + private static final long serialVersionUID = -1; + + { + put("1-1", Collections.nCopies(1, "弥勒菩萨圣诞")); + put("1-6", Collections.nCopies(1, "定光佛圣诞")); + put("2-8", Collections.nCopies(1, "释迦牟尼佛出家")); + put("2-15", Collections.nCopies(1, "释迦牟尼佛涅槃")); + put("2-19", Collections.nCopies(1, "观世音菩萨圣诞")); + put("2-21", Collections.nCopies(1, "普贤菩萨圣诞")); + put("3-16", Collections.nCopies(1, "准提菩萨圣诞")); + put("4-4", Collections.nCopies(1, "文殊菩萨圣诞")); + put("4-8", Collections.nCopies(1, "释迦牟尼佛圣诞")); + put("4-15", Collections.nCopies(1, "佛吉祥日")); + put("4-28", Collections.nCopies(1, "药王菩萨圣诞")); + put("5-13", Collections.nCopies(1, "伽蓝菩萨圣诞")); + put("6-3", Collections.nCopies(1, "韦驮菩萨圣诞")); + put("6-19", Collections.nCopies(1, "观音菩萨成道")); + put("7-13", Collections.nCopies(1, "大势至菩萨圣诞")); + put("7-15", Collections.nCopies(1, "佛欢喜日")); + put("7-24", Collections.nCopies(1, "龙树菩萨圣诞")); + put("7-30", Collections.nCopies(1, "地藏菩萨圣诞")); + put("8-15", Collections.nCopies(1, "月光菩萨圣诞")); + put("8-22", Collections.nCopies(1, "燃灯佛圣诞")); + put("9-9", Collections.nCopies(1, "摩利支天菩萨圣诞")); + put("9-19", Collections.nCopies(1, "观世音菩萨出家")); + put("9-30", Collections.nCopies(1, "药师琉璃光佛圣诞")); + put("10-5", Collections.nCopies(1, "达摩祖师圣诞")); + put("10-20", Collections.nCopies(1, "文殊菩萨出家")); + put("11-17", Collections.nCopies(1, "阿弥陀佛圣诞")); + put("11-19", Collections.nCopies(1, "日光菩萨圣诞")); + put("12-8", Collections.nCopies(1, "释迦牟尼佛成道")); + put("12-23", Collections.nCopies(1, "监斋菩萨圣诞")); + put("12-29", Collections.nCopies(1, "华严菩萨圣诞")); + } + }; + /** * 27星宿,佛教从印度传入中国,印度把28星宿改为27星宿,把牛宿(牛金牛)纳入了女宿(女土蝠)。 */ diff --git a/src/main/java/com/nlf/calendar/util/LunarUtil.java b/src/main/java/com/nlf/calendar/util/LunarUtil.java index 1322d82..9524070 100644 --- a/src/main/java/com/nlf/calendar/util/LunarUtil.java +++ b/src/main/java/com/nlf/calendar/util/LunarUtil.java @@ -123,7 +123,7 @@ public class LunarUtil{ /** 日 */ public static final String[] DAY = {"","初一","初二","初三","初四","初五","初六","初七","初八","初九","初十","十一","十二","十三","十四","十五","十六","十七","十八","十九","二十","廿一","廿二","廿三","廿四","廿五","廿六","廿七","廿八","廿九","三十"}; /** 月相,朔月也叫新月,望月也叫满月 */ - public static final String[] YUE_XIANG = {"","朔","既朔","蛾眉新","蛾眉新","蛾眉","夕月","上弦","上弦","九夜","宵","宵","宵","渐盈凸","小望","望","既望","立待","居待","寝待","更待","渐亏凸","下弦","下弦","有明","有明","蛾眉残","蛾眉残","残","晓","晦"}; + public static final String[] YUE_XIANG = {"","朔","既朔","蛾眉新","蛾眉新","蛾眉","夕","上弦","上弦","九夜","宵","宵","宵","渐盈凸","小望","望","既望","立待","居待","寝待","更待","渐亏凸","下弦","下弦","有明","有明","蛾眉残","蛾眉残","残","晓","晦"}; /** 农历日期对应的节日 */ public static final Map FESTIVAL = new HashMap(){ private static final long serialVersionUID = -1; @@ -1118,8 +1118,7 @@ public class LunarUtil{ boolean matched = false; String months = left.substring(0, left.indexOf(":")); for (int i = 0, j = months.length(); i < j; i += 2) { - String m = months.substring(i, i + 2); - if (m.equals(month)) { + if (month.equals(months.substring(i, i + 2))) { matched = true; break; } @@ -1128,8 +1127,7 @@ public class LunarUtil{ String ys = left.substring(left.indexOf(":") + 1); ys = ys.substring(0, ys.indexOf(",")); for (int i = 0, j = ys.length(); i < j; i += 2) { - String m = ys.substring(i, i + 2); - l.add(YI_JI[Integer.parseInt(m,16)]); + l.add(YI_JI[Integer.parseInt(ys.substring(i, i + 2),16)]); } break; } diff --git a/src/main/java/com/nlf/calendar/util/SolarUtil.java b/src/main/java/com/nlf/calendar/util/SolarUtil.java index fdebcf0..97b135f 100644 --- a/src/main/java/com/nlf/calendar/util/SolarUtil.java +++ b/src/main/java/com/nlf/calendar/util/SolarUtil.java @@ -69,70 +69,141 @@ public class SolarUtil { { put("1-8", Collections.nCopies(1, "周恩来逝世纪念日")); - put("1-10", Arrays.asList("中国人民警察节", "中国公安110宣传日")); + put("1-10", Collections.nCopies(1, "中国人民警察节")); + put("1-14", Collections.nCopies(1, "日记情人节")); put("1-21", Collections.nCopies(1, "列宁逝世纪念日")); put("1-26", Collections.nCopies(1, "国际海关日")); + put("1-27", Collections.nCopies(1, "国际大屠杀纪念日")); put("2-2", Collections.nCopies(1, "世界湿地日")); put("2-4", Collections.nCopies(1, "世界抗癌日")); - put("2-7", Collections.nCopies(1, "京汉铁路罢工纪念")); + put("2-7", Collections.nCopies(1, "京汉铁路罢工纪念日")); put("2-10", Collections.nCopies(1, "国际气象节")); put("2-19", Collections.nCopies(1, "邓小平逝世纪念日")); + put("2-20", Collections.nCopies(1, "世界社会公正日")); put("2-21", Collections.nCopies(1, "国际母语日")); put("2-24", Collections.nCopies(1, "第三世界青年日")); put("3-1", Collections.nCopies(1, "国际海豹日")); - put("3-3", Collections.nCopies(1, "全国爱耳日")); + put("3-3", Arrays.asList("世界野生动植物日", "全国爱耳日")); put("3-5", Arrays.asList("周恩来诞辰纪念日", "中国青年志愿者服务日")); put("3-6", Collections.nCopies(1, "世界青光眼日")); + put("3-7", Collections.nCopies(1, "女生节")); put("3-12", Collections.nCopies(1, "孙中山逝世纪念日")); - put("3-14", Collections.nCopies(1, "马克思逝世纪念日")); + put("3-14", Arrays.asList("马克思逝世纪念日", "白色情人节")); put("3-17", Collections.nCopies(1, "国际航海日")); - put("3-18", Collections.nCopies(1, "全国科技人才活动日")); - put("3-21", Arrays.asList("世界森林日", "世界睡眠日")); + put("3-18", Arrays.asList("全国科技人才活动日", "全国爱肝日")); + put("3-20", Collections.nCopies(1, "国际幸福日")); + put("3-21", Arrays.asList("世界森林日", "世界睡眠日", "国际消除种族歧视日")); put("3-22", Collections.nCopies(1, "世界水日")); put("3-23", Collections.nCopies(1, "世界气象日")); put("3-24", Collections.nCopies(1, "世界防治结核病日")); - put("4-2", Collections.nCopies(1, "国际儿童图书日")); + put("3-29", Collections.nCopies(1, "中国黄花岗七十二烈士殉难纪念日")); + put("4-2", Arrays.asList("国际儿童图书日", "世界自闭症日")); + put("4-4", Collections.nCopies(1, "国际地雷行动日")); put("4-7", Collections.nCopies(1, "世界卫生日")); - put("4-22", Collections.nCopies(1, "列宁诞辰纪念日")); - put("4-23", Collections.nCopies(1, "世界图书和版权日")); - put("4-26", Collections.nCopies(1, "世界知识产权日")); + put("4-8", Collections.nCopies(1, "国际珍稀动物保护日")); + put("4-12", Collections.nCopies(1, "世界航天日")); + put("4-14", Collections.nCopies(1, "黑色情人节")); + put("4-15", Collections.nCopies(1, "全民国家安全教育日")); + put("4-22", Arrays.asList("世界地球日", "列宁诞辰纪念日")); + put("4-23", Collections.nCopies(1, "世界读书日")); + put("4-24", Collections.nCopies(1, "中国航天日")); + put("4-25", Collections.nCopies(1, "儿童预防接种宣传日")); + put("4-26", Arrays.asList("世界知识产权日", "全国疟疾日")); + put("4-28", Collections.nCopies(1, "世界安全生产与健康日")); + put("4-30", Collections.nCopies(1, "全国交通安全反思日")); + put("5-2", Collections.nCopies(1, "世界金枪鱼日")); put("5-3", Collections.nCopies(1, "世界新闻自由日")); put("5-5", Collections.nCopies(1, "马克思诞辰纪念日")); put("5-8", Collections.nCopies(1, "世界红十字日")); put("5-11", Collections.nCopies(1, "世界肥胖日")); + put("5-12", Arrays.asList("全国防灾减灾日", "护士节")); + put("5-14", Collections.nCopies(1, "玫瑰情人节")); + put("5-15", Collections.nCopies(1, "国际家庭日")); + put("5-19", Collections.nCopies(1, "中国旅游日")); + put("5-20", Collections.nCopies(1, "网络情人节")); + put("5-22", Collections.nCopies(1, "国际生物多样性日")); put("5-25", Collections.nCopies(1, "525心理健康节")); put("5-27", Collections.nCopies(1, "上海解放日")); + put("5-29", Collections.nCopies(1, "国际维和人员日")); + put("5-30", Collections.nCopies(1, "中国五卅运动纪念日")); put("5-31", Collections.nCopies(1, "世界无烟日")); + put("6-3", Collections.nCopies(1, "世界自行车日")); put("6-5", Collections.nCopies(1, "世界环境日")); put("6-6", Collections.nCopies(1, "全国爱眼日")); put("6-8", Collections.nCopies(1, "世界海洋日")); put("6-11", Collections.nCopies(1, "中国人口日")); - put("6-14", Collections.nCopies(1, "世界献血日")); + put("6-14", Arrays.asList("世界献血日", "亲亲情人节")); + put("6-17", Collections.nCopies(1, "世界防治荒漠化与干旱日")); + put("6-20", Collections.nCopies(1, "世界难民日")); + put("6-21", Collections.nCopies(1, "国际瑜伽日")); + put("6-25", Collections.nCopies(1, "全国土地日")); + put("6-26", Arrays.asList("国际禁毒日", "联合国宪章日")); put("7-1", Collections.nCopies(1, "香港回归纪念日")); - put("7-7", Collections.nCopies(1, "中国人民抗日战争纪念日")); - put("7-11", Collections.nCopies(1, "世界人口日")); + put("7-6", Arrays.asList("国际接吻日", "朱德逝世纪念日")); + put("7-7", Collections.nCopies(1, "七七事变纪念日")); + put("7-11", Arrays.asList("世界人口日", "中国航海日")); + put("7-14", Collections.nCopies(1, "银色情人节")); + put("7-18", Collections.nCopies(1, "曼德拉国际日")); + put("7-30", Collections.nCopies(1, "国际友谊日")); + put("8-3", Collections.nCopies(1, "男人节")); put("8-5", Collections.nCopies(1, "恩格斯逝世纪念日")); put("8-6", Collections.nCopies(1, "国际电影节")); - put("8-12", Collections.nCopies(1, "国际青年日")); + put("8-8", Collections.nCopies(1, "全民健身日")); + put("8-9", Collections.nCopies(1, "国际土著人日")); + put("8-12", Collections.nCopies(1, "国际青年节")); + put("8-14", Collections.nCopies(1, "绿色情人节")); + put("8-19", Arrays.asList("世界人道主义日", "中国医师节")); put("8-22", Collections.nCopies(1, "邓小平诞辰纪念日")); + put("8-29", Collections.nCopies(1, "全国测绘法宣传日")); put("9-3", Collections.nCopies(1, "中国抗日战争胜利纪念日")); + put("9-5", Collections.nCopies(1, "中华慈善日")); put("9-8", Collections.nCopies(1, "世界扫盲日")); - put("9-9", Collections.nCopies(1, "毛泽东逝世纪念日")); - put("9-14", Collections.nCopies(1, "世界清洁地球日")); + put("9-9", Arrays.asList("毛泽东逝世纪念日", "全国拒绝酒驾日")); + put("9-14", Arrays.asList("世界清洁地球日", "相片情人节")); + put("9-15", Collections.nCopies(1, "国际民主日")); + put("9-16", Collections.nCopies(1, "国际臭氧层保护日")); + put("9-17", Collections.nCopies(1, "世界骑行日")); put("9-18", Collections.nCopies(1, "九一八事变纪念日")); put("9-20", Collections.nCopies(1, "全国爱牙日")); put("9-21", Collections.nCopies(1, "国际和平日")); put("9-27", Collections.nCopies(1, "世界旅游日")); + put("9-30", Collections.nCopies(1, "中国烈士纪念日")); + put("10-1", Collections.nCopies(1, "国际老年人日")); + put("10-2", Collections.nCopies(1, "国际非暴力日")); put("10-4", Collections.nCopies(1, "世界动物日")); + put("10-11", Collections.nCopies(1, "国际女童日")); put("10-10", Collections.nCopies(1, "辛亥革命纪念日")); - put("10-13", Collections.nCopies(1, "中国少年先锋队诞辰日")); + put("10-13", Arrays.asList("国际减轻自然灾害日", "中国少年先锋队诞辰日")); + put("10-14", Collections.nCopies(1, "葡萄酒情人节")); + put("10-16", Collections.nCopies(1, "世界粮食日")); + put("10-17", Collections.nCopies(1, "全国扶贫日")); + put("10-20", Collections.nCopies(1, "世界统计日")); + put("10-24", Arrays.asList("世界发展信息日", "程序员节")); put("10-25", Collections.nCopies(1, "抗美援朝纪念日")); + put("11-5", Collections.nCopies(1, "世界海啸日")); + put("11-8", Collections.nCopies(1, "记者节")); + put("11-9", Collections.nCopies(1, "全国消防日")); + put("11-11", Collections.nCopies(1, "光棍节")); put("11-12", Collections.nCopies(1, "孙中山诞辰纪念日")); + put("11-14", Collections.nCopies(1, "电影情人节")); + put("11-16", Collections.nCopies(1, "国际宽容日")); put("11-17", Collections.nCopies(1, "国际大学生节")); + put("11-19", Collections.nCopies(1, "世界厕所日")); put("11-28", Collections.nCopies(1, "恩格斯诞辰纪念日")); + put("11-29", Collections.nCopies(1, "国际声援巴勒斯坦人民日")); put("12-1", Collections.nCopies(1, "世界艾滋病日")); + put("12-2", Collections.nCopies(1, "全国交通安全日")); + put("12-3", Collections.nCopies(1, "世界残疾人日")); + put("12-4", Collections.nCopies(1, "全国法制宣传日")); + put("12-5", Arrays.asList("世界弱能人士日", "国际志愿人员日")); + put("12-7", Collections.nCopies(1, "国际民航日")); + put("12-9", Arrays.asList("世界足球日", "国际反腐败日")); + put("12-10", Collections.nCopies(1, "世界人权日")); + put("12-11", Collections.nCopies(1, "国际山岳日")); put("12-12", Collections.nCopies(1, "西安事变纪念日")); put("12-13", Collections.nCopies(1, "国家公祭日")); + put("12-14", Collections.nCopies(1, "拥抱情人节")); + put("12-18", Collections.nCopies(1, "国际移徙者日")); put("12-26", Collections.nCopies(1, "毛泽东诞辰纪念日")); } }; diff --git a/src/test/java/test/FotoTest.java b/src/test/java/test/FotoTest.java index 6ef2c67..0c128b4 100644 --- a/src/test/java/test/FotoTest.java +++ b/src/test/java/test/FotoTest.java @@ -5,6 +5,9 @@ import com.nlf.calendar.Lunar; import org.junit.Assert; import org.junit.Test; +import java.util.ArrayList; +import java.util.List; + /** * 佛历测试 * @@ -28,4 +31,12 @@ public class FotoTest { Assert.assertEquals("青龙", foto.getShou()); } + @Test + public void test2() { + Foto foto = Foto.fromLunar(Lunar.fromYmd(2021, 3, 16)); + List expected = new ArrayList(); + expected.add("准提菩萨圣诞"); + Assert.assertEquals(expected, foto.getOtherFestivals()); + } + } diff --git a/src/test/java/test/LunarMonthTest.java b/src/test/java/test/LunarMonthTest.java new file mode 100644 index 0000000..d6b915f --- /dev/null +++ b/src/test/java/test/LunarMonthTest.java @@ -0,0 +1,56 @@ +package test; + +import com.nlf.calendar.LunarMonth; +import org.junit.Assert; +import org.junit.Test; + +/** + * 农历月测试 + * + * @author 6tail + */ +public class LunarMonthTest { + + @Test + public void test(){ + LunarMonth month = LunarMonth.fromYm(2023, 1); + Assert.assertEquals(1, month.getIndex()); + Assert.assertEquals("甲寅", month.getGanZhi()); + } + + @Test + public void test1(){ + LunarMonth month = LunarMonth.fromYm(2023, -2); + Assert.assertEquals(3, month.getIndex()); + Assert.assertEquals("丙辰", month.getGanZhi()); + } + + @Test + public void test2(){ + LunarMonth month = LunarMonth.fromYm(2023, 3); + Assert.assertEquals(4, month.getIndex()); + Assert.assertEquals("丁巳", month.getGanZhi()); + } + + @Test + public void test3(){ + LunarMonth month = LunarMonth.fromYm(2024, 1); + Assert.assertEquals(1, month.getIndex()); + Assert.assertEquals("丙寅", month.getGanZhi()); + } + + @Test + public void test4(){ + LunarMonth month = LunarMonth.fromYm(2023, 12); + Assert.assertEquals(13, month.getIndex()); + Assert.assertEquals("丙寅", month.getGanZhi()); + } + + @Test + public void test5(){ + LunarMonth month = LunarMonth.fromYm(2022, 1); + Assert.assertEquals(1, month.getIndex()); + Assert.assertEquals("壬寅", month.getGanZhi()); + } + +}