찾다
웹 프론트엔드CSS 튜토리얼사용자에게 제어 : 미디어 세션 API를 제공합니다

사용자에게 제어 : 미디어 세션 API를 제공합니다

이것을 상상해보십시오 : 킬러 Kendrick Lamar 트랙은 많은 브라우저 탭 중 하나에서 폭발합니다. 당신은 그루브를하고 있지만 누군가가 들어 와서 일시 중지해야합니다. 어떤 탭? 브라우저는 제한된 도움말을 제공합니다. 모든 오디오를 음소거 할 수도 있지만 직접 제어는 더 나을 수 없습니까?

미디어 세션 API가이를 해결합니다. 재생 탭을 넘어 미디어 재생 컨트롤을 확장하여 다음을 통해 액세스를 제공합니다.

  • 모바일 장치 알림 영역
  • 웨어러블
  • 데스크탑 미디어 허브

또한 미디어 키 및 음성 비서를 사용하여 제어 할 수 있습니다 (Siri, Google Assistant, Bixby, Alexa).

미디어 세션 API 이해

API는 두 인터페이스를 중심으로합니다.

  • MediaMetadata : 미디어 세부 정보 (제목, 앨범, 아트 워크, 아티스트 - Kendrick Lamar,이 예에서)를 제공합니다.
  • MediaSession : 재생 기능을 관리합니다.

구현하기 전에 항상 브라우저 지원을 확인하십시오.

 if (네비게이터의 '미디어 세션') {
  // 미디어 세션 API 코드는 여기에 있습니다
}

MediaMetadata 인터페이스

MediaMetadata.MediaMetadata() MediaMetadata 객체를 만듭니다. 주요 속성에는 다음이 포함됩니다.

  • MediaMetadata.title : 미디어 제목.
  • MediaMetadata.artist Artist : 아티스트 또는 그룹.
  • MediaMetadata.album : 앨범 이름.
  • MediaMetadata.artwork : MediaImage 객체의 배열 (이미지 URL, 크기, 마임 유형).

Kendrick Lamar의 "Alright"의 예 :

 if (네비게이터의 '미디어 세션') {
  navigator.mediasession.metadata = New MediaMetadata ({
    제목 : '좋아요',
    아티스트 : 'Kendrick Lamar',
    앨범 : 'To Pimp a Butterfly',
    작품 : [
      {src : 'https : // mytechnicalarticle/kendrick-lamar/to-pimp-a-butterfly/alright/96x96', 크기 : '96x96', type : 'image/png'},
      {src : 'https : // mytechnicalarticle/kendrick-lamar/to-pimp-a-butterfly/alright/128x128', 크기 : '128x128', type : 'image/png'},
      // 더 많은 크기 추가 (192x192, 256x256 등)
    ]]
  });
}

MediaSession 인터페이스

이 인터페이스는 사용자 재생 컨트롤을 제공합니다.

  • play() : 재생을 시작합니다.
  • pause() : 재생을 일시 중지합니다.
  • previoustrack() : 이전 트랙을 재생합니다.
  • nexttrack() : 다음 트랙을 재생합니다.
  • seekbackward() : 뒤로 추구합니다 (지정된 오프셋으로).
  • seekforward() : 앞으로 추구합니다.
  • seekto() : 특정 시간을 추구합니다.
  • stop() : 재생 중지.
  • skipad() : 건너 뛰기 광고 (구현 세부 사항은 간결하게 생략 됨).

setActionHandler() 이러한 작업에 대해 핸들러를 등록합니다. 플레이/일시 중지 예 :

 let alright = new Audio (); // htmlaudioElement 대신 오디오를 사용합니다

if (네비게이터의 '미디어 세션') {
  navigator.mediasession.setactionHandler ( 'play', () => Alright.Play ());
  navigator.mediasession.setactionHandler ( 'pause', () => allight.pause ());
}

previoustrack , nexttrack , seekbackward , seekforward , seektostop 에서도 비슷한 핸들러가 구현됩니다. seekbackwardseekforward details.seekOffset 있으면 기본 10 초 오프셋을 사용하십시오. seekto 표준과 빠른 추구를 모두 처리합니다. stop 핸들러는 재생 시간을 일시 중지하고 재설정합니다.

각 조치 후 setPositionState() 사용하여 재생 상태를 업데이트해야합니다.

 if (네비게이터의 '미디어 세션') {
  navigator.mediasession.setPositionState ({
    기간 : 알겠습니다.
    Playbackrate : 알겠습니다. Playbackrate,
    위치 : 알겠습니다 .CurrentTime
  });
}

오류 처리는 중요합니다. 랩 setActionHandler try...catch .

오류 처리 및 상태 업데이트를 통합 한 완전한 예는 원본 기사에 제공됩니다. 자리 표시 자 이미지 URL을 실제 URL로 바꾸는 것을 잊지 마십시오. 데모는 다양한 장치와 플랫폼에서 API의 기능을 보여줍니다. 향상된 사용자 경험을 위해 미디어가 풍부한 애플리케이션 에서이 API를 구현하는 것을 고려하십시오.

위 내용은 사용자에게 제어 : 미디어 세션 API를 제공합니다의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
불가능한 문제 해결불가능한 문제 해결May 15, 2025 am 10:32 AM

당신이 결코 생각하지 못한 다른 것으로 판명되는 불가능한 문제 중 하나를 문제 해결하는 것이 어떻게 보이는지.

@keyframes vs CSS 전환 : 차이점은 무엇입니까?@keyframes vs CSS 전환 : 차이점은 무엇입니까?May 14, 2025 am 12:01 AM

@keyframesandcsstransitionsdifferincomplexity :@keyframesallowsfordeTailEdanimationsections, whilecsStransitsimplestateChanges.UsecsStransitionSforHovereffects likeToncolorChanges 및@keyframesforintricateanimationspinners.

정적 사이트 컨텐츠 관리에 페이지 CMS 사용정적 사이트 컨텐츠 관리에 페이지 CMS 사용May 13, 2025 am 09:24 AM

알고 있습니다. 컨텐츠 관리 시스템 옵션이 수많은 톤을 사용할 수 있으며, 여러 번 테스트했지만 실제로는 아무도 없었습니다. y ' 이상한 가격 책정 모델, 어려운 커스터마이즈, 일부는 전체가되었습니다.

HTML의 CSS 파일 연결에 대한 궁극적 인 안내서HTML의 CSS 파일 연결에 대한 궁극적 인 안내서May 13, 2025 am 12:02 AM

HTML의 일부에서 요소를 사용하여 CSS 파일을 HTML에 연결하면 달성 할 수 있습니다. 1) 태그를 사용하여 로컬 CSS 파일을 연결하십시오. 2) 여러 개의 태그를 추가하여 여러 CSS 파일을 구현할 수 있습니다. 3) 외부 CSS 파일은 다음과 같은 절대 URL 링크를 사용합니다. 4) 파일 경로 및 CSS 파일로드 순서의 올바른 사용을 확인하고 성능을 최적화하면 CSS Preprocessor를 사용하여 파일을 병합 할 수 있습니다.

CSS Flexbox vs Grid : 포괄적 인 검토CSS Flexbox vs Grid : 포괄적 인 검토May 12, 2025 am 12:01 AM

Flexbox 또는 그리드 선택은 레이아웃 요구 사항에 따라 다릅니다. 1) Flexbox는 탐색 표시 줄과 같은 1 차원 레이아웃에 적합합니다. 2) 그리드는 매거진 레이아웃과 같은 2 차원 레이아웃에 적합합니다. 두 사람은 프로젝트에 사용하여 레이아웃 효과를 향상시킬 수 있습니다.

CSS 파일 포함 방법 : 방법 및 모범 사례CSS 파일 포함 방법 : 방법 및 모범 사례May 11, 2025 am 12:02 AM

CSS 파일을 포함시키는 가장 좋은 방법은 태그를 사용하여 HTML 부분에 외부 CSS 파일을 소개하는 것입니다. 1. 태그를 사용하여 외부 CSS 파일을 소개합니다. 2. 작은 조정의 경우 인라인 CSS를 사용할 수 있지만주의해서 사용해야합니다. 3. 대규모 프로젝트는 SASS와 같은 CSS 전 처리기를 사용하여 @Import를 통해 다른 CSS 파일을 가져올 수 있습니다. 4. 성능의 경우 CSS 파일을 병합하고 CDN을 사용해야하고 CSSNANO와 같은 도구를 사용하여 압축해야합니다.

Flexbox vs Grid : 둘 다 배워야합니까?Flexbox vs Grid : 둘 다 배워야합니까?May 10, 2025 am 12:01 AM

예, YoushouldLearnbothflexBoxAndgrid.1) FlexBoxisIdealforone-Dimensional, FlexiblelayoutSlikenavigationMenus.2) GridexCelsIntwo-Dimensional, ComplexDesignsSuchasmagazinElayouts.3) 결합 된 BothenSlayoutFlexibility 및 HeartingFortructur

궤도 역학 (또는 CSS 키 프레임 애니메이션을 최적화하는 방법)궤도 역학 (또는 CSS 키 프레임 애니메이션을 최적화하는 방법)May 09, 2025 am 09:57 AM

자신의 코드를 리팩터링하는 것은 어떤 모습입니까? John Rhea는 자신이 쓴 오래된 CSS 애니메이션을 선택하고 최적화하는 사고 과정을 살펴 봅니다.

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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

맨티스BT

맨티스BT

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

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경