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
Large-scale JavaScript Application Architecture
addyosmani
515
110k
jQuery: Nuts, Bolts and Bling
dougneiner
66
8.5k
30 Presentation Tips
portentint
PRO
1
320
Scaling GitHub
holman
464
140k
Code Reviewing Like a Champion
maltzj
528
40k
Navigating Algorithm Shifts & AI Overviews - #SMXNext
aleyda
1
1.3k
How to Talk to Developers About Accessibility
jct
2
230
Done Done
chrislema
186
16k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
17k
4 Signs Your Business is Dying
shpigford
187
22k
The Psychology of Web Performance [Beyond Tellerrand 2023]
tammyeverts
49
3.5k
Distributed Sagas: A Protocol for Coordinating Microservices
caitiem20
333
22k
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]