В предыдущем посте я не затронул техническую часть — исправляю это.
Как Apple опять поменяла UI/UX
Последние годы мы привыкли к безопасному, предсказуемому минимализму в интерфейсах. Плоские панели, строгие сетки, аккуратные тени — дизайн стал почти невидимым фоном для функциональности. И именно в этот момент Apple решила встряхнуть индустрию, представив Liquid Glass — новый визуальный язык, который возвращает интерфейсам материальность, глубину и немного магии.
На первый взгляд это просто красивый эффект полупрозрачного стекла наподобие backdrop-filter: blur(...). Но если копнуть глубже, Liquid Glass — это попытка переосмыслить саму идею взаимодействия с цифровой средой. Между строк читается тезис: интерфейсы снова должны ощущаться, а не только работать. И нравится нам это или нет — тенденция уже начала формировать новые ожидания у пользователей.
В этой статье я разберу, как создать подобный интерфейс яблочной компании без использования различн��х npm-модулей или шейдеров, нагружающих видеопамять устройства.
Принципы Liquid Glass
Чтобы повторить стиль, нужно понимать его ключевые элементы:
Полупрозрачный фон
Размытие окружающего контента (backdrop-filter)
Мягкие внутренние/внешние тени
Лёгкие световые блики
Аккуратные анимации
Объём через слои и глубину
По сути, это — современный re-imagining стеклянного неоморфизма, но легче, воздушнее и «живее».
Пример блока с обычным размытием фона
Начнём с фундаментального — обыкновенной стеклянной панели.
HTML
<div class="backdrop">
Неоморфизм
</div>
CSS
.backdrop {
border-radius: 20px;
background: rgba(255, 255, 255, 0.12);
backdrop-filter: blur(18px);
-webkit-backdrop-filter: blur(18px);
border: 1px solid rgba(255, 255, 255, 0.2);
}
Что здесь важно:
background низкой плотности даёт полупрозрачность
backdrop-filter размывает то, что под карточкой
border создаёт ощущение стеклянного края
Реализация «жидкого стекла» в CSS без магии
Когда смотришь на Liquid Glass, кажется, что это просто blur с прозрачностью. Но характерная “текучесть” появляется только тогда, когда фон под панелью искажается неравномерно, с микродеформациями. Обычный blur даёт матовость, но не живость.
Чтобы получить такую “плату волн”, я использую SVG-фильтр с displacement map, встроенный прямо в backdrop-filter. Это даёт ровно тот эффект, который Apple достигает в своём стекле: фон как будто лежит под тонкой динамической плёнкой.
Как всё работает на уровне механики
Изучим компонент, создающий размытый фон наподобие Liquid Glass, который я создал для своего приложения.
export default function LiquidGlass() {
const isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent);
return (
<>
<svg className="hidden">
<filter id="displacementFilter">
<feImage
href=""
preserveAspectRatio="none"/>
<feDisplacementMap
in="SourceGraphic"
in2="turbulence"
scale="600"
xChannelSelector="R"
yChannelSelector="G"
/>
</filter>
</svg>
<style>{`
.bg-liquid-glass {
backdrop-filter: ${!isSafari ? "url(#displacementFilter) " : ""}blur(2px);
@apply bg-muted/25;
}
`}</style>
</>
);
}
Теперь рассмотрим каждый блок компонента, особенно SVG-фильтра:
Карта искажений — обычный PNG-шум, закодированный в base64. Это не turbulence и не procedural noise из SVG — они дают слишком «облачный» рисунок. PNG с мелким равномерным шумом ведёт себя куда более натурально, особенно под малым blur.
-
feDisplacementMap использует эту карту как векторное поле:
красный канал отвечает за смещения по X
зелёный — по Y
Значениеscaleопределяет амплитуду волн. Большие числа не делают эффект агрессивнее — они делают его заметным после blur.
Проверка браузера сделана из-за того, что в Safari как всегда ничего не работает, и приходится прописывать fallback.
Добавлено немного цвета, чтобы сильно не сливалось с задним фоном.
Как использовать на любом блоке
Просто добавьте к любому тегу, будь то <div>,<button>, класс .bg-liquid-glass:
<div className="bg-liquid-glass ...">
...
</div>
Эффект знаменитого прозрачного стекла готов! Обязательно не забудьте добавить стили к каждому контейнеру, чтобы текст внутри не сливался с задним фоном.

Что важно учитывать при использовании Liquid Glass
Поддержка в браузерах. К сожалению, на данный момент Safari не поддерживают displacement карты.
Не перегружайте интерфейс. На слабых девайсах комплексные фильтры быстро дают по FPS, поэтому используйте эффект аккуратно и избегайте «тотального» блюра на больших областях.
Смотрите на реальный масштаб. Один и тот же слой размывается по-разному на мобильных и десктопных разрешениях. Обязательно проверяйте качество и читаемость на нескольких форм-факторах.
Контраст прежде всего. Стеклянные панели легко «съедают» текст — добавляйте тени, уплотняйте подложку, регулируйте цвет полупрозрачности.
Эффект — не только украшение. Когда Liquid Glass используется аккуратно, он улучшает визуальную иерархию, фокусирует внимание и повышает комфорт взаимодействия, а значит влияет и на продуктовые метрики.
Почему этот эффект стоит внедрять сейчас
После появления Liquid Glass в интерфейсах iOS 26 тема полупрозрачных, «живых» поверхностей снова стала заметным трендом. Apple фактически нормализовала этот стиль, и пользователи их устройств уже воспринимают его как современный и «естественный».
Если продукту нужен актуальный визуальный язык, мягкая глубина и ощущение премиальности — сейчас идеальный момент, чтобы добавить Liquid Glass в дизайн-систему или хотя бы протестировать его в отдельных компонентах.
Комментарии (4)

jarkevithwlad
06.12.2025 20:19видел разные реализации но как по мне самый красивый вариант тут

artemsnite Автор
06.12.2025 20:19В статье рассказывается о том, как это сделать без javascript. В Вашем примере используется WebGL; на npm уже есть много модулей с реализацией такого метода рендера жидкого стекла. Про возможность удобной кастомизации - да, это плюс шейдеров
Nexoic
Если в ios 27 уберут стекло - снова на обычные блоки переделывать ?
artemsnite Автор
Вряд ли будут убирать стекло в ближайшем будущем, ведь Apple уже задала этот тренд. Если его будут как-нибудь изменять, то в предложенном в статье коде почти ничего не придется менять, компонент то реюзабельный