[Resolu] couleur du texte selon la couleur du fond
28 messages
• Page 1 sur 2 • 1, 2
Consultez la formation à Google Analytics de WebRankInfo / Ranking Metrics
- trustno1
- WRInaute occasionnel

- Messages: 395
- Inscription: 7 Aoû 2005
[Resolu] couleur du texte selon la couleur du fond
Bonjour,
Je cherche un javascript pour changer la couleur du texte automatiquement selon la couleur du fond, comme c'est le cas de (Annonces Gooooogle) de adsense.
Merci
Je cherche un javascript pour changer la couleur du texte automatiquement selon la couleur du fond, comme c'est le cas de (Annonces Gooooogle) de adsense.
Merci
Dernière édition par trustno1 le Lun Sep 05, 2005 18:38, édité 1 fois.
-

CaYuS - WRInaute impliqué

- Messages: 601
- Inscription: 14 Juil 2005
Bonjour,
Dans quelles conditions veux tu utiliser cela ?
Je veux dire, je ne comprends pas très bien ta question :
Si tu as le "pouvoir" de changer la couleur de fond, que t'en coûte t'il de rajouter une ligne de code pour changer également la couleur du texte, sans avoir à passer par du javascript ?
Dans quelles conditions veux tu utiliser cela ?
Je veux dire, je ne comprends pas très bien ta question :
Si tu as le "pouvoir" de changer la couleur de fond, que t'en coûte t'il de rajouter une ligne de code pour changer également la couleur du texte, sans avoir à passer par du javascript ?
-

CaYuS - WRInaute impliqué

- Messages: 601
- Inscription: 14 Juil 2005
Tu sais pour Adsense, ils ne sont pas allez chercher bien loin...
Ils se sont dit qu'une couleur en informatique a pour l'habitude d'être exprimée en hexadecimal avec des valeurs de Rouge, Vert et bleu (RRVVBB = Où chaque lettre vaut respectivement une variable allant de 0 1 2 3 4 ... à.... C D E F correspondant à un nombre allant de 0 à 16 qui est multiplié par son voisin de même nature)
Ils savant que chacune de ces valeurs est alors donnée sur une échelle de (16*16) 256 couleurs ( de 0 à 255 ).
La moitié de 256 étant 128, ils ont décidé de se servir de cette valeur comme témoin.
Ils ont alors essayé de créer une valeur moyenne de la couleur de fond choisie par l'internaute sur une échelle de 0 à 256 qu'ils compareraient ensuite à la valeur témoin.
Si elle est inférieur ou égale à 128 le texte serait blanc, sinon, il serait noir.
Ils se sont demandés quelles étaient les couleurs les plus lumineuses entre le rouge, le vert, et le bleu, puis ils leur ont appliqués un pourcentage arbitraire (en s'assurant que la somme des pourcentages fasse bien 100%).
Rouge : 30%
Vert : 59%
Bleu : 11%
Ramené sur un coefficient unitaire, cela donne :
Rouge: 0.3
Vert : 0.59
Bleu : 0.11
A partir de là ils se sont rappelés comment étaient écrites les couleurs en hexadécimal (ce qu'on a vu plus haut) et ils ont crée une petite fonction afin de convertir la valeur de fond choisie par l'internaute en valeur décimal (de 0 à 255) de Rouge, Vert, et Bleu.
Il ne leur restait plus qu'à faire une petite comparaison...
Voilà ce n'était pas plus compliqué que ça ..., en espérant n'avoir perdu personne en cours de route...
Ils se sont dit qu'une couleur en informatique a pour l'habitude d'être exprimée en hexadecimal avec des valeurs de Rouge, Vert et bleu (RRVVBB = Où chaque lettre vaut respectivement une variable allant de 0 1 2 3 4 ... à.... C D E F correspondant à un nombre allant de 0 à 16 qui est multiplié par son voisin de même nature)
Ils savant que chacune de ces valeurs est alors donnée sur une échelle de (16*16) 256 couleurs ( de 0 à 255 ).
La moitié de 256 étant 128, ils ont décidé de se servir de cette valeur comme témoin.
Ils ont alors essayé de créer une valeur moyenne de la couleur de fond choisie par l'internaute sur une échelle de 0 à 256 qu'ils compareraient ensuite à la valeur témoin.
Si elle est inférieur ou égale à 128 le texte serait blanc, sinon, il serait noir.
Ils se sont demandés quelles étaient les couleurs les plus lumineuses entre le rouge, le vert, et le bleu, puis ils leur ont appliqués un pourcentage arbitraire (en s'assurant que la somme des pourcentages fasse bien 100%).
Rouge : 30%
Vert : 59%
Bleu : 11%
Ramené sur un coefficient unitaire, cela donne :
Rouge: 0.3
Vert : 0.59
Bleu : 0.11
A partir de là ils se sont rappelés comment étaient écrites les couleurs en hexadécimal (ce qu'on a vu plus haut) et ils ont crée une petite fonction afin de convertir la valeur de fond choisie par l'internaute en valeur décimal (de 0 à 255) de Rouge, Vert, et Bleu.
Il ne leur restait plus qu'à faire une petite comparaison...
- Code: Tout sélectionner
SI
0.3*(decimal[rouge]) + 0.59*(decimal[vert]) + 0.11*(decimal[bleu])
EST INFERIEUR OU EGAL A 128
couleur_de_texte = #FFFFFF;
SINON
couleur_de_texte = #000000;
Voilà ce n'était pas plus compliqué que ça ..., en espérant n'avoir perdu personne en cours de route...
-

Blini - WRInaute impliqué

- Messages: 506
- Inscription: 29 Nov 2004
Une petite précision: les poids attribués au R/V/B sont généralement:
Ce sont d'ailleurs ces poids qui sont utilisés (généralement*, je répète) pour convertir une image couleur en niveaux de gris.
(*) parce que ça dépend des tubes cathodiques, tout ça, voyez-vous...
- Code: Tout sélectionner
pR = 0.2125;
pG = 0.7154;
pB = 0.0721;
Ce sont d'ailleurs ces poids qui sont utilisés (généralement*, je répète) pour convertir une image couleur en niveaux de gris.
(*) parce que ça dépend des tubes cathodiques, tout ça, voyez-vous...
Dernière édition par Blini le Mar Aoû 30, 2005 9:06, édité 1 fois.
-

CaYuS - WRInaute impliqué

- Messages: 601
- Inscription: 14 Juil 2005
Ergh ...
Mon code n'était qu'une illustration de ma démonstration ... il est tout à fait non fonctionnel tel quel.
Par contre je ne vais pas pouvoir plus t'aider si tu veux faire ce genre d'application en Javascript, car ce n'est pas un langage dans lequel je mets souvent mon nez.
Néanmoins, tu trouveras tous les scripts js nécessaires en jetant un oeil à la source de la page "Couleurs des annonces" de Google Adsense.
Si tu as la motivation de te pencher dessus.. bon courage
Mon code n'était qu'une illustration de ma démonstration ... il est tout à fait non fonctionnel tel quel.
Par contre je ne vais pas pouvoir plus t'aider si tu veux faire ce genre d'application en Javascript, car ce n'est pas un langage dans lequel je mets souvent mon nez.
Néanmoins, tu trouveras tous les scripts js nécessaires en jetant un oeil à la source de la page "Couleurs des annonces" de Google Adsense.
Si tu as la motivation de te pencher dessus.. bon courage
-

Blini - WRInaute impliqué

- Messages: 506
- Inscription: 29 Nov 2004
trustno1 a écrit:je ne suis pas fort en php.
Euhh... Ben surtout que tu parles de javascript dans ton premier post
Quelques pistes (pour du javascript):
- d'abord accéder à l'élément qui t'intéresse et récupérer la couleur de son texte (recherche getElementById et récupération du style associé)
- écrire un peu de code pour calculer la couleur de fond (une fois que tu as le code hexa de la couleur, utilises les substring pour extraire les canaux R,V et B, puis la fonction parseInt(str, 16) pour convertir en décimal)
- reconstituer le code hexa de ta couleur de fond (méthode toString(16))
- attribuer cette couleur au background de ton élément (getElementById.style.backgroundColor = blabla ou un truc du genre)
Le code suivant pourra peut-être t'aider (bound, c'est une fonction qui contraint une valeur entre 0 et 1, genre max(min(val, 1), 0), et les this.r, this.g, this.b, ce sont les valeurs rgb sur [0,1] (c'est tiré d'une classe)):
- Code: Tout sélectionner
//------ RGB vers #xxxxxx
function RGBtoHEX()
{
var strTot = "#";
var str = "";
var i;
i = Math.round(this.r * 255); str = i.toString(16); if (str.length == 1) str = "0" + str; strTot += str;
i = Math.round(this.g * 255); str = i.toString(16); if (str.length == 1) str = "0" + str; strTot += str;
i = Math.round(this.b * 255); str = i.toString(16); if (str.length == 1) str = "0" + str; strTot += str;
strTot = strTot.toUpperCase();
return strTot;
}
//------ #xxxxxx vers RGB
function HEXtoRGB(str)
{
var rgb = new RGB(0, 0, 0);
if (str.length != 7)
return rgb;
rgb.r = bound(parseInt(str.substr(1,2), 16) / 255.0);
rgb.g = bound(parseInt(str.substr(3,2), 16) / 255.0);
rgb.b = bound(parseInt(str.substr(5,2), 16) / 255.0);
return rgb;
}
- comparef
- WRInaute impliqué

- Messages: 504
- Inscription: 5 Avr 2005
et en php, ca donne :
Pour ceux que ca peut interresser...
- Code: Tout sélectionner
if (0.3*(hexdec(rouge)) + 0.59*(hexdec(vert)) + 0.11*(hexdec(bleu)) <= 128)
{
$couleur = "#FFFFFF";
}
else
{
$couleur = "#000000";
}
Pour ceux que ca peut interresser...
- trustno1
- WRInaute occasionnel

- Messages: 395
- Inscription: 7 Aoû 2005
Bonjour à tous
J'ai essayé avec ce code mais ca marche pas
<?
if (0.3*(hexdec(rouge)) + 0.59*(hexdec(vert)) + 0.11*(hexdec(bleu)) <= 128)
{
$couleur = "#FFFFFF";
}
else
{
$couleur = "#000000";
}
echo"<body bgcolor=#ffffff><font color=$couleur>Maison</font>";
?>
le bgcolor est blanc, et le texte (Maison) blanc aussi, donc le code n'a rien changé
J'ai essayé avec ce code mais ca marche pas
<?
if (0.3*(hexdec(rouge)) + 0.59*(hexdec(vert)) + 0.11*(hexdec(bleu)) <= 128)
{
$couleur = "#FFFFFF";
}
else
{
$couleur = "#000000";
}
echo"<body bgcolor=#ffffff><font color=$couleur>Maison</font>";
?>
le bgcolor est blanc, et le texte (Maison) blanc aussi, donc le code n'a rien changé
- comparef
- WRInaute impliqué

- Messages: 504
- Inscription: 5 Avr 2005
trustno1 a écrit:Bonjour à tous
J'ai essayé avec ce code mais ca marche pas
<?
if (0.3*(hexdec(rouge)) + 0.59*(hexdec(vert)) + 0.11*(hexdec(bleu)) <= 128)
{
$couleur = "#FFFFFF";
}
else
{
$couleur = "#000000";
}
echo"<body bgcolor=#ffffff><font color=$couleur>Maison</font>";
?>
le bgcolor est blanc, et le texte (Maison) blanc aussi, donc le code n'a rien changé
il ne faut pas applique ce code tel quel, voici les element a changer (en rouge):
if (0.3*(hexdec(rouge)) + 0.59*(hexdec(vert)) + 0.11*(hexdec(bleu)) <= 128)
{
$couleur = "#FFFFFF";
}
else
{
$couleur = "#000000";
}
ces élément sont le code couleur de ton fond, par exemple, si le code couleur de ton fond est #05A56E et bien tu mettra 05 a la palce de "rouge", A5 a la place de "vert" et 6E a la place de "bleu".
Dans ton cas, #FFFFFF, tu mettra FF dans chaque.
- trustno1
- WRInaute occasionnel

- Messages: 395
- Inscription: 7 Aoû 2005
oui, c'est bon maintenant merci.
mais ça ne donne pas le même resultat que sur google adsense.
Par exemple:
Quand on choisi un fond noir (ou une plage de couleurs foncés) le texte doit etre blanc
et quand on choisi un fond blanc (ou plage de couleurs clairs) le texte doit être noir.
Merci pour votre aide
mais ça ne donne pas le même resultat que sur google adsense.
Par exemple:
Quand on choisi un fond noir (ou une plage de couleurs foncés) le texte doit etre blanc
et quand on choisi un fond blanc (ou plage de couleurs clairs) le texte doit être noir.
Merci pour votre aide
28 messages
• Page 1 sur 2 • 1, 2
Formation recommandée sur ce thème :
Formation Google Analytics : en 2 jours, apprenez comment exploiter l'essentiel des possibilités de l'outil de mesure d'audience de Google. Formation animée par les experts Google Analytics de Ranking Metrics.
Tous les détails sur le site Ranking Metrics : programme, prix, dates et lieux, inscription en ligne.
Lectures recommandées sur ce thème :
- Couleur du lien et couleur du fond ?
- [résolu] couleur de fond de page et police en gras
- Imprimer couleur fond tableaux
- Ajax : changer couleur de fond
- Lien de la même couleur que le fond
- centrer un site + couleur de fond
- [CSS] définir la couleur de fond
- Choix couleur de fond d'un site
- Nouvelle présentation Adwords - fond de couleur
- Adsense : possible de ne pas mettre de couleur de fond ?
Consultez la description détaillée des produits ou services de Google suivants : Google Latitude
Qui est en ligne
Utilisateurs parcourant ce forum: Aucun utilisateur enregistré et 0 invités
