Maison  >  Article  >  interface Web  >  En HTML, changer la couleur du texte en fonction de la luminosité de la zone d'arrière-plan couverte ?

En HTML, changer la couleur du texte en fonction de la luminosité de la zone d'arrière-plan couverte ?

PHPz
PHPzavant
2023-08-28 13:29:02588parcourir

En HTML, changer la couleur du texte en fonction de la luminosité de la zone darrière-plan couverte ?

Vous pouvez utiliser l'extrait de code suivant pour modifier la couleur du texte en fonction de la luminosité moyenne des pixels superposés par sa couleur d'arrière-plan parent.

var rgb = [255, 0, 0];
setInterval(display, 1000);
function display() {
   rgb[0] = Math.round(Math.random() * 255);
   rgb[1] = Math.round(Math.random() * 255);
   rgb[2] = Math.round(Math.random() * 255);
   
   var d = Math.round(((parseInt(rgb[0]) * 299) + (parseInt(rgb[1]) * 587) +
      (parseInt(rgb[2]) * 114)) / 1000);
   // for foregound
   var f = (d> 125) ? 'black' : 'white';
   
  // for background
  var b = 'rgb(' + rgb[0] + ',' + rgb[1] + ',' + rgb[2] + ')';
  $('#box').css('color', f);
  $('#box').css('background-color', b);
}
<scriptsrc = "https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<div id = "box"> Demo</div>

Voici le CSS -

#box {
   width: 300px;
  height: 300px;
}

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer