惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Engineering at Meta
Engineering at Meta
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
C
Cyber Attacks, Cyber Crime and Cyber Security
A
Arctic Wolf
Help Net Security
Help Net Security
T
Threatpost
K
Kaspersky official blog
T
Threat Research - Cisco Blogs
C
CERT Recently Published Vulnerability Notes
T
The Exploit Database - CXSecurity.com
Stack Overflow Blog
Stack Overflow Blog
大猫的无限游戏
大猫的无限游戏
J
Java Code Geeks
B
Blog
Latest news
Latest news
爱范儿
爱范儿
G
Google Developers Blog
P
Privacy International News Feed
C
CXSECURITY Database RSS Feed - CXSecurity.com
S
Schneier on Security
H
Help Net Security
aimingoo的专栏
aimingoo的专栏
T
Tenable Blog
S
Securelist
博客园 - 【当耐特】
MongoDB | Blog
MongoDB | Blog
Last Week in AI
Last Week in AI
美团技术团队
P
Proofpoint News Feed
Cisco Talos Blog
Cisco Talos Blog
Know Your Adversary
Know Your Adversary
D
Darknet – Hacking Tools, Hacker News & Cyber Security
Cyberwarzone
Cyberwarzone
C
Cisco Blogs
F
Fortinet All Blogs
L
Lohrmann on Cybersecurity
AWS News Blog
AWS News Blog
P
Privacy & Cybersecurity Law Blog
M
MIT News - Artificial intelligence
G
GRAHAM CLULEY
Simon Willison's Weblog
Simon Willison's Weblog
The Cloudflare Blog
The Register - Security
The Register - Security
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
GbyAI
GbyAI
V
Vulnerabilities – Threatpost
L
LINUX DO - 热门话题
V
Visual Studio Blog
I
InfoQ
阮一峰的网络日志
阮一峰的网络日志

Все публикации подряд на Хабре

Ловим музу за клавиатуру: как айтишнику стать автором Что умеет Midjourney в 2026? Мой немного грустный разбор этого шикарного инструмента Никто не любит писать тесты, но ИИ может исправить это IPv8 выглядит как мечта. Поэтому почти наверняка не взлетит Производители вернули в продажу материнки с DDR3. Что происходит? Управление агентом с телефона через Telegram теперь в KodaCode От координации к лидерству: как меняется роль руководителя разработки Я сделала родителям бизнес вместо пенсии: зарабатываем 70 тысяч, мама не даёт продать В три раза быстрее приемка товара и оптимизация трудозатрат на 73%: как «РСТ-Инвент» помог Gulliver Group ИИ-шечный мир победил? О влиянии искусственного интеллекта на игропром Кремль снижает давление на Телеграмм пока Европа строит интернет по паспорту Как CEO, CTO и CIO за 8 часов собрали ИИ-директора, который умеет держать позицию под давлением Как (не) потерять домен за выходные Вместо 8 разных VPS: как я организовал практику студентам на одном сервере Почему твой Open Source проект не замечают? R&D: искусство управления неопределенностью в разработке AI-дефляция: вакансий для разработчиков больше, а рост зарплат — худший за 15 лет Мы отдали управление роботами OpenClaw. Что из этого вышло Галактический ID: система идентификации для всех форм разумной жизни Шесть основ бизнес-анализа: начинаем с вопроса «Кто в игре?» Код-ревью, в котором дело не в коде Данные переехали. Команда — нет Системной подход к сдаче OSWE в 2025 Почему комната управления реактором покрашена в цвет морской пены 4 YAML-файла вместо PySpark: как аналитикам строить пайплайны без разработчиков LLM-агент для поиска свободных доменов: автоматизируем подбор Когда, зачем и как правильно начинать новую сессию в Claude Code? Как я заставил нейросеть писать макросы для FreeCAD Анатомия ИИ‑агента для подбора персонала. От тысячи резюме к топ‑10 за минуты Опыт разработчика как экономика внимания Автономность как точка невозврата: кто будет субъектом в цифровом будущем Обучение ИИ в «диких» условиях: как рутинные действия превращаются в датасеты Как измерить LLM для задач кибербеза: обзор открытых бенчмарков Где хранить код? Сравнение GitHub, GitLab и Bitbucket Математика объясняет, почему нормальное распределение встречается повсюду Почему ваш FinOps не работает: 12 тезисов от практиков Как подписать проектную документацию УКЭП с использованием бесплатных лицензий Pilot Адаптивное администрирование Sigla Vision Я грузил уран в бочки, а потом 20 лет строил ИТ в атомной отрасли Чем позвонить с Эвереста? История и обзор спутниковой связи. Часть 2 Как языковая модель помогает контролировать качество инструктажей по охране труда в металлургии Как не передать на desktop свой IP в РКН Анатомия SAP Privileges: как устроено управление правами в macOS MoneyDev: Сказка про три главных слова Обновлённый токенизатор видео K-VAE 2.0 от Сбера Как сделать диспетчеризацию дома на 1284 квартиры почти бесплатно Как мы разогнали железную дорогу Мы дали агентам рутину. Теперь надо решить — что делать с освободившимся временем Токсичный контент, промпт-хакинг и защита ИИ — всё о Guardrails для LLM Умный город начинается с точного взгляда: как «Фалькон Тех» меняет пространство к лучшему Навайбкодил приложение для анализа графов Почему Дюну так интересно читать? Упрощаем работу с рутиной или как стать Гендальфом Белым Деконструкция Go: CPU, RAM и что там происходит. Go Assembler база. Часть 1.1 Какие профессии исчезнут из-за ИИ, а какие появятся? И что с этим делать Как мы построили IT-отдел, где хочется расти: архитектурные встречи, прозрачные метрики и книжные подарки Rufler: Делаем из Claude Code автономный рой через один YAML-конфиг Sing-box и белый список приложений Как построить надёжный обмен сообщениями в микросервисах: лучшие практики для enterprise OpenAI строит MLM-пирамиду, а McKinsey и Accenture помогают ей в этом Дом, который не построил Фишер (Часть 2) «Сверхзвуковой математик» против «Вдумчивого логиста»: битва алгоритмов 3D-упаковки Мультимодальные модели – грубый и дорогой инструмент Разговоры ничего не стоят. Код тоже Проверки физических лиц: с кого начнет ФНС Топ-10 бесплатных нейросетей для создания видео в 2026 году Первые слои кода: как наши решения сегодня определяют архитектуру ИИ на десятилетия Разработка нового статического анализатора: PVS-Studio JavaScript Поиск уязвимостей ПО: базовый минимум или роскошный максимум Почему оценка персонала не работает как инструмент управления Как мы разработали ИИ-ассистента и сократили рутину продуктовой команды на 50% Как я ушел из найма, нажарил косточек и продал на маркетплейсах на 168 млн в год Когда 1С:ERP уже внедрена, а нормального производственного плана всё ещё нет Как я сделал Claude мультимодальным, подключив к нему Qwen Omni Как приглашение на вакансию мечты превращается в атаку Infrastructure as Code: философия и лучшие практики IaC Тестируем Yandex Code Assistant на задаче, в которой нужно хранить секреты nxs-universal-chart v3.0: новое поколение универсального Helm-чарта Callback Injection: Техника, которая отправила Microsoft Defender в глухой нокаут «Все идеи на стол»: митап как способ вывести проект из тупика Сегодня я узнал нечто новое о GPU благодаря багу в своей игре Как заставить LLM ̶ ̶г̶а̶л̶л̶ю̶ ̶ эволюционировать Карта событий как фундамент аналитики: практический кейс для E-commerce Что выбрать для AI: x86, ARM или RISC-V? Дайджест железа за март Роль соматических мутаций в развитии аутоиммунных заболеваний: путь к избирательной терапии Mythos от Anthropic — тревожный сигнал для всех, а не только для банков Guardrails для LLM на Java: как приручить промпт‑инъекции и токсичные ответы Green-VLA: как мы собрали VLA-модель для реального антропоморфного робота и не потеряли обобщение Финансовая гонка вооружений: почему умные люди добровольно в ней участвуют Эра ИИ-агентов наступила: выбираем лучшего цифрового сотрудника # Практический опыт внедрения WinCC Redundancy на производственном предприятии Сделал MVP за 3 дня, а потом неделю прикручивал оплату. Оно того стоило? Физика против Маска: почему Starship V3 может оказаться ещё одной катастрофой Нефть Венесуэлы: крупнейшие запасы в мире, но не крупнейшая нефтяная держава JPA 4. Переосмысление Hibernate Почему зеркальная фотокамера Nikon D5 десятилетней давности идеально подошла для миссии «Артемида-2» Проект «Уровень-Спутник» или как мы сделали платформу для гидрологов «Замедлиться, чтобы ускориться»: почему ИИ повышает цену ошибок в требованиях и архитектуре Как с нуля поднять трафик IT-компании на 1657% при бюджете 55 тыс. и выжить Pixel-perfect Downsampling — идеальная отрисовка 50 миллионов точек без потерь
Делаем P2P-кинотеатр: как мы написали десктопное приложение для совместного просмотра видео на Electron
Денис Брель · 2026-06-18 · via Все публикации подряд на Хабре

Средний

4 мин

0

Я разработал десктопное приложение для Windows, которое позволяет смотреть видео вместе с друзьями онлайн. Ключевая возможность — всё одновременно: один участник транслирует экран со звуком системы, и при этом все могут общаться голосом через микрофон и включать свои камеры. Никаких серверов посередине — данные идут напрямую между участниками. В статье расскажу про архитектуру, ключевые технические решения и грабли, на которые мы наступили.

Предыстория

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

Готовых бесплатных решений, которые делают именно это — экран + звук системы + голос поверх + без регистрации — мы не нашли. Решили написать своё.

Выбор технологий

Платформа — Windows. Цель — один портативный .exe, который можно кинуть другу и сразу начать смотреть.

  • Electron 34 — как основа десктопного приложения

  • WebRTC — для передачи видео и аудио напрямую между участниками

  • Socket.IO — для сигналинга (помочь участникам найти друг друга)

  • Сборка — electron-builder, portable.exe

Архитектура P2P-соединения

Участники соединяются напрямую (peer-to-peer). Видео и аудио не проходят через сервер — только напрямую между клиентами. Это даёт минимальную задержку, позволяет не платить за серверную пропускную способность и гарантирует, что ваши данные видит только тот, кому вы их отправили. Никаких облачных серверов, никакой записи разговоров, никаких «корпоративных аккаунтов», куда стекается всё ваше общение.

Архитектура P2P-соединения

Участники соединяются напрямую (peer-to-peer). Видео и аудио не проходят через сервер — только напрямую между клиентами. Это даёт минимальную задержку, позволяет не платить за серверную пропускную способность и гарантирует, что ваши данные видит только тот, кому вы их отправили. Никаких облачных серверов, никакой записи разговоров, никаких «корпоративных аккаунтов», куда стекается всё ваше общение.

A ────── P2P ──────────── Участник B
     │                        │
     └──── P2P ───────────────┘
          │
     Участник C

Сервер нужен только на этапе установки соединения (сигналинг). Мы используем облачный сервер на Render.com и встроенный локальный сервер для работы по LAN.

После того как участники нашли друг друга, все данные идут напрямую. Сервер можно выключить — соединение останется.

Ключевые фичи, которые потребовали нетривиальных решений

Трансляция экрана со звуком системы

WebRTC в браузере не умеет захватывать звук системы при трансляции экрана. Electron даёт доступ к нативному API Chromium — getDisplayMedia с опцией audio: true. Пользователь видит диалог выбора окна, может выбрать свёрнутое окно и включить флажок «Поделиться звуком».

Браузерное ограничение: мобильная версия не может транслировать экран со звуком, только смотреть.

Режим рации (Push-to-Talk)

Мы сделали два режима работы микрофона:

  • Обычный: микрофон включён постоянно

  • Рация: микрофон работает только пока зажата кнопка

В десктоп-версии вход в режим рации — правая кнопка мыши по иконке микрофона. Говорить — зажать Пробел. В мобильной версии — двойной тап по микрофону.

Технически это просто включение/выключение локального трека, но важно было не трогать остальные соединения.

Плавающая панель при трансляции

Когда пользователь начинает транслировать экран, главное окно сворачивается, и появляется маленькое плавающее окно (310×78) с кнопками управления: микрофон, камера, рация, остановка трансляции. Оно всегда поверх других окон.

Рядом открывается окно камер участников (300×220) с превью всех камер и ползунками громкости.

Поддержка двух режимов: локально и через интернет

Приложение работает как через интернет (облачный сервер сигналинга), так и локально по LAN — без доступа в интернет. Это оказалось полезно для корпоративных сетей и мест с плохим интернетом.

Что пошло не так

Некоторые вещи пришлось переделывать по несколько раз:

Выбор окна для трансляции. Первая версия использовала кастомный пикер окон. Он не показывал свёрнутые окна и имел проблемы с обновлением списка. Перешли на нативный диалог Chromium — он показывает все окна, включая свёрнутые, и сам обновляется.

Модалка выбора окна на мобильной версии изначально была в 2 колонки — окна не влезали. Переделали на 3 колонки, стало нормально.

Сборка portable .exe. Electron-builder делает установщик, но нам нужен был один .exe без установки. Потребовалось отдельно собирать portable через --prepackaged.

Windows Defender. Каждая новая сборка с новым именем файла — чтобы не блокировался антивирусом.

Текущее состояние

Приложение работает, (последняя версия 1.8.0)

Три главные ценности, на которых построен продукт:

  1. Всё одновременно. Трансляция экрана со звуком системы + голос по микрофону + видео с камеры — всё это работает одновременно. Не нужно выбирать, чем жертвовать. Один показывает экран, остальные смотрят и комментируют голосом.

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

  3. Рация по пробелу. Режим Push-to-Talk: зажал пробел — говоришь, отпустил — тебя не слышно. Идеально для комментариев во время просмотра, чтобы не шуметь в эфире постоянно.

Полный список возможностей:

  • Трансляция экрана со звуком системы (Windows)

  • Голосовой чат через микрофон

  • Видеозвонок (камера каждого участника)

  • Режим рации Push-to-Talk (зажал пробел — говоришь)

  • До 5 участников в одной P2P-сетке

  • Работает без установки (portable .exe)

  • Без регистрации, без рекламы, без слежения

  • Два языка интерфейса: русский и английский

  • Мобильная версия (PWA) для просмотра с телефона

Весь проект — open source на GitHub.

Ссылки

Иcходный код: https://github.com/outmilker1978/hamsters-theater

Скачать: https://github.com/outmilker1978/hamsters-theater/releases

Сайт проекта: https://tvhamsters.outmilk.online