Calcul et affiche le lever et coucher du soleil

  Information

Avec ce code vous pourrez savoir quand le soleil se couche et quand il se lève de n'importe quel ville du monde.
Pour cela vous devrez lancer le script en paramétrant l'url pour fournir la ville, la latitude et la longitude. En argument (après l'extension du fichier .php) vous ajoutez les arguments comme ceci:

?ville=NomVille&la=Latitude&Lo=Longitude.

Avec Latitude en degrés décimaux (Nord = +)
Longitude en degrés décimaux (Ouest = +)
( A défaut on tombe à  Paris)
Vous pouvez demander une date différente en ajoutant &mois=03&jour=17 et les horaires arrivent pour le 17 mars... (à  défaut, c'est la date du jour qui est prise en compte.)

  code source classé dans  Dates - Heures

 
 01    
 02    
 03    
 04    
 05    
 06    
 07    
 08    
 09    
 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    
 101    
 102    
 103    
                               
<?php
/*---------------------------------------------------------------*/
/*
    Titre : Calcul et affiche le lever et coucher du soleil                                                               
                                                                                                                          
    URL   : https://phpsources.net/code_s.php?id=385
    Auteur           : Olravet                                                                                            
    Website auteur   : http://olravet.fr/                                                                                 
    Date édition     : 07 Mai 2008                                                                                        
    Date mise à jour : 22 Aout 2019                                                                                      
    Rapport de la maj:                                                                                                    
    - fonctionnement du code vérifié                                                                                    
    - correction du code                                                                                                  
    - amélioration du code                                                                                               
*/
/*---------------------------------------------------------------*/

    if (!isset($fh)) {$fh date("H") - gmdate("H") ;}
    if (!isset($La)) { $La 48.833;}
    if (!isset($Lo)) { $Lo = -2.333;}
    if (!isset($ville)) { $ville "Paris";}
    if (!isset($mois)) {$mois date("m") ;}
    if (!isset($jour)) {$jour date("d") ;}
    // Fuseau horaire et coordonnées géographiques
    $k 0.0172024;
    $jm 308.67;
    $jl 21.55;
    $e 0.0167;
    $ob 0.4091;
    $PI3.1415926536;
    //Hauteur du soleil au lever et au coucher
    $dr $PI180;
    $hr $PI12;
    $ht = (-40 60);
    $ht $ht $dr;
    $La $La $dr;
    $Lo $Lo $dr;
    //Date
    if ($mois 3) {
    $mois $mois 12;
    }
    //Heure TU du milieu de la journée
    $h 12 + ($Lo $hr);
    //Nombre de jours écoulés depuis le 1 Mars O h TU
    $J floor(30.61 * ($mois 1)) + $jour + ($h 24) - 123;
    //Anomalie et longitude moyenne
    $M $k * ($J $jm);
    $L $k * ($J $jl);
    //Longitude vraie
    $S =$L $e Sin($M) + 1.25 $e $e Sin($M);
    //Coordonnées rectangulaires du soleil dans le repère équatorial
    $X Cos($S);
    $Y Cos($ob) * Sin($S);
    $Z Sin($ob) * Sin($S);
    //Equation du temps et déclinaison
    $R $L;
    $rx Cos($R) * $X Sin($R) * $Y;
    $ry = -Sin($R) * $X Cos($R) * $Y;
    $X $rx;
    $Y $ry;
    $ET atan($Y $X);
    $DC atan($Z Sqrt($Z $Z));
    //Angle horaire au lever et au coucher
    $cs = (Sin($ht) - Sin($La) * Sin($DC)) / Cos($La) / Cos($DC);
    if ($cs 1) { $CalculSol "Ne se lève pas";}
    if ($cs < -1) { $CalculSol "Ne se couche pas";}
    if ($cs == 0) {
    $ah $PI 2;
    }else{
    $ah atan(Sqrt($cs $cs) / $cs);
    }
    if ($cs 0) { $ah $ah $PI;}
    //Lever du soleil
    $Pm $h $fh + ($ET $ah) / $hr;
    if ($Pm 0) { $Pm $Pm 24;}
    if ($Pm 24) { $Pm $Pm 24;}
    $hs floor($Pm);
    $Pm floor(60 * ($Pm $hs));
    if (strlen($hs)<2) {$hs "0".$hs;}
    if (strlen($Pm)<2) {$Pm "0".$Pm;}
    if (!isset($CalculSol)){
    $lev $hs":" .$Pm;
    }else{
    $lev "---";}
    //Coucher du soleil
    $Pm $h $fh + ($ET $ah) /$hr;
    if ($Pm 24) { $Pm $Pm 24;}
    if ($Pm 0) { $Pm $Pm 24;}
    $hs floor($Pm);
    $Pm floor(60 * ($Pm $hs));
    if (strlen($hs)<2) {$hs "0".$hs;}
    if (strlen($Pm)<2) {$Pm "0".$Pm;}
    if (!isset($CalculSol)){
    $couch $hs":" .$Pm;
    }else{
    $couch  "---";}
    echo "Horaires du Soleil à  ".$ville."<br />";
    echo "Lever = " .$lev ;
    echo "<br />";
    echo "Coucher = "$couch;
?>

          Fonctions du code - Doc officielle PHP

   php.net   Description Versions PHP OUTIL
   atan Arc tangente PHP 4, PHP 5, PHP 7, PHP 8
   cos Cosinus PHP 4, PHP 5, PHP 7, PHP 8
   date Formate une date/heure locale PHP 4, PHP 5, PHP 7, PHP 8
   echo Affiche une chaîne de caractères PHP 4, PHP 5, PHP 7, PHP 8
   floor Arrondit à l'entier inférieur PHP 4, PHP 5, PHP 7, PHP 8
   gmdate Formate une date/heure GMT/CUT PHP 4, PHP 5, PHP 7, PHP 8
   isset Détermine si une variable est affectée PHP 4, PHP 5, PHP 7, PHP 8
   sin Sinus PHP 4, PHP 5, PHP 7, PHP 8
   sqrt Racine carrée PHP 4, PHP 5, PHP 7, PHP 8
   strlen Calcule la taille d'une chaîne PHP 4, PHP 5, PHP 7, PHP 8

   Dites merci aux auteurs pour leurs travail, ça ne coûte rien et ça fait toujours plaisir wink

[1]

  • avatar

    Invité

    22 Mars 2012 à 11:36

    Voir aussi la fonction PHP date_sunrise


 Autres snippets qui pourraient vous intéressez

Calcul le nombre de ligne de plusieurs fichiers

Compatibilité : PHP 5, PHP 7

Affiche le nombre de lignes de fichiers (php, html et txt) d'un dossier spécifié en le parcourant récursivement.

Fonction de calcul

Compatibilité : PHP 5, PHP 7

Fonction de calcul retournant l'ensemble des valeurs traitées dans un tableau.

Calcul les pourcentages

Compatibilité : PHP 5, PHP 7

Vous souhaitez calculer n'importe quel pourcentage en 1 seule fonction mathématique : Avec un calcul simple, cette fonction devrait vous être utile.

Calcul les taux d'intérêt

Compatibilité : PHP 5, PHP 7

Permet avec 1 prix + 1 durée + 1 taux d'intéret : de savoir ce que l'on paie par mois et combien cela coute.

Calcul le cube d'un nombre

Compatibilité : PHP 5, PHP 7

Fonction mathématique typique qui calcul le cube d'un nombre.

Présentation de PHP

PHP débutant et initié 50 Tutoriel

Présentation de MySQL

avatar

Olravet

  07 Mai 2008

  SOURCE   Télécharger

Information sur les mises à jour

Dernière mise à jour :

    22 Aout 2019
    fonctionnement du code vérifié
    correction du code
    amélioration du code

31 824 Vues
Compatibilité
PHP 5, 7 et 8+
avatar
50 codes

Catégorie :  Dates - Heures

Addition de mois à une date
Affiche date et heure dynamiquement
Affiche la date dans une autre langue
Affiche la date de mise à jour d'1 page ou 1 script
Affiche la date du jour en Français
Affiche la date littérale en Français
Affiche le numéro de semaine ISO pour Windows
Affiche les dates du mois - Calendrier mensuel
Affiche les jours du mois
Affiche ligne par ligne les dates comprises entre 2 dates
Affiche une date avec le nom du jour et du mois
Ajoute ou soustrait des jours à une date
Calcul et affiche le lever et coucher du soleil
Calcul et trouve la date d'hier
Calcul l'age à partir de l'année
Calcul l'age à partir d'une date de naissance
Calcul la date de Paque à partir d'une année
Calcul la différence de jour entre 2 dates
Calcul la différence de temps du passé au présent
Calcul la différence entre 2 heures
Calcul le nombre de jours écoulés depuis l'an zéro
Calcul le nombre de jours non-ouvrés entre 2 dates
Calcul le nombre de jours ouvrés entre 2 dates
Calcul le temps restant ou le temps écoulé
Change de format de date us <=> fr
Classement de dates dans 1 fichier
Compte à  rebours du nouvel an
Compte le nombre de jour à partir d'une date
Convertie de secondes en heures, minutes et secondes
Convertie une date MySQL format US au format FR
Date du jour en français de manière littérale
Détermine rapidement si un jour est férié (fetes mobiles incluses)
Formulaire de date en HTML
Fractionne un créneau horaire entre l'heure de début et celle de fin
Indique si une année est bissextile ou pas
Injecte une Date SQL dans un tableau PHP
Lettres dominicales & Epacte julienne
Nombre de jours dans 1 mois
Obtient date + heure ( DATETIME ) au format littérale
Obtient la saison actuelle dans les 2 hémisphères
Quel sont les jours fériés en France
Retourne d'une date littérale la date exacte
Retourne le numéro de semaine passée en paramètre
Transforme une date dans un format littéraire et sympa
Trouve la date du prochain jour
Trouve les dates début et fin de semaine
Trouve si l'année est bissextile
Une autre utilisation de la fonction microtime ()
Vérifie la validité et l'existence d'une date
Vérifie si une date correspond au jour choisi