admin管理员组

文章数量:1334385

I'm looking for a way to change the color of text to either #000 or #fff depending on the main color of a background image within a div called "banner". The background images are chosen at random on each page so I need to be able to do this automatically. I came across JavaScript color contraster but I'm struggling to understand how to use it properly. I notice the link I've posted gives a solution in javascript and I've also read about a possible solution in jquery.

I'm clueless with functions so if anyone could explain clearly how I could achieve this, where I place functions and how I "call them" (if that's the right term!) to use it I'd be really grateful.

Thanks for any help.

I'm looking for a way to change the color of text to either #000 or #fff depending on the main color of a background image within a div called "banner". The background images are chosen at random on each page so I need to be able to do this automatically. I came across JavaScript color contraster but I'm struggling to understand how to use it properly. I notice the link I've posted gives a solution in javascript and I've also read about a possible solution in jquery.

I'm clueless with functions so if anyone could explain clearly how I could achieve this, where I place functions and how I "call them" (if that's the right term!) to use it I'd be really grateful.

Thanks for any help.

Share Improve this question edited May 23, 2017 at 12:13 CommunityBot 11 silver badge asked Jun 27, 2013 at 14:50 JustinJustin 691 silver badge3 bronze badges 3
  • 2 possible duplicate of How to decide font color in white or black depending on background color? – Marc Audet Commented Jun 27, 2013 at 14:51
  • Not sure that answer would help the OP here. – Kyle Commented Jun 27, 2013 at 15:00
  • See the Colours.js library for plimentary colours. And see this question about getting the image average colour. – Xotic750 Commented Jun 27, 2013 at 15:03
Add a ment  | 

1 Answer 1

Reset to default 5

You could do something like this. (using Colours.js and this answer)

Note, this will only work with images on the same domain and in browsers that support HTML5 canvas.

'use strict';

var getAverageRGB = function(imgEl) {
  var rgb = {
    b: 0,
    g: 0,
    r: 0
  };

  var canvas = document.createElement('canvas');
  var context = canvas.getContext && canvas.getContext('2d');
  if (Boolean(context) === false) {
    return rgb;
  }

  var height = imgEl.naturalHeight || imgEl.offsetHeight || imgEl.height;
  var width = imgEl.naturalWidth || imgEl.offsetWidth || imgEl.width;
  canvas.height = height;
  canvas.width = width;
  context.drawImage(imgEl, 0, 0);

  var data;
  try {
    data = context.getImageData(0, 0, width, height).data;
  } catch (e) {
    console.error('security error, img on diff domain');
    return rgb;
  }

  var count = 0;
  var length = data.length;
  // only visit every 5 pixels
  var blockSize = 5;
  var step = (blockSize * 4) - 4;
  for (var i = step; i < length; i += step) {
    count += 1;
    rgb.r += data[i];
    rgb.g += data[i + 1];
    rgb.b += data[i + 2];
  }

  rgb.r = Math.floor(rgb.r / count);
  rgb.g = Math.floor(rgb.g / count);
  rgb.b = Math.floor(rgb.b / count);

  return rgb;
};

var rgb = getAverageRGB(document.getElementById('image'));
var avgComplement = Colors.plement(rgb.r, rgb.b, rgb.g);
var avgComplementHex = Colors.rgb2hex.apply(null, avgComplement.a);
var pliment = parseInt(avgComplementHex.slice(1), 16);

document.body.style.backgroundColor = 'rgb(' + [
  rgb.r,
  rgb.g,
  rgb.b
].join(',') + ')';

var maxColors = 0xFFFFFF;
var midPoint = Math.floor(maxColors / 2);
document.getElementById('text').style.color = pliment > midPoint ? '#000' : '#fff';
<script src="https://cdnjs.cloudflare./ajax/libs/Colors.js/1.2.3/colors.min.js"></script>
<div id="text">Setting the BODY's background to the average color in the following image and this text to a plimentary colour of black or white:</div>
<img id="image" src="" />

本文标签: javascriptAutomatically contrasting text color based on background image colorStack Overflow