Bestimmung der Zeitpunkte von Ereignissen
ulrich
2023-03-23 d20d989f5495492f1258c8313db7c19b429111a3
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
/*
  Zeitrechnung - a class library to determine calendar events
  Copyright (c) 1984-2023 Ulrich Hilger, http://uhilger.de
 
  This program is free software: you can redistribute it and/or modify
  it under the terms of the GNU Affero General Public License as published by
  the Free Software Foundation, either version 3 of the License, or
  (at your option) any later version.
 
  This program is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  GNU Affero General Public License for more details.
 
  You should have received a copy of the GNU Affero General Public License
  along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
package de.uhilger.zeitrechnung.ereignis;
 
import de.uhilger.zeitrechnung.ChinesischesDatum;
import de.uhilger.zeitrechnung.Datum;
import de.uhilger.zeitrechnung.Definition;
import de.uhilger.zeitrechnung.kalender.ChinesischerKalender;
import de.uhilger.zeitrechnung.kalender.ISOKalender;
import java.util.ArrayList;
import java.util.List;
 
/**
 * Ein Ereignis, das durch ein Datum im traditionellen 
 * chinesischen Kalender definiert ist.
 * 
 * <p>Soll nicht ein Ereignis bestimmt sondern in den oder vom chinesischen 
 * Kalender umgerechnet werden, muss die Klasse ChinesischerKalender genutzt 
 * werden.</p> 
 * 
 * <p>
 * Die Ereignis-Definition lautet:<br> 
 * ChinesischesEreignis.getDefinition.setp1(Monat des chinesischen Kalenders);<br>
 * ChinesischesEreignis.getDefinition.setp2(Tag im Monat des chinesischen Kalenders);<br>
 * wobei Monat einer Ganzzahl aus 
 * [ChinesischerKalender.noch-angeben .. ChinesischerKalender.noch-angeben] 
 * entspricht.
 * </p>
 * 
 * @author Ulrich Hilger
 */
public class ChinesischesEreignis extends EreignisBasis {
 
  @Override
  public int getTyp() {
    return EreignisBasis.TYP_CHINESISCH;
  }
 
  @Override
  public List<Datum> getZeitpunkte(long isoJahr) {
    Definition def = getDefinition();
    ChinesischerKalender j = new ChinesischerKalender();
    long tag = j.cDatumZuGenerisch(isoJahr, (int) def.getp1(), (int) def.getp2());
    List daten = new ArrayList();
    daten.add(new ISOKalender().vonTagen(tag));
    return daten;
  }
 
  public List<Datum> getZeitpunkte2(long isoJahr) {
    ISOKalender w = new ISOKalender();
    long start = w.zuTagen(isoJahr, Definition.JANUAR, 1);
    long ende = w.zuTagen(isoJahr, Definition.DEZEMBER, 31);
 
    ChinesischerKalender j = new ChinesischerKalender();
    Definition def = getDefinition();
    List daten = new ArrayList();
    long y = 0;
    long tag = start;
    long ersterJanuar = start;
    while(tag < ende) {
      
      // Neujahr vor dem 1.1. als generisches Datum
      long cNeujahr = j.neujahrAmOderVor(ersterJanuar); 
      
      // Neujahrstag als chinesisches Datum, z.B. 7. Feb 2022 für Neujahr vor 1.1.2023
      ChinesischesDatum cdNeujahr = j.vonTagen(cNeujahr);
      
      // generisches Datum fuer den Tag des Ereignisses bestimmen, 
      // Ereignisse fallen nie auf Schaltmonate, deshalb schaltmonat auf false
      tag = j.zuTagen(cdNeujahr.getZyklus(), (int) cdNeujahr.getJahr(), (int) def.getp1(), 
              false, (int) def.getp2());
      
      // der Liste hinzufügen, wenn das Ereignis ins isoJahr fällt
      if (tag >= start && tag <= ende) {
        Datum d = w.vonTagen(tag);
        daten.add(d);
      }
      
      // für nächstes Jahr wiederholen, bis das Ereignis nicht mehr im isoJahr liegt 
      ++y;
      ersterJanuar = w.zuTagen(isoJahr+y, Definition.JANUAR, 1);
    }
    return daten;
  }
}