Как преобразовать строки в хэш-код html-кода?
Я хотел бы представлять строки как произвольные html-цвета.
Пример:
"blah blah" = # FFCC00
"foo foo 2" = # 565656
Не имеет значения, каков фактический цветовой код, если он действительно хорошо представлен шестнадцатеричный код цвета HTML и весь спектр.
Я предполагаю, что первым шагом было бы сделать MD5 на строке, а затем каким-то образом преобразовать это в шестнадцатеричный код цвета?
Обновление: Пример использования - это создание визуального отчета о запросах файлов на сервере. Цвета не должны выглядеть красиво, тем более, что человеческий мозг может легче обнаружить шаблоны и т.д. В данных.
Ответы
Ответ 1
Спасибо за указатели, это, похоже, делает компетентную работу:
function stringToColorCode($str) {
$code = dechex(crc32($str));
$code = substr($code, 0, 6);
return $code;
}
$str = 'test123';
print '<span style="background-color:#'.stringToColorCode($str).'">'.$str.'</span>';
Ответ 2
Почти всегда, просто используя случайные цвета
- плохо выглядеть
- конфликт с фоном
Я бы порекомендовал создать (длинный) список цветов, которые хорошо работают вместе с вашим фоном, а затем просто хешируйте строку и модуль (%) с вашим количеством цветов, чтобы получить индекс в таблице.
public function colorFromString($string)
{
$colors = [
'#0074D9',
'#7FDBFF',
'#39CCCC',
// this list should be as long as practical to avoid duplicates
];
// generate a partial hash of the string (a full hash is too long for the % operator)
$hash = substr(sha1($string), 0, 10);
// determine the color index
$colorIndex = hexdec($hash) % count($colors);
return $colors[$colorIndex];
}
Ответ 3
Я согласен с sje397 выше, что вполне случайные цвета могут оказаться неприятными. Вместо того, чтобы делать длинный список красиво выглядящих цветов, я бы предложил выбрать постоянное значение насыщенности + люминесценции и варьировать оттенок на основе содержимого. Чтобы получить цвет RGB из цвета HSL, вы можете использовать нечто похожее на то, что описано в http://en.wikipedia.org/wiki/HSL_and_HSV#Converting_to_RGB.
Вот пример (попробуйте в http://codepad.viper-7.com что-то, что работает, например https://codepad.remoteinterview.io/ZXBMZWYJFO):
<?php
function hsl2rgb($H, $S, $V) {
$H *= 6;
$h = intval($H);
$H -= $h;
$V *= 255;
$m = $V*(1 - $S);
$x = $V*(1 - $S*(1-$H));
$y = $V*(1 - $S*$H);
$a = [[$V, $x, $m], [$y, $V, $m],
[$m, $V, $x], [$m, $y, $V],
[$x, $m, $V], [$V, $m, $y]][$h];
return sprintf("#%02X%02X%02X", $a[0], $a[1], $a[2]);
}
function hue($tstr) {
return unpack('L', hash('adler32', $tstr, true))[1];
}
$phrase = "Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.";
$words = [];
foreach (explode(' ', $phrase) as $word)
$words[hue($word)] = $word;
ksort($words);
foreach ($words as $h => $word) {
$col = hsl2rgb($h/0xFFFFFFFF, 0.4, 1);
printf('<span style="color:%s">%s</span> ', $col, $word);
}
?>
Ответ 4
Один вкладыш:
substr(md5($string), 0, 6);
Ответ 5
Думаю, я очень хорошо понимаю это желание. Я хотел того же. Попытка получить уникальный цвет фона, который представляет собой заголовок. Я не хотел ничего предопределять себе, я хотел, чтобы получить визуальный хэш для каждого названия, но с довольно-таки. Нашли это, чтобы сделать работу довольно хорошо. Вы можете изменить яркость цветов и варианты того, что он возвращает. Вы просто проверяете его на цвета, которые вам удобны. Я думаю, что любой цвет должен быть хорошим для этой работы, только чтобы яркость имела значение, чтобы отличить его от переднего плана.
https://mrkmg.com/blog/2012/01/13/php-function-to-generate-a-color-from-a-text-string/
Дайте ему строку, минимальную яркость (0-255) и дисперсию (2-10), и она будет генерировать цвет для вашей строки. Это может дать вам красивые цвета, если вы настроились.