Bestimmung der Zeitpunkte von Ereignissen
ulrich
2023-03-18 66d68b6462bfd492db15535559c0c25b0f16eebc
commit | author | age
66d68b 1 /*
U 2   Zeitrechnung - a class library to determine calendar events
3   Copyright (c) 1984-2023 Ulrich Hilger, http://uhilger.de
4
5   This program is free software: you can redistribute it and/or modify
6   it under the terms of the GNU Affero General Public License as published by
7   the Free Software Foundation, either version 3 of the License, or
8   (at your option) any later version.
9
10   This program is distributed in the hope that it will be useful,
11   but WITHOUT ANY WARRANTY; without even the implied warranty of
12   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13   GNU Affero General Public License for more details.
14
15   You should have received a copy of the GNU Affero General Public License
16   along with this program.  If not, see <http://www.gnu.org/licenses/>.
17  */
18 package de.uhilger.zeitrechnung.ereignis;
19
20 import de.uhilger.zeitrechnung.Datum;
21 import de.uhilger.zeitrechnung.Definition;
22 import de.uhilger.zeitrechnung.kalender.ISOKalender;
23 import de.uhilger.zeitrechnung.kalender.MuslimischerKalender;
24 import java.util.ArrayList;
25 import java.util.List;
26
27 /**
28  * Bestimmung der Zeitpunkte von Ereignissen im muslimischen Kalendersystem
29  * 
30  * 
31  * <p>
32  * Die Ereignis-Definition lautet:<br> 
33  * MuslimischesEreignis.getDefinition.setp1(Monat des muslimischen Kalenders);<br>
34  * MuslimischesEreignis.getDefinition.setp2(Tag im Monat des muslimischen Kalenders);<br>
35  *  
36  * @author Ulrich Hilger
37  */
38 public class MuslimischesEreignis extends EreignisBasis {
39
40   /**
41    * Den Typ des Ereignisses ermitteln
42    * 
43    * @return Ereignis.TYP_MUSLIMISCH 
44    */
45   @Override
46   public int getTyp() {
47     return TYP_MUSLIMISCH;
48   }
49
50   /**
51    * Die Tage eines Jahres im gregorianischen Kalendersystem 
52    * ermitteln, an denen das Ereignis stattfindet.
53    * 
54    * @param isoJahr das Jahr im gregorianischen Kalender, 
55    * fuer das ermittelt werden soll, an welchen Tagen das Ereignis stattfindet
56    * @return die Liste aus Datum-Objekten, die die Tage im gregorianischen 
57    * Kalender bezeichnet, an denen das Ereignis stattfinden
58    */
59   @Override
60   public List<Datum> getZeitpunkte(long isoJahr) {
61     ISOKalender w = new ISOKalender();
62     long start = w.zuTagen(isoJahr, Definition.JANUAR, 1);
63     long end = w.zuTagen(isoJahr, Definition.DEZEMBER, 31);
64
65     MuslimischerKalender m = new MuslimischerKalender();
66     Datum mStart = m.vonTagen(start);
67     long mStartJahr = mStart.getJahr();
68     Datum mEnd = m.vonTagen(end);
69     long mEndJahr = mEnd.getJahr();
70     long anzahlJahre = (mEndJahr - mStartJahr) + (long) 1;
71
72     Definition def = getDefinition();
73     List daten = new ArrayList();
74     for (long y = 0; y < anzahlJahre; y++) {
75       long tage = m.zuTagen(mStartJahr + y, (int) def.getp1(), (int) def.getp2());
76       if (tage >= start && tage <= end) {
77         Datum d = w.vonTagen(tage);
78         daten.add(d);
79       }
80     }
81     return daten;
82   }
83   
84 }