Представьте себе действительный цвет #RGB в шестнадцатеричном формате, определенный как $color = "#f7b9a0";
Теперь я хочу получить php из этого $ color двух других цветов, которые немного светлее / темнее (тот же оттенок / цвет, но только измененная яркость). Какими способами я мог бы достичь этого? Какой код будет генерировать это? У меня такое чувство, что мне нужно что-то простое:
brightness(input rgb color, ± number of steps); // function outputs the new RGB
// ?? What php code should go here??
В идеале, я хотел бы, чтобы что-то вроде этого было в моем html:
.classDefault {color:<?=$color?> }
.classLighter {color:<?=brightness($color,+10)?> } /* 10 steps brighter */
.classDarker {color:<?=brightness($color,-25)?> } /* 25 steps darker */
Какой код PHP должен идти в функции brightness();
? чтобы сбылась моя мечта?
Любые предложения и / или код оба очень ценятся!
обновлено из ответа ниже:
function alter_brightness($colourstr, $steps) {
$colourstr = str_replace('#','',$colourstr);
$rhex = substr($colourstr,0,2);
$ghex = substr($colourstr,2,2);
$bhex = substr($colourstr,4,2);
$r = hexdec($rhex);
$g = hexdec($ghex);
$b = hexdec($bhex);
$r = max(0,min(255,$r + $steps));
$g = max(0,min(255,$g + $steps));
$b = max(0,min(255,$b + $steps));
return '#'.dechex($r).dechex($g).dechex($b);
}
### NOW LETS DEFINE MY COLOR
$color = "#2233FF";
### DERIVED BRIGHTER COLORS
$color1 = brightness($color,25);
$color2 = brightness($color,50);
$color3 = brightness($color,75);
### DERIVED DARKER COLORS
$color4 = brightness($color,-25);
$color5 = brightness($color,-50);
$color6 = brightness($color,-75);
<!-- BRIGHTER -->
<div style=" background-color:<?=$color3?>"><?=$color3?></div>
<div style=" background-color:<?=$color2?>"><?=$color2?></div>
<div style=" background-color:<?=$color1?>"><?=$color1?></div>
<!-- DEFINED CONSTANT -->
<div style=" background-color:<?=$color?>"><?=$color?></div>
<!-- DARKER -->
<div style=" background-color:<?=$color4?>"><?=$color4?></div>
<div style=" background-color:<?=$color5?>"><?=$color5?></div>
<div style=" background-color:<?=$color6?>"><?=$color6?></div>
работают более яркие цвета, но не темнее . Да ладно, половина решения - это, по крайней мере, большая часть решения, так что большое спасибо!