diff --git a/README.md b/README.md index 58b4d44..4cb20c6 100644 --- a/README.md +++ b/README.md @@ -16,7 +16,7 @@ lunar是一款无第三方依赖的公历(阳历)、农历(阴历、老黄历) cn.6tail lunar - 1.3.10 + 1.3.11 ``` diff --git a/README_EN.md b/README_EN.md index e8660f6..20b47f4 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.10 + 1.3.11 ``` diff --git a/pom.xml b/pom.xml index 2ed65a8..5aa7e52 100644 --- a/pom.xml +++ b/pom.xml @@ -7,7 +7,7 @@ cn.6tail lunar jar - 1.3.10 + 1.3.11 ${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 17a92b6..c9c91a2 100644 --- a/src/main/java/com/nlf/calendar/EightChar.java +++ b/src/main/java/com/nlf/calendar/EightChar.java @@ -501,27 +501,27 @@ public String getTaiXiNaYin() { public String getMingGong() { int monthZhiIndex = 0; int timeZhiIndex = 0; + String monthZhi = getMonthZhi(); + String timeZhi = getTimeZhi(); for (int i = 0, j = MONTH_ZHI.length; i < j; i++) { - String zhi = MONTH_ZHI[i]; - if (lunar.getMonthZhiExact().equals(zhi)) { + if (monthZhi.equals(MONTH_ZHI[i])) { monthZhiIndex = i; + break; } - if (lunar.getTimeZhi().equals(zhi)) { + } + for (int i = 0, j = MONTH_ZHI.length; i < j; i++) { + if (timeZhi.equals(MONTH_ZHI[i])) { timeZhiIndex = i; + break; } } - int zhiIndex = 26 - (monthZhiIndex + timeZhiIndex); - if (zhiIndex > 12) { - zhiIndex -= 12; - } - int jiaZiIndex = LunarUtil.getJiaZiIndex(lunar.getMonthInGanZhiExact()) - (monthZhiIndex - zhiIndex); - if (jiaZiIndex >= 60) { - jiaZiIndex -= 60; - } - if (jiaZiIndex < 0) { - jiaZiIndex += 60; + int offset = monthZhiIndex + timeZhiIndex; + offset = (offset >= 14 ? 26 : 14) - offset; + int ganIndex = (lunar.getYearGanIndexExact() + 1) * 2 + offset; + while (ganIndex > 10) { + ganIndex -= 10; } - return LunarUtil.JIA_ZI[jiaZiIndex]; + return LunarUtil.GAN[ganIndex] + MONTH_ZHI[offset]; } /** @@ -541,27 +541,29 @@ public String getMingGongNaYin() { public String getShenGong() { int monthZhiIndex = 0; int timeZhiIndex = 0; + String monthZhi = getMonthZhi(); + String timeZhi = getTimeZhi(); for (int i = 0, j = MONTH_ZHI.length; i < j; i++) { - String zhi = MONTH_ZHI[i]; - if (lunar.getMonthZhiExact().equals(zhi)) { + if (monthZhi.equals(MONTH_ZHI[i])) { monthZhiIndex = i; + break; } - if (lunar.getTimeZhi().equals(zhi)) { + } + for (int i = 0, j = MONTH_ZHI.length; i < j; i++) { + if (timeZhi.equals(LunarUtil.ZHI[i])) { timeZhiIndex = i; + break; } } - int zhiIndex = 2 + monthZhiIndex + timeZhiIndex; - if (zhiIndex > 12) { - zhiIndex -= 12; + int offset = monthZhiIndex + timeZhiIndex; + while (offset > 12) { + offset -= 12; } - int jiaZiIndex = LunarUtil.getJiaZiIndex(lunar.getMonthInGanZhiExact()) - (monthZhiIndex - zhiIndex); - if (jiaZiIndex >= 60) { - jiaZiIndex -= 60; - } - if (jiaZiIndex < 0) { - jiaZiIndex += 60; + int ganIndex = (lunar.getYearGanIndexExact() + 1) * 2 + (offset % 12); + while (ganIndex > 10) { + ganIndex -= 10; } - return LunarUtil.JIA_ZI[jiaZiIndex]; + return LunarUtil.GAN[ganIndex] + MONTH_ZHI[offset]; } /** diff --git a/src/test/java/test/BaZiTest.java b/src/test/java/test/BaZiTest.java index 6a992ac..6bdd7bb 100644 --- a/src/test/java/test/BaZiTest.java +++ b/src/test/java/test/BaZiTest.java @@ -234,7 +234,7 @@ public void testShenGong() { @Test public void testShenGong1() { Lunar lunar = new Solar(1994, 12, 6, 2, 0, 0).getLunar(); - Assert.assertEquals("身宫", "丁丑", lunar.getEightChar().getShenGong()); + Assert.assertEquals("身宫", "乙丑", lunar.getEightChar().getShenGong()); } @Test @@ -412,7 +412,7 @@ public void test17() { Solar solar = new Solar(1986, 5, 29, 13, 37, 0); Lunar lunar = solar.getLunar(); EightChar eightChar = lunar.getEightChar(); - Assert.assertEquals("辛丑", eightChar.getShenGong()); + Assert.assertEquals("己丑", eightChar.getShenGong()); } @Test @@ -437,4 +437,60 @@ public void test19() { Assert.assertEquals(expected, actual); } + @Test + public void test20() { + List l = Solar.fromBaZi("乙未","己卯","丁丑","甲辰"); + List actual = new ArrayList(); + for (Solar solar : l) { + actual.add(solar.toYmdHms()); + } + + List expected = new ArrayList(); + expected.add("1955-03-17 08:00:00"); + Assert.assertEquals(expected, actual); + } + + @Test + public void test21() { + Lunar lunar = Solar.fromYmdHms(2024, 1, 29, 9, 30, 0).getLunar(); + EightChar eightChar = lunar.getEightChar(); + Assert.assertEquals("命宫", "癸亥", eightChar.getMingGong()); + Assert.assertEquals("身宫", "己未", eightChar.getShenGong()); + } + + @Test + public void test22() { + Assert.assertEquals("身宫", "丙寅", Solar.fromYmdHms(1990, 1, 27, 0, 0, 0).getLunar().getEightChar().getShenGong()); + } + + @Test + public void test23() { + Assert.assertEquals("甲戌", Solar.fromYmdHms(2019, 3, 7, 8, 0, 0).getLunar().getEightChar().getMingGong()); + } + + @Test + public void test24() { + Assert.assertEquals("丁丑", Solar.fromYmdHms(2019, 3, 27, 2, 0, 0).getLunar().getEightChar().getMingGong()); + } + + @Test + public void test25() { + Assert.assertEquals("丙寅", Lunar.fromYmdHms(1994, 5, 20, 18, 0 ,0).getEightChar().getMingGong()); + } + + @Test + public void test26() { + Lunar lunar = Solar.fromYmdHms(1986, 2, 16, 8, 0, 0).getLunar(); + EightChar eightChar = lunar.getEightChar(); + Assert.assertEquals("命宫", "己亥", eightChar.getMingGong()); + Assert.assertEquals("身宫", "乙未", eightChar.getShenGong()); + } + + @Test + public void test27() { + Lunar lunar = Solar.fromYmdHms(1972, 11, 27, 10, 0, 0).getLunar(); + EightChar eightChar = lunar.getEightChar(); + Assert.assertEquals("身宫", "乙巳", eightChar.getShenGong()); + } + }