FastComments.com

FastComments Image Chat обеспечивает интерактивные обсуждения изображений, позволяя пользователям кликать в любое место изображения для создания точек обсуждения. Пользователи могут кликать по конкретным частям изображений, чтобы начать разговоры об этих областях, создавая визуальные метки, которые показывают, где находятся обсуждения.

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

Адаптивный дизайн Internal Link

Процентное позиционирование

Image Chat использует координаты на основе процентов вместо пиксельных координат для расположения маркеров чата на изображениях. Когда пользователь кликает по изображению, виджет преобразует пиксельные координаты клика в проценты от ширины и высоты изображения. Такой подход гарантирует, что маркеры остаются в правильном месте независимо от того, как отображается изображение.

Например, если пользователь кликнул в 250 пикселях от левого края изображения шириной 1000px, виджет сохраняет это как 25% от левого края. Когда другой пользователь просматривает то же изображение шириной 500px на мобильном устройстве, маркер появляется в 125 пикселях от левого края, что по-прежнему составляет 25% от ширины.

Преимущества для адаптивной верстки

Эта процентная система позволяет Image Chat корректно работать на всех размерах устройств и ориентациях. Ваши изображения могут отображаться в разных размерах в зависимости от ширины экрана, CSS-правил или ограничений контейнера, но маркеры всегда будут правильно совпадать с задуманными местами.

Пользователи на настольных компьютерах с большими мониторами видят маркеры в тех же относительных позициях, что и пользователи на смартфонах с маленькими экранами. Маркеры масштабируются пропорционально самому изображению.

Масштабирование изображения и соотношение сторон

Пока ваше изображение сохраняет соотношение сторон при изменении размера (что является поведением браузера по умолчанию), процентные маркеры будут оставаться идеально выровненными. Виджет предполагает, что изображения масштабируются пропорционально и рассчитывает позиции на этом основании.

Если вы применяете CSS, которое искажает соотношение сторон изображения (например, используя object-fit: cover с заданными размерами), позиции маркеров могут не совпадать корректно. Для наилучших результатов позволяйте изображениям масштабироваться естественным образом или используйте object-fit: contain, чтобы сохранять соотношение сторон.

Размер чат-квадрата

Визуальный размер маркеров чата также основан на процентах. Опция конфигурации chatSquarePercentage по умолчанию равна 5%, что означает, что каждый квадрат составляет 5% от ширины изображения. Это обеспечивает согласованный визуальный вес на изображениях разного размера.

На изображении шириной 1000px с настройкой по умолчанию 5% маркеры имеют размеры 50px. На изображении шириной 500px те же маркеры имеют размеры 25px. Они остаются пропорциональными размеру изображения.

Поведение на мобильных устройствах

На экранах шириной меньше 768px Image Chat переключается на оптимизированную для мобильных устройств компоновку. Окна чата открываются во весь экран вместо плавающего окна рядом с маркером. Это обеспечивает лучшую удобочитаемость на маленьких экранах, где плавающие окна скрывали бы слишком большую часть изображения.

Сами маркеры остаются видимыми и кликабельными в своих процентных позициях. Пользователи по‑прежнему видят, где расположены все обсуждения, и могут нажимать на маркеры, чтобы открыть полноэкранный интерфейс чата.

Динамическая загрузка изображений

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

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

Согласованность между устройствами

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

Это работает в обоих направлениях. Обсуждение, созданное путём касания определённого места на мобильном устройстве, появляется в той же относительной позиции при просмотре на большом настольном мониторе.

Учет области просмотра

Виджет рассчитывает проценты относительно самого элемента изображения, а не относительно viewport. Это означает, что прокрутка страницы или изменение размера окна браузера не влияют на позиции маркеров. Маркеры остаются привязанными к своим местам на изображении независимо от изменений области просмотра.

Защита контента на будущее

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

Кастомизация Internal Link

Поддержка тёмной темы

Image Chat включает встроенную поддержку тёмной темы. Если вы установите hasDarkBackground: true в вашей конфигурации, окна чата и элементы интерфейса автоматически адаптируются для корректного отображения на тёмном фоне.

FastCommentsImageChat(imageElement, {
    tenantId: 'demo',
    hasDarkBackground: true
});

Стили тёмной темы применяются к окнам чата, маркерам-квадратам и всем интерактивным элементам. Если на вашем сайте есть переключатель тёмной темы, вы можете переинициализировать виджет при смене режима или использовать подход с классом body, описанный ниже.

Динамическая тёмная тема

Если тёмная тема на вашем сайте управляется добавлением класса .dark к элементу body, UI Image Chat автоматически учтёт это без необходимости переинициализации. Стили виджета разработаны так, чтобы реагировать на наличие этого класса.

/* Your dark mode CSS */
body.dark {
    background: #1a1a1a;
    color: #ffffff;
}

Пользовательская стилизация через CSS

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

Квадраты чата и окна используют систему стилизации пузырьков комментариев FastComments, поэтому любые кастомизации, применённые к стандартному виджету комментирования, также повлияют на Image Chat.

Размер квадрата чата

Опция chatSquarePercentage управляет размером кликабельных маркеров. По умолчанию это 5% от ширины изображения:

FastCommentsImageChat(imageElement, {
    tenantId: 'demo',
    chatSquarePercentage: 7  // Крупнее, более заметные квадраты
});

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

Поведение на мобильных устройствах

На экранах шириной менее 768px Image Chat автоматически переключается на макет, оптимизированный для мобильных устройств. Окна чата открываются в полноэкранном режиме, а не плавают рядом с маркерами, обеспечивая лучшую удобопользуемость на маленьких экранах.

Маркеры остаются видимыми в своих адаптивных позициях на изображении. Пользователи могут нажать любой маркер, чтобы открыть полноэкранный интерфейс чата. Это поведение встроено и не требует настройки.

Внешний вид окна чата

Окна чата имеют ширину 300px на десктопе с указателем-стрелкой 16px, указывающей на маркер. Окна позиционируются автоматически в зависимости от доступного пространства в области просмотра, используя классы позиционирования, такие как to-right, to-left, to-top и to-bottom.

Вы можете добавить собственный CSS, чтобы настроить цвета, шрифты, отступы или другие визуальные свойства этих окон. Окна чата используют ту же структуру компонентов, что и стандартный виджет FastComments, поэтому они наследуют любые глобальные кастомизации, которые вы применили.

Ленивная инициализация

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

Ленивая инициализация происходит прозрачно. Пользователи не заметят задержки, но браузеру не нужно рендерить десятки скрытых окон чата, если на изображении много маркеров.

Локализация

Image Chat поддерживает те же параметры локализации, что и стандартный виджет FastComments. Установите опцию locale, чтобы отображать текст интерфейса на разных языках:

FastCommentsImageChat(imageElement, {
    tenantId: 'demo',
    locale: 'fr'  // Французский
});

FastComments поддерживает десятки языков. Параметр locale влияет на весь текст интерфейса, включая подсказки, кнопки и текст-заполнитель.

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

Поскольку Image Chat расширяет стандартный виджет комментирования, он наследует все опции кастомизации базового виджета. Это включает пользовательские CSS-классы, собственные переводы, настройку аватаров, форматирование даты и многое другое.

См. основную документацию по кастомизации FastComments для полного списка доступных опций кастомизации.

Работа с пользовательскими шрифтами

Если на вашем сайте используются пользовательские шрифты, UI Image Chat унаследует эти шрифты из CSS вашей страницы. Окна чата рендерятся внутри DOM вашей страницы и уважительно используют существующие настройки типографики.

Для лучшего результата убедитесь, что пользовательские шрифты загружены до инициализации Image Chat, или примите возможность краткого мигания нестилизованного текста, пока шрифты подгружаются.

Визуальный дизайн маркеров

Квадратные маркеры имеют тонкий визуальный дизайн, который делает их заметными, не перегружая изображение. При желании вы можете настроить их внешний вид через CSS для другого визуального оформления.

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


Синхронизация в реальном времени Internal Link

Real-Time Updates

Image Chat использует WebSocket-соединения для синхронизации всех бесед в режиме реального времени между всеми подключенными пользователями. Когда кто-то создаёт новый маркер, добавляет комментарий или удаляет обсуждение, все остальные пользователи, просматривающие то же изображение, видят обновление мгновенно без перезагрузки.

How WebSocket Sync Works

Когда вы инициализируете Image Chat, виджет устанавливает WebSocket-соединение с серверами FastComments. Это соединение остаётся открытым на протяжении сессии пользователя и прослушивает обновления, связанные с текущим изображением.

Система WebSocket использует три типа широковещательных сообщений для Image Chat. Событие new-image-chat срабатывает, когда кто-то создаёт новый маркер на изображении. Событие image-chat-updated срабатывает, когда кто-то обновляет существующее обсуждение. Событие deleted-image-chat срабатывает, когда кто-то удаляет маркер.

Broadcast ID System

Чтобы предотвратить эффект эха, когда пользователи видят свои собственные действия, транслируемые обратно, каждое обновление включает уникальный broadcastId. Когда пользователь создаёт или обновляет маркер, его клиент генерирует UUID для этой операции. Когда WebSocket транслирует обновление обратно всем клиентам, исходный клиент игнорирует обновление, потому что оно совпадает с его собственным broadcastId.

Это обеспечивает плавное взаимодействие: пользователи видят свои изменения сразу в UI без ожидания кругового обмена через сервер, при этом все остальные пользователи получают обновление.

Connection Resilience

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

После восстановления соединения виджет повторно синхронизируется, чтобы убедиться, что не было пропущено обновлений. Это происходит прозрачно и не требует вмешательства пользователя.

Bandwidth Considerations

Сообщения WebSocket лёгкие и содержат только необходимую информацию для синхронизации состояния. Создание нового маркера обычно использует менее 1KB трафика. Система также включает интеллектуальную группировку сообщений, чтобы снизить частоту сообщений в периоды высокой активности.

Ваша статистика использования в панели FastComments отслеживает pubSubMessageCount и pubSubBandwidth, чтобы вы могли контролировать активность синхронизации в реальном времени на ваших сайтах.

Cross-Tab Synchronization

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

Пользователи могут иметь ваш сайт открытым на нескольких устройствах одновременно, и все они останутся синхронизированными. Маркер, созданный на настольном компьютере, мгновенно появляется на планшете пользователя, если оба устройства просматривают одно и то же изображение.

Security

Сообщения WebSocket передаются по защищённым соединениям (WSS) и включают проверку tenant, чтобы пользователи получали только те обновления, к которым они уполномочены иметь доступ. Сервер проверяет все операции перед их широковещательной отправкой, чтобы предотвратить несанкционированный доступ или манипуляции.

Offline Behavior

Когда пользователи полностью офлайн, они всё ещё могут просматривать существующие маркеры, но не могут создавать новые или видеть обновления от других. Виджет обнаруживает офлайн-состояние и отображает соответствующие сообщения.

Если пользователь пытается создать маркер в офлайне, а затем выходит в онлайн, операция завершится неудачей, а не будет поставлена в очередь, чтобы обеспечить согласованность данных. Пользователям следует повторить операцию, когда соединение будет восстановлено.

Performance Impact

WebSocket-соединение оказывает минимальное влияние на производительность. Соединение остаётся простаивающим, когда обновлений не происходит, и обрабатывает сообщения только при активности. На типичном изображении с умеренной активностью маркеров WebSocket использует меньше CPU, чем отрисовка самого изображения.

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

Collaborative Use Cases

Синхронизация в реальном времени делает Image Chat особенно полезным для совместных рабочих процессов. Команды дизайнеров могут вместе просматривать макеты, при этом все видят размещение маркеров в реальном времени. Команды поддержки клиентов могут совместно аннотировать скриншоты для выявления проблем. Образовательные группы могут обсуждать диаграммы, и все участники видят маркеры друг друга по мере их создания.

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

Есть вопросы?

На этом всё для FastComments Image Chat! Если у вас есть вопросы, нужна помощь с реализацией или есть предложения по функционалу, пожалуйста, сообщите нам ниже или свяжитесь с нашей службой поддержки.

Посмотрите живую демонстрацию на нашей странице демо, чтобы увидеть Image Chat в действии.