Zend_Date-Additional.xml 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 17600 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.date.additional">
  5. <title>Funktionierende Beispiele</title>
  6. <para>
  7. In diesem Kapitel werden wir verschiedene zusätzliche Funkionen beschreiben welche auch
  8. durch <classname>Zend_Date</classname> verfügbar sind. Natürlich haben alle beschriebene
  9. Funktionen auch Beispiele um die Arbeitsweise, und die einfache <acronym>API</acronym> für
  10. die richtige Benutzung von Ihnen, zu zeigen.
  11. </para>
  12. <sect2 id="zend.date.additional.checking">
  13. <title>Prüfen von Daten</title>
  14. <para>
  15. Normalerweise werden die meisten Daten als Zeichenketten übergeben. Aber das Problem
  16. mit Zeichenketten ist das man nicht sicher sein kann ob eine Zeichenkette ein echtes
  17. Datum enthält. Hierfür gibt es in <classname>Zend_Date</classname> eine eigene
  18. statische Funktion um Datums-Zeichenketten zu prüfen.
  19. <classname>Zend_Locale</classname> hat eine eigene Funktion
  20. <methodname>getDate($date, $locale)</methodname> welche ein Datum analysiert und
  21. die gültigen normalisierten Datumsabschnitte zurück gibt. Ein Monatsname wird zum
  22. Beispiel erkannt und anschließend nur die Nummer des Monats zurück gegeben. Aber da
  23. <classname>Zend_Locale</classname> nichts über Daten weiß, da es eine Klasse zum
  24. Normalisieren und Lokalisieren ist, haben wir eine eigene Funktion
  25. <methodname>isDate($date)</methodname> integriert welche das für uns prüft.
  26. </para>
  27. <para>
  28. <methodname>isDate($date, $format, $locale)</methodname> nimmt bis zu drei Parameter
  29. entgegen und benötigt mindestens einen Parameter. Deshalb ist alles was wir für das
  30. Prüfen eines Datums benötigen natürlich das Datum selbst als Zeichenkette. Der zweite
  31. Parameter kann das Format sein, in welchem das Datum erwartet wird. Wenn kein Format
  32. angegeben wurde, wird das Standardformat des verwendeten Gebietsschemas benutzt. Für
  33. Details darüber wie Formate aussehen müssen kann im Kapitel über
  34. <link linkend="zend.date.constants.selfdefinedformats">selbst definierte Formate</link>
  35. nachgeschaut werden.
  36. </para>
  37. <para>
  38. Der dritte Parameter ist auch optional genauso wie der zweite Parameter und kann
  39. verwendet werden um ein Gebietsschema anzugeben. Das gebietsschema wird benötigt um
  40. Monats- und Wochentagsnamen zu normalisieren. Mit dem dritten Parameter sind wir also in
  41. der Lage Daten zu erkennen wie '01.Jänner.2000' oder '01.January.2000' abhängig von dem
  42. angegebenen Gebietsschema.
  43. </para>
  44. <para>
  45. <methodname>isDate()</methodname> prüft natürlich auch ob ein Datum existiert.
  46. <classname>Zend_Date</classname> selbst prüft die Daten nicht. Deshalb ist es möglich
  47. ein Datum wie zum Beispiel '31.Februar.2000' mit <classname>Zend_Date</classname> zu
  48. erstellen weil <classname>Zend_Date</classname> das Datum automatisch korrigiert und
  49. ein gültiges Datum zurück gibt. In unserem Fall den '03.März.2000'. Auf der anderen
  50. Seite führt <methodname>isDate()</methodname> diese Prüfung durch und gibt beim
  51. '31.Februar.2000' <constant>FALSE</constant> zurück, weil sie weiß das dieses Datum
  52. unmöglich ist.
  53. </para>
  54. <example id="zend.date.additional.checking.example-1">
  55. <title>Prüfen von Daten</title>
  56. <programlisting language="php"><![CDATA[
  57. // Prüfen des Datums
  58. $date = '01.03.2000';
  59. if (Zend_Date::isDate($date)) {
  60. print "Zeichenkette $date ist ein Datum";
  61. } else {
  62. print "Zeichenkette $date ist KEIN Datum";
  63. }
  64. // Prüfen eines lokalisierten Datums
  65. $date = '01 February 2000';
  66. if (Zend_Date::isDate($date,'dd MMMM yyyy', 'en')) {
  67. print "Zeichenkette $date ist ein Datum";
  68. } else {
  69. print "Zeichenkette $date ist KEIN Datum";
  70. }
  71. // Prüfen eines unmöglichen Datums
  72. $date = '30 February 2000';
  73. if (Zend_Date::isDate($date,'dd MMMM yyyy', 'en')) {
  74. print "Zeichenkette $date ist ein Datum";
  75. } else {
  76. print "Zeichenkette $date ist KEIN Datum";
  77. }
  78. ]]></programlisting>
  79. </example>
  80. </sect2>
  81. <sect2 id="zend.date.additional.sunrise-sunset">
  82. <title>Sonnenaufgang und Sonnenuntergang</title>
  83. <para>
  84. <classname>Zend_Date</classname> beinhaltet auch Funktionen um Informationen von der
  85. Sonne zu erhalten. Oft ist es notwendig die Zeit für Sonnenaugang oder Sonnenuntergang
  86. für einen bestimmten Tag zu erhalten. Das ist mit <classname>Zend_Date</classname> sehr
  87. einfach weil nur der gewünschte Tag angegeben werden muß, und zusätzlich die Ortsangabe
  88. für den Sonnenaufgang oder Sonnenuntergang berechnet werden soll.
  89. </para>
  90. <para>
  91. Da die meisten Personen die genaue Ortsangabe Ihrer Stadt nicht kennen haben wir auch
  92. eine Helferklasse spendiert die für etwa 250 Haupt- und Großstädte der ganzen Welt die
  93. Daten der Ortsangaben bereithält. Die meisten Personen können Städte in Ihrer näheren
  94. Umgebung benutzen, da die Differenz für Ortsangaben welche nahe beineinander liegen nur
  95. in Sekunden gemessen werden kann.
  96. </para>
  97. <para>
  98. Für die Erstellung einer Auswahlbox und der Auswahl einer speziellen Stadt kann die
  99. Funktion <classname>Zend_Date_Cities::getCityList</classname> benutzt werden. Sie gibt
  100. die Namen aller verfügbaren vordefinierten Städte der Helferklasse zurück.
  101. </para>
  102. <example id="zend.date.additional.sunrise-sunset.example-1">
  103. <title>Alle verfügbaren Städte ausgeben</title>
  104. <programlisting language="php"><![CDATA[
  105. // Ausgabe der kompletten Liste aller verfügbaren Städte
  106. print_r (Zend_Date_Cities::getCityList());
  107. ]]></programlisting>
  108. </example>
  109. <para>
  110. Die Ortsangabe selbst erhält man mit der Funktion
  111. <methodname>Zend_Date_Cities::City()</methodname>. Sie akzeptiert den Namen einer Stadt
  112. wie durch die Funktion <methodname>Zend_Date_Cities::getCityList()</methodname>
  113. angegeben und optional als zweiten Parameter den zu setzenden Horizont.
  114. </para>
  115. <para>
  116. Es gibt 4 vordefinierte Horizonte welche mit einer Ortsangabe benutzt werden können um
  117. den genauen Zeitpunkt von Sonnenauf- und -untergang zu erhalten. Der
  118. '<code>horizon</code>' Parameter ist in allen Funktionen immer optional. Wenn er nicht
  119. gesetzt wird, wird der '<code>effective</code>' Horizont benutzt.
  120. </para>
  121. <table id="zend.date.additional.sunrise-sunset.table">
  122. <title>Arten von unterstützten Horizonten für Sonnenauf- und -untergang</title>
  123. <tgroup cols="3">
  124. <thead>
  125. <row>
  126. <entry>Horizont</entry>
  127. <entry>Beschreibung</entry>
  128. <entry>Verwendung</entry>
  129. </row>
  130. </thead>
  131. <tbody>
  132. <row>
  133. <entry>effective</entry>
  134. <entry>Standard Horizont</entry>
  135. <entry>
  136. Nimmt an das die Welt ein Ball ist. Dieser Horizont wird immer benutzt
  137. wenn keiner definiert wurde.
  138. </entry>
  139. </row>
  140. <row>
  141. <entry>civil</entry>
  142. <entry>Üblicher Horizont</entry>
  143. <entry>Oft in den üblichen Medien wie Fernsehen und Radio benutzt.</entry>
  144. </row>
  145. <row>
  146. <entry>nautic</entry>
  147. <entry>Nautischer Horizont</entry>
  148. <entry>Oft in der Navigation zu See benutzt.</entry>
  149. </row>
  150. <row>
  151. <entry>astronomic</entry>
  152. <entry>Astronomischer Horizont</entry>
  153. <entry>Oft bei der Berechnung mit Sternen benutzt</entry>
  154. </row>
  155. </tbody>
  156. </tgroup>
  157. </table>
  158. <para>
  159. Natürlich kann auch eine selbst-definierte Ortsangabe für die Berechnung benutzt werden.
  160. Hierzu ist eine '<code>latitude</code>' und eine '<code>longitude</code>' anzugeben und
  161. optional der '<code>horizon</code>'.
  162. </para>
  163. <example id="zend.date.additional.sunrise-sunset.example-2">
  164. <title>Die Ortsangabe für eine Stadt auslesen</title>
  165. <programlisting language="php"><![CDATA[
  166. // Die Ortsangabe für eine bestimmte Stadt auslesen
  167. // Benutzt den effektiven Horizont da kein Horizont angegeben wurde
  168. print_r (Zend_Date_Cities::City('Vienna'));
  169. // Benutzt den nautischen Horizont
  170. print_r (Zend_Date_Cities::City('Vienna', 'nautic'));
  171. // Selbstdefinition einer Ortsangabe
  172. $mylocation = array('latitude' => 41.5, 'longitude' => 13.2446);
  173. ]]></programlisting>
  174. </example>
  175. <para>
  176. Da nun alle benötigten Daten angegeben werde können ist der nächste Schritt die
  177. Erstellung eines <classname>Zend_Date</classname> Objekts mit dem Tag für welchen
  178. Sonnenauf- oder -untergang berechnet werden sollen. Für die Berechnung stehen 3
  179. Funktionen bereit. Die Berechnung des Sonnenaufganges ist mit
  180. '<methodname>getSunset()</methodname>', des Sonnenuntergangs mit
  181. '<methodname>getSunrise()</methodname>' und alle möglichen Informationen welche die
  182. Sonne betreffen mit '<methodname>getSunInfo()</methodname>' möglich. Nach der
  183. Berechnung wird das <classname>Zend_Date</classname> Objekt mit der berechneten Zeit
  184. zurückgegeben.
  185. </para>
  186. <example id="zend.date.additional.sunrise-sunset.example-3">
  187. <title>Berechnung von Sonneninformationen</title>
  188. <programlisting language="php"><![CDATA[
  189. // Die Ortsangabe einer bestimmten Stadt auslesen
  190. $city = Zend_Date_Cities::City('Vienna');
  191. // Ein Datumsobjekt erstellen für den Tag
  192. // für den die Sonne berechnet werden soll
  193. $date = new Zend_Date('10.03.2007', Zend_Date::ISO_8601, 'de');
  194. // Sonnenuntergang berechnen
  195. $sunset = $date->getSunset($city);
  196. print $sunset->get(Zend_Date::ISO_8601);
  197. // Alle Sonneninformationen berechnen
  198. $info = $date->getSunInfo($city);
  199. foreach ($info as $sun) {
  200. print "\n" . $sun->get(Zend_Date::ISO_8601);
  201. }
  202. ]]></programlisting>
  203. </example>
  204. </sect2>
  205. <sect2 id="zend.date.additional.timezones">
  206. <title>Zeitzonen</title>
  207. <para>
  208. Zeitzonen sind genauso wichtig wie die Datumsangaben selbst. Es gibt einige Zeitzonen
  209. abhängig davon wo auf der Welt der Benutzer lebt. Deshalb bedeutet das Arbeiten mit
  210. Daten auch immer das eine gültige Zeitzone gesetzt ist. Das klingt eventuell
  211. kompliziert, ist aber viel einfacher als erwartet. Wie schon im ersten Kapitel von
  212. <classname>Zend_Date</classname> erwähnt muß immer eine Standardzeitzone ersetzt werden.
  213. Entweder durch <filename>php.ini</filename> oder durch Definition in der Bootstrap
  214. Datei.
  215. </para>
  216. <para>
  217. Ein <classname>Zend_Date</classname> Objekt speichert natürlich die aktuelle Zeitzone.
  218. Selbst wenn die Zeitzone nach der Erstellung des Objektes geändert wird, merkt sich das
  219. Objekt die originale Zeitzone und arbeitet mit Ihr. Es ist also nicht notwendig die
  220. Zeitzone im Code mithilfe von <acronym>PHP</acronym> Funktionen zu ändern.
  221. <classname>Zend_Date</classname> hat zwei eingebaute Funktionen die es ermöglichen damit
  222. zu Arbeiten.
  223. </para>
  224. <para>
  225. <methodname>getTimezone()</methodname> gibt die aktuell gesetzte Zeitzone des
  226. <classname>Zend_Date</classname> Objektes zurück. Man sollte in Erinnerung behalten das
  227. <classname>Zend_Date</classname> nicht mit den <acronym>PHP</acronym> Internas gekoppelt
  228. ist. Deshalb ist die zurückgegebene Zeitzone nicht die des <acronym>PHP</acronym>
  229. Skripts sondern jene des Objektes. <methodname>setTimezone($zone)</methodname> ist die
  230. zweite Funktion und ermöglicht es eine neue Zeitzone für
  231. <classname>Zend_Date</classname> zu setzen. Eine angegebene Zeitzone wird immer geprüft.
  232. Wenn diese nicht existiert wird eine Ausnahme geworfen. Zusätzlich kann die Zeitzone des
  233. aktuellen Skripts oder des Systems für das Datumsobjekt gesetzt werden indem
  234. <methodname>setTimezone()</methodname> ohne den Parameter zone aufgerufen wird. Das wird
  235. auch automatisch gemacht wenn das Datumsobjekt erstellt wird.
  236. </para>
  237. <example id="zend.date.additional.timezones.example-1">
  238. <title>Arbeiten mit Zeitzonen</title>
  239. <programlisting language="php"><![CDATA[
  240. // Setzen einer Standardzeitzone... das muß in der Bootstrap Datei
  241. // oder php.ini gemacht werden. Wir setzen Sie hier nur der Vollständigkeit
  242. // halber um ein komplettes Beispiel zu erhalten.
  243. date_default_timezone_set('Europe/Vienna');
  244. // Erstellen des Datumsobjektes
  245. $date = new Zend_Date('10.03.2007', Zend_Date::DATES, 'de');
  246. // Ausgabe des Datumsobjektes
  247. print $date->getIso();
  248. // Welche Zeitzone ist gesetzt ?
  249. print $date->getTimezone();
  250. // Setzen einer anderen Zeitzone
  251. $date->setTimezone('America/Chicago');
  252. // Welche Zeitzone ist jetzt gesetzt ?
  253. print $date->getTimezone();
  254. // Ausgabe des geänderten Datumsobjektes
  255. print $date->getIso();
  256. ]]></programlisting>
  257. </example>
  258. <para>
  259. <classname>Zend_Date</classname> nimmt immer die aktuelle Zeitzone für das Erstellen
  260. eines Objektes wie in den ersten Zeilen des Beispiels gezeigt. Das Ändern der Zeitzone
  261. für ein erstelltes Objekt hat einen Effekt auf das Datum selbst. Daten sind immer
  262. relativ zu einer Zeitzone. Das Ändern der Zeitzone für ein
  263. <classname>Zend_Date</classname> Objekt ändert nicht die Zeit des
  264. <classname>Zend_Date</classname> Objektes selbst. Man muß sich in Erinnerung halten das
  265. Daten intern immer als Zeitpunkte und in der <acronym>GMT</acronym> gespeichert werden.
  266. Eine Zeitzone bedeutet also wieviele Stunden subtrahiert oder addiert werden müssen um
  267. die aktuelle globale Zeit für die eigene Zeitzone und Region er erhalten.
  268. </para>
  269. <para>
  270. Das koppeln der Zeitzone innerhalb von <classname>Zend_Date</classname> hat einen
  271. anderen positiven Nebeneffekt. Es ist möglich verschiedene Daten mit verschiedenen
  272. Zeitzonen zu haben.
  273. </para>
  274. <example id="zend.date.additional.timezones.example-2">
  275. <title>Mehrere Zeitzonen</title>
  276. <programlisting language="php"><![CDATA[
  277. // Setzen einer Standardzeitzone... das muß in der Bootstrap Datei oder
  278. // php.ini gemacht werden. Wir setzen Sie hier nur der Vollständigkeit
  279. // halber um ein komplettes Beispiel zu erhalten.
  280. date_default_timezone_set('Europe/Vienna');
  281. // Erstellen des Datumsobjektes
  282. $date = new Zend_Date('10.03.2007 00:00:00', Zend_Date::ISO_8601, 'de');
  283. // Ausgabe des Datumsobjektes
  284. print $date->getIso();
  285. // Das Datum bleibt unverändert selbst nach einer Änderung der Zeitzone
  286. date_default_timezone_set('America/Chicago');
  287. print $date->getIso();
  288. $otherdate = clone $date;
  289. $otherdate->setTimezone('Brazil/Acre');
  290. // Ausgabe des Datumsobjektes
  291. print $otherdate->getIso();
  292. // Setzen der aktuellen Zeitzone des Systems für das Objekt
  293. $lastdate = clone $date;
  294. $lastdate->setTimezone();
  295. // Ausgabe des Datumsobjektes
  296. print $lastdate->getIso();
  297. ]]></programlisting>
  298. </example>
  299. </sect2>
  300. </sect1>