[SPIP] ~v3.0.20-->v3.0.25
[lhc/web/clavette_www.git] / www / ecrire / inc / filtres_images_mini.php
1 <?php
2
3 /***************************************************************************\
4 * SPIP, Systeme de publication pour l'internet *
5 * *
6 * Copyright (c) 2001-2016 *
7 * Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James *
8 * *
9 * Ce programme est un logiciel libre distribue sous licence GNU/GPL. *
10 * Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. *
11 \***************************************************************************/
12
13 if (!defined('_ECRIRE_INC_VERSION')) return;
14 include_spip('inc/filtres_images_lib_mini'); // par precaution
15
16 // http://doc.spip.org/@couleur_html_to_hex
17 function couleur_html_to_hex($couleur){
18 $couleurs_html=array(
19 'aqua'=>'00FFFF','black'=>'000000','blue'=>'0000FF','fuchsia'=>'FF00FF','gray'=>'808080','green'=>'008000','lime'=>'00FF00','maroon'=>'800000',
20 'navy'=>'000080','olive'=>'808000','purple'=>'800080','red'=>'FF0000','silver'=>'C0C0C0','teal'=>'008080','white'=>'FFFFFF','yellow'=>'FFFF00');
21 if (isset($couleurs_html[$lc=strtolower($couleur)]))
22 return $couleurs_html[$lc];
23 return $couleur;
24 }
25
26 // http://doc.spip.org/@couleur_foncer
27 function couleur_foncer ($couleur, $coeff=0.5) {
28 $couleurs = _couleur_hex_to_dec($couleur);
29
30 $red = $couleurs["red"] - round(($couleurs["red"])*$coeff);
31 $green = $couleurs["green"] - round(($couleurs["green"])*$coeff);
32 $blue = $couleurs["blue"] - round(($couleurs["blue"])*$coeff);
33
34 $couleur = _couleur_dec_to_hex($red, $green, $blue);
35
36 return $couleur;
37 }
38
39 // http://doc.spip.org/@couleur_eclaircir
40 function couleur_eclaircir ($couleur, $coeff=0.5) {
41 $couleurs = _couleur_hex_to_dec($couleur);
42
43 $red = $couleurs["red"] + round((255 - $couleurs["red"])*$coeff);
44 $green = $couleurs["green"] + round((255 - $couleurs["green"])*$coeff);
45 $blue = $couleurs["blue"] + round((255 - $couleurs["blue"])*$coeff);
46
47 $couleur = _couleur_dec_to_hex($red, $green, $blue);
48
49 return $couleur;
50
51 }
52
53 // selectionner les images qui vont subir une transformation sur un critere de taille
54 // ls images exclues sont marquees d'une class no_image_filtrer qui bloque les filtres suivants
55 // dans la fonction image_filtrer
56 // http://doc.spip.org/@image_select
57 function image_select($img,$width_min=0, $height_min=0, $width_max=10000, $height_max=1000){
58 if (!$img) return $img;
59 list ($h,$l) = taille_image($img);
60 $select = true;
61 if ($l<$width_min OR $l>$width_max OR $h<$height_min OR $h>$height_max)
62 $select = false;
63
64 $class = extraire_attribut($img,'class');
65 $p = strpos($class,'no_image_filtrer');
66 if (($select==false) AND ($p===FALSE)){
67 $class .= " no_image_filtrer";
68 $img = inserer_attribut($img,'class',$class);
69 }
70 if (($select==true) AND ($p!==FALSE)){
71 $class = preg_replace(",\s*no_image_filtrer,","",$class);
72 $img = inserer_attribut($img,'class',$class);
73 }
74 return $img;
75 }
76
77
78 // http://doc.spip.org/@image_passe_partout
79 function image_passe_partout($img,$taille_x = -1, $taille_y = -1,$force = false,$cherche_image=false,$process='AUTO'){
80 if (!$img) return '';
81 list ($hauteur,$largeur) = taille_image($img);
82 if ($taille_x == -1)
83 $taille_x = isset($GLOBALS['meta']['taille_preview'])?$GLOBALS['meta']['taille_preview']:150;
84 if ($taille_y == -1)
85 $taille_y = $taille_x;
86
87 if ($taille_x == 0 AND $taille_y > 0)
88 $taille_x = 1; # {0,300} -> c'est 300 qui compte
89 elseif ($taille_x > 0 AND $taille_y == 0)
90 $taille_y = 1; # {300,0} -> c'est 300 qui compte
91 elseif ($taille_x == 0 AND $taille_y == 0)
92 return '';
93
94 list($destWidth,$destHeight,$ratio) = ratio_passe_partout($largeur,$hauteur,$taille_x,$taille_y);
95 $fonction = array('image_passe_partout', func_get_args());
96 return process_image_reduire($fonction,$img,$destWidth,$destHeight,$force,$cherche_image,$process);
97 }
98
99 // http://doc.spip.org/@image_reduire
100 function image_reduire($img, $taille = -1, $taille_y = -1, $force=false, $cherche_image=false, $process='AUTO') {
101 // Determiner la taille x,y maxi
102 // prendre le reglage de previsu par defaut
103 if ($taille == -1)
104 $taille = (isset($GLOBALS['meta']['taille_preview']) AND intval($GLOBALS['meta']['taille_preview']))?intval($GLOBALS['meta']['taille_preview']):150;
105 if ($taille_y == -1)
106 $taille_y = $taille;
107
108 if ($taille == 0 AND $taille_y > 0)
109 $taille = 10000; # {0,300} -> c'est 300 qui compte
110 elseif ($taille > 0 AND $taille_y == 0)
111 $taille_y = 10000; # {300,0} -> c'est 300 qui compte
112 elseif ($taille == 0 AND $taille_y == 0)
113 return '';
114
115 $fonction = array('image_reduire', func_get_args());
116 return process_image_reduire($fonction,$img,$taille,$taille_y,$force,$cherche_image,$process);
117 }
118
119 // Reduire une image d'un certain facteur
120 // http://doc.spip.org/@image_reduire_par
121 function image_reduire_par ($img, $val=1, $force=false) {
122 list ($hauteur,$largeur) = taille_image($img);
123
124 $l = round($largeur/$val);
125 $h = round($hauteur/$val);
126
127 if ($l > $h) $h = 0;
128 else $l = 0;
129
130 $img = image_reduire($img, $l, $h, $force);
131
132 return $img;
133 }
134
135 ?>