webrtc视频流设置码率和分辨率

浏览器进行webrtc推流的时候,有时候需要保证视频清晰度,那就需要设置视频推送时的码率以及分辨率,下面是设置码率和分辨率的方法

设置码率

获取peerConnection的senders,遍历senders中获取类型为video的sender,通过setParameters设置sender的params就能操控码率:params.encodings0.maxBitrate = 1024 * 1024 * 10; // 设置码率为10MB

js 复制代码
const video = document.createElement('video');
video.crossOrigin = 'anonymous';
video.src = '视频地址';
video.muted = true; // 静音才能实现自动播放
video.preload = 'auto';
video.loop = true;

video.onloadedmetadata = () => {
  let stream = null;
  try {
    stream = video.captureStream();
    console.log('音视频流', stream);

    // 创建webrtc
    const peerConnection = new RTCPeerConnection(null);

    stream.getTracks().forEach((track) => {
      peerConnection.addTrack(track, stream);
    });

    const senders = peerConnection.getSenders();

    // 遍历每个 sender
    senders.forEach(async (sender) => {
      // 找到视频的 sender
      if (sender && sender.track.kind === 'video') {
        const params = sender.getParameters();
        params.encodings[0].maxBitrate = 1024 * 1024 * 10; // 设置码率为10MB
        await sender.setParameters(params);
      }
    });
  } catch (error) {}
};

设置分辨率

设置分辨率只用操作视频流的宽高就能设置分辨率

我们可以通过操作源流的分辨率,或者通过canvas重新调整视频流的宽高

如:视频流只有1280*720,想要调整为1920*1080的分辨率

1.创建一个canvas,设置宽高为1920*1080

2.通过requestAnimationFrame和ctx.drawImage(video, 0, 0, 1920, 1080)将视频帧绘制到canvas上

js 复制代码
const video = document.createElement('video');
video.crossOrigin = 'anonymous';
video.src = '视频地址';
video.muted = true; // 静音才能实现自动播放
video.preload = 'auto';
video.loop = true;

...
// 绘制视频帧
ctx = canvas.getContext("2d");
ctx.drawImage(video, 0, 0, 1920, 1080)

3.获取canvas的流stream:video.captureStream

获取到是stream就是调整后分辨率为1920*1080的流

相关推荐
IT_陈寒1 天前
SpringBoot这个自动配置坑我跳了三次
前端·人工智能·后端
kyriewen1 天前
我用 AI 一周写完了整个项目,上线第一天就崩了——这是我踩过最贵的 5 个坑
前端·javascript·ai编程
牧艺1 天前
从零到协同:构建类飞书在线文档系统的五个技术重难点
前端·人工智能
红尘散仙1 天前
想写一个像样的终端 App?试试把 React 的开发体验搬进 Rust TUI
前端·rust
袋鼠云数栈UED团队1 天前
一套 Spec-First 的 AI 编程工作流
前端·人工智能
袋鼠云数栈前端1 天前
一套 Spec-First 的 AI 编程工作流
前端·ai+
angerdream1 天前
Android手把手编写儿童手机远程监控App之vue3 路由守卫
前端
不服老的小黑哥1 天前
AI规范驱动编程-harness工程项目实战
前端
vivo互联网技术1 天前
从 Web 到桌面:基于 Tauri 2.0 + Vue 3 打造 vivo 线下门店「大头贴」拍照体验系统
前端·rust
光影少年1 天前
React 合成事件机制、和原生事件区别、事件冒泡阻止
前端·react.js·掘金·金石计划