웹 카메라 녹화를 브라우저에 로컬로 저장
오늘 우리는 브라우저의 indexedDB에 녹화 후 비디오를 저장할 것입니다.
따라서 이미 존재하는 웹 카메라 녹화 코드Source code부터 시작하겠습니다. 이 프로젝트에 대한 새 브랜치를 만들 것입니다.
이름 짓기 잘하는 거 다 알아!
다음으로 idb-file-storage.js 이라는 새 파일을 만듭니다. 이것은 indexedDB API의 래퍼입니다.
이제 indexedDB.js라는 새 파일을 만들 수 있습니다.
이 파일에서 세 가지 기능을 정의합니다.
-
saveRecordedVideoInDB(recordedpieces, stored_name, blob_name)
녹음된 조각의 배열을 저장하는 기능 -
retreiveVideoFromDB(stored_name)
indexedDB에 저장된 비디오 배열을 반환합니다. -
removeStoredVideo(bloburl, videoname, stored_name)
indexedDB에서 특정 비디오를 제거합니다.
이제 index.html에 indexedDB 스크립트가 포함된 스크립트 태그를 추가합니다.
<script type="module" src="js/indexedDB.js"></script>
마지막으로 index.js를 편집합니다. 녹화가 중지되면 saveRecordedVideoInDB 함수를 호출합니다.
mediarecorder.onstop = ()=>{
window.saveRecordedVideoInDB([recordedChunks],"storedvideos", "videoname" + datetime).then(() => {
download();
})
}
최종 index.html 및 index.js:
index.html:
<script id="gist-ltag"src="https://gist.github.com/EneasLari/7509d0a47c1dd92d823d4d059f7ac148.js?file=index.html"/>
index.js
<script id="gist-ltag"src="https://gist.github.com/EneasLari/7509d0a47c1dd92d823d4d059f7ac148.js?file=index.js"/>
f12 키를 누르고 콘솔 패널에서 Application > Storage > IndexedDb로 이동하면 새 항목이 추가된 것을 볼 수 있습니다.
html에서 검색하거나 삭제하려면 retreiveVideoFromDB 및 removeStoredVideo를 호출하기만 하면 됩니다.
아래에 제공된 소스 코드:
시간 내주셔서 감사합니다.
아래에 질문이나 의견을 남겨주세요.
Reference
이 문제에 관하여(웹 카메라 녹화를 브라우저에 로컬로 저장), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/eneaslari/save-your-web-camera-recording-locally-in-your-browser-10kj텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)