1
0
mirror of synced 2025-12-10 23:48:00 +08:00

v1.2.23 新增525心理健康节;修复出现多个全国中小学生安全教育日的问题;新增胎息。

This commit is contained in:
6tail
2022-05-19 20:48:42 +08:00
parent 3415fc04a4
commit 5d589eb957
10 changed files with 65 additions and 38 deletions

View File

@@ -16,7 +16,7 @@ lunar是一款无第三方依赖的公历(阳历)、农历(阴历、老黄历)
<dependency> <dependency>
<groupId>cn.6tail</groupId> <groupId>cn.6tail</groupId>
<artifactId>lunar</artifactId> <artifactId>lunar</artifactId>
<version>1.2.22</version> <version>1.2.23</version>
</dependency> </dependency>
``` ```

View File

@@ -12,7 +12,7 @@ lunar is a calendar library for Solar and Chinese Lunar.
<dependency> <dependency>
<groupId>cn.6tail</groupId> <groupId>cn.6tail</groupId>
<artifactId>lunar</artifactId> <artifactId>lunar</artifactId>
<version>1.2.22</version> <version>1.2.23</version>
</dependency> </dependency>
``` ```

View File

@@ -7,7 +7,7 @@
<groupId>cn.6tail</groupId> <groupId>cn.6tail</groupId>
<artifactId>lunar</artifactId> <artifactId>lunar</artifactId>
<packaging>jar</packaging> <packaging>jar</packaging>
<version>1.2.22</version> <version>1.2.23</version>
<name>${project.groupId}:${project.artifactId}</name> <name>${project.groupId}:${project.artifactId}</name>
<url>https://github.com/6tail/lunar-java</url> <url>https://github.com/6tail/lunar-java</url>
<description>a calendar library for Solar and Chinese Lunar</description> <description>a calendar library for Solar and Chinese Lunar</description>

View File

@@ -474,6 +474,26 @@ public class EightChar {
return LunarUtil.NAYIN.get(getTaiYuan()); return LunarUtil.NAYIN.get(getTaiYuan());
} }
/**
* 获取胎息
*
* @return 胎息
*/
public String getTaiXi() {
int ganIndex = (2 == sect) ? lunar.getDayGanIndexExact2() : lunar.getDayGanIndexExact();
int zhiIndex = (2 == sect) ? lunar.getDayZhiIndexExact2() : lunar.getDayZhiIndexExact();
return LunarUtil.HE_GAN_5[ganIndex] + LunarUtil.HE_ZHI_6[zhiIndex];
}
/**
* 获取胎息纳音
*
* @return 纳音
*/
public String getTaiXiNaYin() {
return LunarUtil.NAYIN.get(getTaiXi());
}
/** /**
* 获取命宫 * 获取命宫
* *
@@ -531,7 +551,10 @@ public class EightChar {
timeZhiIndex = i; timeZhiIndex = i;
} }
} }
int zhiIndex = (2 + (monthZhiIndex + timeZhiIndex)) % 12; int zhiIndex = 2 + monthZhiIndex + timeZhiIndex;
if (zhiIndex > 12) {
zhiIndex -= 12;
}
int jiaZiIndex = LunarUtil.getJiaZiIndex(lunar.getMonthInGanZhiExact()) - (monthZhiIndex - zhiIndex); int jiaZiIndex = LunarUtil.getJiaZiIndex(lunar.getMonthInGanZhiExact()) - (monthZhiIndex - zhiIndex);
if (jiaZiIndex >= 60) { if (jiaZiIndex >= 60) {
jiaZiIndex -= 60; jiaZiIndex -= 60;

View File

@@ -1904,7 +1904,7 @@ public class Lunar {
* @return 日冲,如申 * @return 日冲,如申
*/ */
public String getDayChong() { public String getDayChong() {
return LunarUtil.CHONG[dayZhiIndex + 1]; return LunarUtil.CHONG[dayZhiIndex];
} }
/** /**
@@ -1946,7 +1946,7 @@ public class Lunar {
* @return 无情之克的日冲天干,如甲 * @return 无情之克的日冲天干,如甲
*/ */
public String getDayChongGan() { public String getDayChongGan() {
return LunarUtil.CHONG_GAN[dayGanIndex + 1]; return LunarUtil.CHONG_GAN[dayGanIndex];
} }
/** /**
@@ -1955,7 +1955,7 @@ public class Lunar {
* @return 有情之克的日冲天干,如甲 * @return 有情之克的日冲天干,如甲
*/ */
public String getDayChongGanTie() { public String getDayChongGanTie() {
return LunarUtil.CHONG_GAN_TIE[dayGanIndex + 1]; return LunarUtil.CHONG_GAN_TIE[dayGanIndex];
} }
/** /**
@@ -1964,7 +1964,7 @@ public class Lunar {
* @return 时冲,如申 * @return 时冲,如申
*/ */
public String getTimeChong() { public String getTimeChong() {
return LunarUtil.CHONG[timeZhiIndex + 1]; return LunarUtil.CHONG[timeZhiIndex];
} }
/** /**
@@ -2006,7 +2006,7 @@ public class Lunar {
* @return 无情之克的时冲天干,如甲 * @return 无情之克的时冲天干,如甲
*/ */
public String getTimeChongGan() { public String getTimeChongGan() {
return LunarUtil.CHONG_GAN[timeGanIndex + 1]; return LunarUtil.CHONG_GAN[timeGanIndex];
} }
/** /**
@@ -2015,7 +2015,7 @@ public class Lunar {
* @return 有情之克的时冲天干,如甲 * @return 有情之克的时冲天干,如甲
*/ */
public String getTimeChongGanTie() { public String getTimeChongGanTie() {
return LunarUtil.CHONG_GAN_TIE[timeGanIndex + 1]; return LunarUtil.CHONG_GAN_TIE[timeGanIndex];
} }
/** /**

View File

@@ -235,7 +235,7 @@ public class LunarTime {
* @return 时冲,如申 * @return 时冲,如申
*/ */
public String getChong() { public String getChong() {
return LunarUtil.CHONG[zhiIndex + 1]; return LunarUtil.CHONG[zhiIndex];
} }
/** /**
@@ -277,7 +277,7 @@ public class LunarTime {
* @return 无情之克的时冲天干,如甲 * @return 无情之克的时冲天干,如甲
*/ */
public String getChongGan() { public String getChongGan() {
return LunarUtil.CHONG_GAN[ganIndex + 1]; return LunarUtil.CHONG_GAN[ganIndex];
} }
/** /**
@@ -286,7 +286,7 @@ public class LunarTime {
* @return 有情之克的时冲天干,如甲 * @return 有情之克的时冲天干,如甲
*/ */
public String getChongGanTie() { public String getChongGanTie() {
return LunarUtil.CHONG_GAN_TIE[ganIndex + 1]; return LunarUtil.CHONG_GAN_TIE[ganIndex];
} }
/** /**

View File

@@ -386,7 +386,7 @@ public class Solar {
if (null != f) { if (null != f) {
l.add(f); l.add(f);
} }
if (day + 7 >= SolarUtil.getDaysOfMonth(year, month)) { if (day + 7 > SolarUtil.getDaysOfMonth(year, month)) {
f = SolarUtil.WEEK_FESTIVAL.get(month + "-0-" + week); f = SolarUtil.WEEK_FESTIVAL.get(month + "-0-" + week);
if (null != f) { if (null != f) {
l.add(f); l.add(f);

View File

@@ -351,32 +351,17 @@ public class LunarUtil{
} }
}; };
/** 地支相冲(子午相冲,丑未相冲,寅申相冲,辰戌相冲,卯酉相冲,巳亥相冲),由于地支对应十二生肖,也就对应了生肖相冲 */ /** 地支相冲(子午相冲,丑未相冲,寅申相冲,辰戌相冲,卯酉相冲,巳亥相冲),由于地支对应十二生肖,也就对应了生肖相冲 */
public static final String[] CHONG = {"","","","","","","","","","","","",""}; public static final String[] CHONG = {"","","","","","","","","","","",""};
/** 天干相冲之无情之克(阳克阳,阴克阴) */ /** 天干相冲之无情之克(阳克阳,阴克阴) */
public static final String[] CHONG_GAN = {"","","","","","","","","","",""}; public static final String[] CHONG_GAN = {"","","","","","","","","",""};
/** 天干四冲无情之克中克得最严重的4个 */
public static final Map<String,String> CHONG_GAN_BAD = new HashMap<String,String>(){
private static final long serialVersionUID = -1;
{
put("","");
put("","");
put("","");
put("","");
}
};
/** 天干相冲之有情之克(阳克阴,阴克阳) */ /** 天干相冲之有情之克(阳克阴,阴克阳) */
public static final String[] CHONG_GAN_TIE = {"","","","","","","","","","",""}; public static final String[] CHONG_GAN_TIE = {"","","","","","","","","",""};
/** 天干五合有情之克中最有情的5个) */ /** 天干四冲无情之克中克得最严重的4个) */
public static final Map<String,String> CHONG_GAN_TIE_GOOD = new HashMap<String,String>(){ public static final String[] CHONG_GAN_4 = {"","","","","","","","","",""};
private static final long serialVersionUID = -1; /** 天干五合有情之克中最有情的5个甲己合乙庚合丙辛合丁壬合戊癸合 */
{ public static final String[] HE_GAN_5 = {"","","","","","","","","",""};
put("",""); /** 地支六合(子丑合,寅亥合,卯戌合,辰酉合,巳申合,午未合) */
put("",""); public static final String[] HE_ZHI_6 = {"","","","","","","","","","","",""};
put("","");
put("","");
put("","");
}
};
/** 煞(逢巳日、酉日、丑日必煞东;亥日、卯日、未日必煞西;申日、子日、辰日必煞南;寅日、午日、戌日必煞北) */ /** 煞(逢巳日、酉日、丑日必煞东;亥日、卯日、未日必煞西;申日、子日、辰日必煞南;寅日、午日、戌日必煞北) */
public static final Map<String,String> SHA = new HashMap<String,String>(){ public static final Map<String,String> SHA = new HashMap<String,String>(){
private static final long serialVersionUID = -1; private static final long serialVersionUID = -1;

View File

@@ -100,6 +100,7 @@ public class SolarUtil {
put("5-5", Collections.nCopies(1, "马克思诞辰纪念日")); put("5-5", Collections.nCopies(1, "马克思诞辰纪念日"));
put("5-8", Collections.nCopies(1, "世界红十字日")); put("5-8", Collections.nCopies(1, "世界红十字日"));
put("5-11", Collections.nCopies(1, "世界肥胖日")); put("5-11", Collections.nCopies(1, "世界肥胖日"));
put("5-25", Collections.nCopies(1, "525心理健康节"));
put("5-27", Collections.nCopies(1, "上海解放日")); put("5-27", Collections.nCopies(1, "上海解放日"));
put("5-31", Collections.nCopies(1, "世界无烟日")); put("5-31", Collections.nCopies(1, "世界无烟日"));
put("6-5", Collections.nCopies(1, "世界环境日")); put("6-5", Collections.nCopies(1, "世界环境日"));

View File

@@ -230,6 +230,24 @@ public class BaZiTest {
Assert.assertEquals("身宫", "壬午", lunar.getEightChar().getShenGong()); Assert.assertEquals("身宫", "壬午", lunar.getEightChar().getShenGong());
} }
@Test
public void testShenGong1() {
Lunar lunar = new Solar(1994, 12, 6, 2, 0, 0).getLunar();
Assert.assertEquals("身宫", "丁丑", lunar.getEightChar().getShenGong());
}
@Test
public void testShenGong2() {
Lunar lunar = new Solar(1990, 12, 11, 6, 0, 0).getLunar();
Assert.assertEquals("身宫", "庚辰", lunar.getEightChar().getShenGong());
}
@Test
public void testShenGong3() {
Lunar lunar = new Solar(1993, 5, 23, 4, 0, 0).getLunar();
Assert.assertEquals("身宫", "庚申", lunar.getEightChar().getShenGong());
}
@Test @Test
public void testBaZi2Solar() { public void testBaZi2Solar() {
Solar solar = Solar.fromYmdHms(2027,1,27,12,0,0); Solar solar = Solar.fromYmdHms(2027,1,27,12,0,0);