setPattern('LLLL'); // full month name with NO DECLENSION ;-) $months_locale = []; for ($month_number = 1; $month_number <= 12; ++$month_number) { $months_locale[] = $dateFormatter->format( // 'n' => month number with no leading zeros DateTime::createFromFormat('n', (string)$month_number) ); } $my = ucfirst($months_locale[(int)$m]) . " " . $y; //echo $my; return $my; } /* Fonctions get_gps() et gps2Num(): extrait les coord GPS depuis les exifs insert_bdd.php */ function gps2Num($coordPart){ $parts = explode('/', $coordPart); if(count($parts) <= 0) return 0; if(count($parts) == 1) return $parts[0]; return floatval($parts[0]) / floatval($parts[1]); } function get_gps($exif) { if($exif && isset($exif['GPS'])){ $GPSLatitudeRef = isset($exif['GPS']['GPSLatitudeRef']) ? $exif['GPS']['GPSLatitudeRef'] : ''; $GPSLatitude = isset($exif['GPS']['GPSLatitude']) ? $exif['GPS']['GPSLatitude'] : ''; $GPSLongitudeRef = isset($exif['GPS']['GPSLongitudeRef']) ? $exif['GPS']['GPSLongitudeRef'] : ''; $GPSLongitude = isset($exif['GPS']['GPSLongitude']) ? $exif['GPS']['GPSLongitude'] : ''; $GPSAltitude = isset($exif['GPS']['GPSAltitude']) ? $exif['GPS']['GPSAltitude'] : ''; $lat_degrees = count($GPSLatitude) > 0 ? gps2Num($GPSLatitude[0]) : 0; $lat_minutes = count($GPSLatitude) > 1 ? gps2Num($GPSLatitude[1]) : 0; $lat_seconds = count($GPSLatitude) > 2 ? gps2Num($GPSLatitude[2]) : 0; $lon_degrees = count($GPSLongitude) > 0 ? gps2Num($GPSLongitude[0]) : 0; $lon_minutes = count($GPSLongitude) > 1 ? gps2Num($GPSLongitude[1]) : 0; $lon_seconds = count($GPSLongitude) > 2 ? gps2Num($GPSLongitude[2]) : 0; $lat_direction = ($GPSLatitudeRef == 'W' or $GPSLatitudeRef == 'S') ? -1 : 1; $lon_direction = ($GPSLongitudeRef == 'W' or $GPSLongitudeRef == 'S') ? -1 : 1; $latitude = $lat_direction * ($lat_degrees + ($lat_minutes / 60) + ($lat_seconds / (60*60))); $longitude = $lon_direction * ($lon_degrees + ($lon_minutes / 60) + ($lon_seconds / (60*60))); $alt = explode('/', $exif['GPS']["GPSAltitude"]); $altitude = (isset($alt[1])) ? ($alt[0] / $alt[1]) : $alt[0]; } else { $latitude = ''; $longitude = ''; $altitude = ''; } return array('latitude'=>$latitude, 'longitude'=>$longitude, 'altitude'=>$altitude); } /* Fonction create_thumb(): Création des vigntettes insert_bdd.php */ function create_thumb($thumb_w, $thumb_h, $image) { list($origin_w, $origin_h) = getimagesize($image); $origin_ratio = round($origin_w / $origin_h, 1); $outFile = str_replace("photos/img", "photos/thumb", $image); if ($origin_w != null && $origin_h != null) { if ($thumb_w / $thumb_h > $origin_ratio) { $thumb_w = $thumb_h * $origin_ratio; } else { $thumb_h = $thumb_w / $origin_ratio; } if ($origin_w >= 400 && $origin_h >= 400) { $image = new Imagick($image); // !!! $image->thumbnailImage($thumb_w, $thumb_h); $image->writeImage($outFile); $image->destroy(); } } } /* Fonction in_bdd(): test si la photo est déjà dans la bdd insert_bdd.php */ function in_bdd($image) { try { $conn3 = new PDO('sqlite:db_photo.sqlite3'); #$query3 = "SELECT filename FROM photos WHERE instr(filename, '". $file . "') > 0;"; $query3 = "SELECT filename FROM photos WHERE filename = :filename"; $stmt = $conn3->prepare($query3); $stmt->bindParam(':filename', $image, PDO::PARAM_STR); $stmt->execute(); $result3 = $stmt->fetchAll(PDO::FETCH_ASSOC); if (count($result3) > 0) { return true; } else { return false; } $conn3 = null; } catch(PDOException $e) { echo $e->getMessage(); } } // function _pr($d) { echo "
"; echo '' . debug_backtrace()[0]['file'] . ' ' . debug_backtrace()[0]['line'] . ''; echo "
"; echo '
';
    if(is_array($d)) {
    	print_r($d);
    	} else if(is_object($d)) {
    	var_dump($d);
    	}
    echo '
'; } /* return geo exif in a nice form */ function geo_frac2dec($str) { @list( $n, $d ) = explode( '/', $str ); if ( !empty($d) ) return $n / $d; return $str; } /* 33° 52.37′ 0″ S 151° 9.06′ 0″ E */ function geo_pretty_fracs2dec($fracs) { return geo_frac2dec($fracs[0]) . '° ' . geo_frac2dec($fracs[1]) . '′ ' . geo_frac2dec($fracs[2]) . '″ '; } /* to GoogleMaps */ function geo_single_fracs2dec($fracs) { return geo_frac2dec($fracs[0]) + geo_frac2dec($fracs[1]) / 60 + geo_frac2dec($fracs[2]) / 3600; } ?>