В предыдущем посте я не затронул техническую часть — исправляю это.

Как 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-фильтра:

  1. Карта искажений — обычный PNG-шум, закодированный в base64. Это не turbulence и не procedural noise из SVG — они дают слишком «облачный» рисунок. PNG с мелким равномерным шумом ведёт себя куда более натурально, особенно под малым blur.

  2. feDisplacementMap использует эту карту как векторное поле:

    1. красный канал отвечает за смещения по X

    2. зелёный — по Y
      Значение scale определяет амплитуду волн. Большие числа не делают эффект агрессивнее — они делают его заметным после blur.

  3. Проверка браузера сделана из-за того, что в Safari как всегда ничего не работает, и приходится прописывать fallback.

  4. Добавлено немного цвета, чтобы сильно не сливалось с задним фоном.

Как использовать на любом блоке

Просто добавьте к любому тегу, будь то <div>,<button>, класс .bg-liquid-glass:

<div className="bg-liquid-glass ...">
...
</div>

Эффект знаменитого прозрачного стекла готов! Обязательно не забудьте добавить стили к каждому контейнеру, чтобы текст внутри не сливался с задним фоном.

Хэдер моего приложения с применением Liquid Glass
Хэдер моего приложения с применением Liquid Glass

Что важно учитывать при использовании Liquid Glass

  • Поддержка в браузерах. К сожалению, на данный момент Safari не поддерживают displacement карты.

  • Не перегружайте интерфейс. На слабых девайсах комплексные фильтры быстро дают по FPS, поэтому используйте эффект аккуратно и избегайте «тотального» блюра на больших областях.

  • Смотрите на реальный масштаб. Один и тот же слой размывается по-разному на мобильных и десктопных разрешениях. Обязательно проверяйте качество и читаемость на нескольких форм-факторах.

  • Контраст прежде всего. Стеклянные панели легко «съедают» текст — добавляйте тени, уплотняйте подложку, регулируйте цвет полупрозрачности.

  • Эффект — не только украшение. Когда Liquid Glass используется аккуратно, он улучшает визуальную иерархию, фокусирует внимание и повышает комфорт взаимодействия, а значит влияет и на продуктовые метрики.

Почему этот эффект стоит внедрять сейчас

После появления Liquid Glass в интерфейсах iOS 26 тема полупрозрачных, «живых» поверхностей снова стала заметным трендом. Apple фактически нормализовала этот стиль, и пользователи их устройств уже воспринимают его как современный и «естественный».

Если продукту нужен актуальный визуальный язык, мягкая глубина и ощущение премиальности — сейчас идеальный момент, чтобы добавить Liquid Glass в дизайн-систему или хотя бы протестировать его в отдельных компонентах.

Комментарии (4)


  1. Nexoic
    06.12.2025 20:19

    Если в ios 27 уберут стекло - снова на обычные блоки переделывать ?


    1. artemsnite Автор
      06.12.2025 20:19

      Вряд ли будут убирать стекло в ближайшем будущем, ведь Apple уже задала этот тренд. Если его будут как-нибудь изменять, то в предложенном в статье коде почти ничего не придется менять, компонент то реюзабельный


  1. jarkevithwlad
    06.12.2025 20:19

    видел разные реализации но как по мне самый красивый вариант тут


    1. artemsnite Автор
      06.12.2025 20:19

      В статье рассказывается о том, как это сделать без javascript. В Вашем примере используется WebGL; на npm уже есть много модулей с реализацией такого метода рендера жидкого стекла. Про возможность удобной кастомизации - да, это плюс шейдеров