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
Money Talks: Using Revenue to Get Sh*t Done
nikkihalliwell
0
250
Rebuilding a faster, lazier Slack
samanthasiow
85
9.5k
Designing for Performance
lara
611
70k
Winning Ecommerce Organic Search in an AI Era - #searchnstuff2025
aleyda
1
2k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
360
30k
The State of eCommerce SEO: How to Win in Today's Products SERPs - #SEOweek
aleyda
2
11k
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
55k
Build your cross-platform service in a week with App Engine
jlugia
234
18k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
35
3.5k
Accessibility Awareness
sabderemane
1
130
How to Ace a Technical Interview
jacobian
281
24k
Measuring Dark Social's Impact On Conversion and Attribution
stephenakadiri
2
210
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]