Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
InsertableStreams
Search
Polina Gurtovaya
December 04, 2021
120
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
InsertableStreams
Polina Gurtovaya
December 04, 2021
More Decks by Polina Gurtovaya
See All by Polina Gurtovaya
Не учите алгоритмы
hellsquirrel
1
1k
Давайте все заблокируем
hellsquirrel
0
360
Wasmысле?
hellsquirrel
0
270
Магия декларативныx схем.
hellsquirrel
0
390
ML for HolyJS
hellsquirrel
0
190
Идеальный способ заблюрить белочку
hellsquirrel
0
190
ML/DL на фронте
hellsquirrel
0
240
WebRTC-404
hellsquirrel
0
570
Давайте декодируем кодеки
hellsquirrel
0
620
Featured
See All Featured
Noah Learner - AI + Me: how we built a GSC Bulk Export data pipeline
techseoconnect
PRO
0
190
Are puppies a ranking factor?
jonoalderson
1
3.5k
世界の人気アプリ100個を分析して見えたペイウォール設計の心得
akihiro_kokubo
PRO
71
40k
A Tale of Four Properties
chriscoyier
163
24k
How Fast Is Fast Enough? [PerfNow 2025]
tammyeverts
3
600
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
17k
What’s in a name? Adding method to the madness
productmarketing
PRO
24
4.1k
Connecting the Dots Between Site Speed, User Experience & Your Business [WebExpo 2025]
tammyeverts
11
940
GraphQLとの向き合い方2022年版
quramy
50
15k
The innovator’s Mindset - Leading Through an Era of Exponential Change - McGill University 2025
jdejongh
PRO
1
190
Have SEOs Ruined the Internet? - User Awareness of SEO in 2025
akashhashmi
0
360
Claude Code のすすめ
schroneko
67
230k
Transcript
Смешные шапочки на Insertable Streams
Начнем с WebRTC…
Пересылаем видео, аудио, файлики, скриншару Challenge В условиях Лагающего интернета
Злых админов, настроивших fi rewall Между Большим количеством участников С разными приоритетами 🧟🧟🧟
None
Как работает WebRTC new RTCPeerConnection(…) new RTCPeerConnection(…) 🦄
Media: SRTP + SRTCP Data: SCTP Шифрование Работает поверх UDP→быстрее
Можно терять пакеты, если нужно Не гарантирует порядок Bundling DTLS: TLS для UDP
Как выглядит пожатое видео?
Compression: intra & inter
Intraframe compression (AV1)
Какие кодеки поддерживает ваш браузер?
Чего-то не хватает….
None
Streams 101
None
None
None
None
Insertable-streams const stream = await getUserMedia({ video: true }); const
track = stream.getVideoTracks()[0]; const processor = new MediaStreamTrackProcessor({ track }); const generator = new MediaStreamTrackGenerator({ kind: 'video' }); const transformer = new TransformStream({ async transform(frame, controller) { const newFrame = processFrameSomehow(frame); videoFrame.close(); controller.enqueue(newFrame); }, }); trackProcessor.readable.pipeThrough(transformer).pipeTo(trackGenerator.writable);
Как же нарисовать ?
Нам нужна нейронка :)
Находим точки одевания шапочки Выбираем бекенд •WebAssembly •WebGL •WebGPU Находим
нужную модель или грузим свою • Лучше использовать Lite (Mobile) варианты Закидываем в модель пиксели •getImageData •VideoDecoder.decode Запускаем модель и получаем результат
Рисуем const silhouette = predictions[0].annotations.silhouette const slice = [silhouette[silhouette.length -
4], silhouette[0], silhouette[4]] const hatW = slice[2][0] - slice[0][0] const hatH = hatW * ratio ctx.drawImage(image, slice[0][0] + 0.2 * hatW, slice[0][1] - 0.8 * hatH, hatW, hatH)
Крафтим новый поток const transformer = new TransformStream({ async transform(frame,
controller) { // ... const newFrame = new VideoFrame(canvas, { timestamp: frame.timestamp }) controller.enqueue(newFrame) frame.close() }}) trackProcessor.readable.pipeThrough(transformer).pipeTo(trackGenerator.writable) const transformedStream = new MediaStream([trackGenerator])
None
Что еще можно делать? • Encryption • Analytics • Transcoding
(VideoEncoder) • Frame rate change
@polina_gurtovaya @pgurtovaya @evilmartians @evilmartians_ru evilmartians.com Спасибо!
[email protected]