From 7836f2e47f8895e49d1e3fcbc96b9ff638c88600 Mon Sep 17 00:00:00 2001 From: seydx Date: Tue, 11 Mar 2025 01:50:41 +0100 Subject: [PATCH] check h265 --- www/video-rtc.js | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/www/video-rtc.js b/www/video-rtc.js index fb872b45..518e242f 100644 --- a/www/video-rtc.js +++ b/www/video-rtc.js @@ -583,7 +583,7 @@ export class VideoRTC extends HTMLElement { if (stream.getVideoTracks().length > 0) rtcPriority += 0x220; if (stream.getAudioTracks().length > 0) rtcPriority += 0x102; - if (this.mseCodecs.indexOf('hvc1.') >= 0) msePriority += 0x230; + if (this.mseCodecs.indexOf('hvc1.') >= 0 && !VideoRTC.isH265Supported()) msePriority += 0x230; if (this.mseCodecs.indexOf('avc1.') >= 0) msePriority += 0x210; if (this.mseCodecs.indexOf('mp4a.') >= 0) msePriority += 0x101; @@ -664,6 +664,23 @@ export class VideoRTC extends HTMLElement { this.send({type: 'mp4', value: this.codecs(this.video.canPlayType)}); } + static isH265Supported() { + try { + const videoCodecs = RTCRtpSender?.getCapabilities('video')?.codecs; + + if (!videoCodecs) { + return false; + } + + return videoCodecs.some(codec => + codec.mimeType.toLowerCase().includes('h265') || + codec.mimeType.toLowerCase().includes('hevc') + ); + } catch { + return false; + } + } + static btoa(buffer) { const bytes = new Uint8Array(buffer); const len = bytes.byteLength;