찾다
웹 프론트엔드CSS 튜토리얼Picture-in-Picture Web API 소개

Picture-in-Picture Web API 소개

2016 년 Safari Browser는 Macos Sierra와 함께 출시되어 처음으로 Picture-in-Picture 기능을 소개했습니다. 이 기능을 통해 사용자는 항상 다른 창 위에있는 작은 부유 식 창에 비디오를 팝업 할 수 있으므로 다른 작업을 수행하면서 비디오를 계속 볼 수 있습니다. 이 아이디어는 텔레비전에서 비롯된 것입니다. 예를 들어, 사용자는 검색 프로그램 목록 또는 기타 채널을 탐색하면서 인기있는 스포츠 이벤트를 계속보고 싶어 할 수 있습니다.

얼마 지나지 않아 Android 8.0이 출시되어 기본 API를 통한 사진 기능을 지원했습니다. 이 기능은 크롬 데스크탑 버전에서 아직 지원되지 않지만 Android의 Chrome 은이 API를 통해 사진 모드에서 비디오를 재생할 수 있습니다.

이로 인해 표준 Picture-in-Picture Web API가 개발되어 웹 사이트 가이 동작을 시작하고 제어 할 수있었습니다.

작성 당시 Chrome (버전 70 이상) 및 Edge (버전 76 이상)만이 기능을 지원합니다. Firefox, Safari 및 Opera는 모두 독점 API를 사용하여 기능을 구현합니다.

이 브라우저는 Caniuse의 데이터를 지원하며 자세한 내용이 포함되어 있습니다. 이 숫자는 브라우저 가이 기능과 이후 버전 에서이 기능을 지원한다는 것을 나타냅니다.

데스크탑

모바일/태블릿

Picture-in-Picture API를 사용하는 방법

웹 페이지에 비디오를 추가하여 시작하겠습니다.

<video controls="" src="video.mp4"></video>

Chrome에는 Picture-in-Picture 모드를 입력하고 종료하기위한 버튼이 이미 있습니다.

Firefox 구현을 테스트하려면 먼저 media.videocontrols.picture-in-picture.enabled 플래그를 사용하여 구성을 마우스 오른쪽 버튼으로 클릭하여 사진을 찍는 옵션을 찾으십시오.

이 효과가 있지만 많은 경우 비디오 컨트롤이 브라우저에서 일관되게되기를 원하며 Picture-in Picture-in Picture 모드로 이동할 수있는 비디오와 할 수없는 비디오를 제어 할 수 있습니다.

Picture-in-Picture Web API를 사용하여 브라우저의 기본 메소드를 교체하여 Picture-in-Picture 모드를 자체 메소드로 입력 할 수 있습니다. 예를 들어 버튼을 추가하고 클릭하여 활성화하겠습니다.

 <button id="pipButton" class="hidden" disabled>Picture-in-Picture 모드를 입력하십시오</button>

그런 다음 JavaScript에서 비디오 및 버튼을 선택하십시오.

 const video = document.getElementById ( '비디오');
const pipbutton = document.getElementById ( 'pipbutton');

기본적으로 버튼은 숨겨져 있고 비활성화됩니다. Picture-in-Picture API가 사용자의 브라우저에서 표시되기 전에 지원되고 활성화되어 있는지 알아야하므로 표시됩니다. 이것은이 기능을 지원하지 않는 브라우저에서 손상된 경험을 피하는 데 도움이되는 점진적인 형태의 향상입니다.

API가 지원되었는지 확인하고 다음과 같이 버튼을 활성화 할 수 있습니다.

 if (문서에서 'pictureInPictureEnabled') {
  pipbutton.classlist.remove ( 'Hidden')
  pipbutton.disabled = false;
}

Picture-in-Picture 모드를 입력하십시오

JavaScript가 브라우저가 Picture-in-Picture 지원을 가능하게했다고 결정했다고 가정합니다. #PipButton으로 버튼을 클릭하면 비디오 요소에서 requestPictureInPicture ()를 호출하겠습니다. 이 메소드는 기본적으로 구문 분석 할 때 화면의 오른쪽 하단에 미니 창에 비디오를 배치하지만 사용자가 이동할 수는 있지만 약속을 반환합니다.

 if (문서에서 'pictureInPictureEnabled') {
  pipbutton.classlist.remove ( 'Hidden')
  pipbutton.disabled = false;

  pipbutton.addeventListener ( 'click', () => {
    video.requestpictureinpicture ();
  });
}

requestPictureInPicture ()가 약속을 반환하고 예를 들어 비디오 메타 데이터가로드되지 않았거나 DisablePictureInPicture 속성이 비디오에 존재하는 경우 약속이 거부 될 수 있기 때문에 위의 코드를 그대로 유지할 수 없습니다.

캐치 블록을 추가 하여이 잠재적 오류를 잡고 사용자에게 무슨 일이 일어나고 있는지 알려주겠습니다.

 pipbutton.addeventListener ( 'click', () => {
  동영상
    .requestPictureInPicture ()
    .catch (error => {
      // 오류 처리});
});

Picture-in-Picture 모드 종료

브라우저는 Picture-in-Picture Window의 닫기 버튼을 상당히 제공하며 클릭하여 창을 닫을 수 있습니다. 그러나 Picture-in-Picture 모드를 종료하는 또 다른 방법을 제공 할 수도 있습니다. 예를 들어, #PipButton을 클릭하면 활성화 된 사진 창을 닫을 수 있습니다.

 pipbutton.addeventListener ( 'click', () => {
  if (document.pictureInpictureElement) {
    문서
      .exitPictureInPicture ()
      .catch (error => {
      // 오류 처리})
  } 또 다른 {
    // 그림의 사진 요청}
});

Picture-in-Picture 창을 닫으려는 또 다른 상황은 비디오가 전체 화면 모드로 들어가는 경우입니다. Chrome은 이미 코드를 쓰지 않고 자동으로 수행합니다.

사진 촬영 이벤트

브라우저를 사용하면 비디오가 P-In-Picture 모드로 들어가거나 떠날 때 감지 할 수 있습니다. P-P 모드에는 입력 또는 종료 방법이 여러 가지가 있기 때문에 미디어 컨트롤 업데이트를 위해 이벤트 감지에 의존하는 것이 가장 좋습니다.

이러한 이벤트는 EnterpictureInpicture 및 LeavePictureInpicture입니다.

이 예에서는 비디오가 현재 P-P 모드인지에 따라 #PipButton 태그를 업데이트해야합니다.

다음은이를 달성하는 데 도움이되는 코드입니다.

 video.addeventListener ( 'EnterPictureInPicture', () => {
  PIPBUTTON.TEXTCONTENT = 'EXIT PICTION-in-PICTURE MODE';
});

video.addeventListener ( 'LeavePictureInPicture', () => {
  pipbutton.textContent = 'Picture-in-Picture 모드를 입력';
});

다음은 데모입니다.

Picture-in-Picture 창을 사용자 정의하십시오

브라우저는 비디오가 MediaStream 객체 (카메라, 비디오 녹화 장치, 화면 공유 서비스 또는 기타 하드웨어 소스와 같은 가상 비디오 소스에서 생성)를 재생하지 않는 한 기본적으로 Picture-in-Picture Window의 재생/일시 정지 버튼을 기본적으로 표시합니다.

Picture-in-Picture 창에서 이전 또는 다음 트랙으로 직접 이동하기 위해 컨트롤을 추가 할 수도 있습니다.

 navigator.mediasession.setactionHandler ( 'previoustrack', () => {
  // 이전 트랙으로 이동});

navigator.mediasession.setactionHandler ( 'NextTrack', () => {
  // 다음 트랙으로 이동});

사진 촬영 창에 웹캠 피드를 표시하십시오

화상 회의 웹 애플리케이션은 사용자가 응용 프로그램과 다른 브라우저 탭 또는 Windows 사이를 전환 할 때 웹캠 피드를 Picture-in Picture 모드에 배치하면 혜택을 볼 수 있습니다.

예는 다음과 같습니다.

비디오에서 사진을 비활성화합니다

그림 창에서 사진에서 비디오가 팝업되기를 원하지 않으면 아래와 같이 DisabledPictureInPicture 속성을 추가 할 수 있습니다.

<video controls="" disablepictureinpicture="" src="video.mp4"></video>

요약

지금은 그게 Picture-in-Picture Web API에 대해 알아야 할 전부입니다! 현재 API는 지원합니다<video></video> 요소이지만 다른 요소로 확장하기위한 것입니다.

브라우저 지원은 이제 들쭉날쭉하지만 웹 사이트 비디오 경험을 점차적으로 향상시키는 방법으로 사용할 수 있습니다.

추가 독서

  • Picture-in-Picture API 사양
  • 사진을 사용하여 비디오를 시청하십시오
  • Picture-in-Picture 예제 (Github의 Google Chrome)

출력은 원본 이미지와 그 형식을 유지합니다. 텍스트는 원래 의미를 유지하면서 흐름과 명확성을 향상시키기 위해 해당 및 재구성되었습니다. 기술 용어는 일관성을 유지합니다.

위 내용은 Picture-in-Picture Web API 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
'Podcast 구독'링크는 어디에서 링크해야합니까?'Podcast 구독'링크는 어디에서 링크해야합니까?Apr 16, 2025 pm 12:04 PM

한동안 iTunes는 팟 캐스팅에서 큰 개 였으므로 "Podcast 구독"을 링크 한 경우 다음과 같습니다.

브라우저 엔진 다양성브라우저 엔진 다양성Apr 16, 2025 pm 12:02 PM

우리는 그들이 2013 년에 크롬에 갔을 때 오페라를 잃었습니다. 올해 초 크롬 (Chrome)에 갔을 때 Edge와 같은 거래를했습니다. Mike Taylor는 이러한 변화를 "감소 적으로"불렀습니다

웹 공유에 대한 UX 고려 사항웹 공유에 대한 UX 고려 사항Apr 16, 2025 am 11:59 AM

Trashy Clickbait 사이트에서 가장 8 월 출판물에 이르기까지 공유 버튼은 웹 전체에서 오랫동안 어디서 유비쿼터스되었습니다. 그럼에도 불구하고 이것들은 논쟁의 여지가 있습니다

Weekly Platform News : Apple은 웹 구성 요소, 프로그레시브 HTML 렌더링, 자체 호스팅 중요한 리소스를 배포합니다.Weekly Platform News : Apple은 웹 구성 요소, 프로그레시브 HTML 렌더링, 자체 호스팅 중요한 리소스를 배포합니다.Apr 16, 2025 am 11:55 AM

이번 주에 Apple은 웹 구성 요소, Instagram이 Insta-Loading 스크립트의 방법 및 자조적 자체 호스팅 리소스를 생각하기위한 음식을 웹 구성 요소에 들어갑니다.

Git Pathspecs 및 사용 방법Git Pathspecs 및 사용 방법Apr 16, 2025 am 11:53 AM

GIT 명령의 문서를 살펴 보았을 때 많은 사람들이 옵션이 있음을 알았습니다. 나는 처음에 이것이 단지 a라고 생각했다

제품 이미지를위한 컬러 피커제품 이미지를위한 컬러 피커Apr 16, 2025 am 11:49 AM

어려운 문제가 어려운 것 같지 않습니다. 우리는 종종 수천 가지 색상의 제품 샷을 가지고 있으므로 우리는 다음과 같이 뒤집을 수 있습니다. 우리도 아닙니다

Dark Mode는 React 및 Temprovider로 전환합니다Dark Mode는 React 및 Temprovider로 전환합니다Apr 16, 2025 am 11:46 AM

웹 사이트에 어두운 모드 옵션이있을 때 좋아합니다. 다크 모드는 웹 페이지를 더 쉽게 읽을 수있게하고 눈이 더 편안하다고 느끼도록 도와줍니다. 많은 웹 사이트를 포함합니다

HTML 대화 요소와 함께 일부 실습HTML 대화 요소와 함께 일부 실습Apr 16, 2025 am 11:33 AM

이것은 처음으로 HTML 요소를보고 있습니다. 나는 그것을 잠시 동안 알고 있었지만 아직 스핀을 위해 그것을 가져 갔다. 그것은 꽤 시원하고 있습니다

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경