Кросс-платформенный текст, рисуемый цветовым градиентом

в 11:16, , рубрики: css, javascript, linear-gradient, Веб-разработка, градиент, текст, метки: , ,

Вот два изображенья — вот и вот: *

[два изображенья]

На том и на другом изображении мы видим красивый текст. Большей частью своей красоты этот текст обязан тому, что рисуется не одним простым цветом, а плавным цветовым переходом — так называемою градиентною заливкою.

Здесь уместно припомнить, что веборазработчики постепенно выучились употреблять градиенты в качестве фоновых рисунков: для этой цели им верно служит свойство «background: linear-gradient();», описываемое в стандарте «CSS Image Values and Replaced Content Module Level 3». И если сейчас перейти к стандарту по гиперссылке, то станет видно, что он достиг уж статуса «Candidate Recommendation», и что датируется он семнадцатым апреля 2012 года. В честь первой годовщины этого дня позвольте поговорить о том, что градиентная отрисовка текста всё ещё распространена в Сети куда менее, чем градиентная отрисовка фона.

Почему это так? Да потому, что единственным широко известным средством для градиентной раскраски текста служит нам нестандартный CSS-код «-webkit-background-clip: text», который обрезает любой фон (в том числе градиентный) по границе текста — и который употребляется обыкновенно в сочетании с CSS-кодом «-webkit-text-fill-color: transparent», обеспечивающим прозрачность букв самогó текста, так что фон через него проглядывает. Этот код работает с весны 2008 года, но, к сожалению, только во браузерах на основе WebKit, число которых хотя и возросло недавно (благодаря Опере, отступившейся от собственного движка), но ими одними плоды мирового браузеростроения не исчерпываются. Ни в Firefox, ни в Internet Explorer этот код не заработает.

Можно ли преодолеть этот тупик и достичь кросс-платформенности текста, отрисовываемого цветовым градиентом? Да, это возможно; но для этого придётся вместо CSS прибегнуть ко джаваскрипту.

Зайдите на сайт проекта «Codename Rainbows», откройте тамошнюю демонстрационную страницу (например, в Файерфоксе) — и вашему взору предстанут девять примеров текста, оформленного градиентом. Именно оттуда я позаимстовал два примера, приведённых выше.

Как такое достигается? Читая пособие, нетрудно обнаружить, что действует плагин jQuery, который нарезает текст на узкие горизонтальные полоски однопиксельной высоты, и внутри каждой такой полоски отображает копию текста, раскрашенную в необходимый промежуточный цвет и сдвинутую по вертикали таким образом, чтобы в точности стать на место первоначального текста внутри этой полоски:

[RAINBOWS]

Благодаря этой счастливой мысли, пришедшей в голову авторов проекта «Codename Rainbows», мы можем считать решённою задачу кросс-платформенной отрисовки текста заданным цветовым градиентом. Правда, решена она только для одного частного случая: градиент должен быть вертикальным, да притом в данной реализации задавать возможно только самый верхний и самый нижний цвет его — не получится, например, поназадавать ряд специальных промежуточных точек и тем реализовать эффект «хромирования» букв. Но и так, и так нам есть чему порадоваться.

_______________
* Шекспир, «Гамлет, принц датский», акт III, сцена IV, в переводе Пастернака.

Автор: Mithgol

Источник

Поделиться

* - обязательные к заполнению поля