Microsoft MVP성태의 닷넷 이야기
ffmpeg 질문 있습니다! [링크 복사], [링크+제목 복사],
조회: 10243
글쓴 사람
주니어
홈페이지
첨부 파일
 

안녕하세요 ffmpeg 관련해서 질문이 있습니다

현재 진행 중인 프로젝트에서 ffmpeg를 랩핑해서 사용하고 있습니다

QA 진행 중에 예상하지 못했던 이슈가 생겼는데 블로그에 ffmpeg 예제를 보고 에러 개선을 해보려다가 실패해서 답답함에 질문드립니다 ㅠ


일단 간단하게 프로젝트에 대해 설명 드리면

여러 개의 카메라 입력과 오디오 입력을 백그라운드에서 계속 캡쳐하고 있습니다

오디오가 빌트인이 된 카메라이든, 오디오 보조 입력 장치가 있든 간에

사용자가 원하는 대로 카메라와 오디오를 선택해서 하나의 영상으로 만들 수 있습니다

일종의 믹서입니다


카메라는 최대 3채널을 입력 받을 수 있으며, 오디오는 최대 5채널입니다(PC + 오디오 보조 입력 장치)


새로운 비디오 프레임, 새로운 오디오 패킷이 발생할 때마다

ConcurrentQueue에 Enqueue시켰고(srcVideoFrameQueue / srcAudioCircularBuffer)

녹화 버튼을 눌렀을 경우에 사전에 정의해둔 비디오와 오디오에 해당되는 새로운 ConcurrentQueue에 dequeue한 데이터를 enqueue하여 FFmpeg에 MediaWriter를 랩핑하여 호출해서 썼습니다


문제는 립싱크입니다

약 0.5초 정도 립싱크가 맞지 않습니다

PTS를 계산해보니 오디오는 제 때 들어가지만 영상이 느리게 들어갑니다


ConcurrentQueue말고 핸들링 방법이 있을까요?


현재로서는 PTS가 맞지 않을 때 비디오 프레임을 누락시켜서 립싱크를 억지로 맞췄는데

더 좋은 개선 방법이 있을지 궁금합니다 ㅠ


소스코드를 올리고 싶지만 불가능해서 부족하지만 이렇게 글로 설명합니다

이해 안되시는 부분이 있으시면 제가 다시 댓글로 설명 드리겠습니다








[최초 등록일: ]
[최종 수정일: 4/15/2022]


비밀번호

댓글 작성자
 



2022-04-15 09시51분
그러니까, 설명한 바에 따르면 비디오 쪽은 ConcurrentQueue를 사용하고 오디오 쪽은 다른 걸 사용하고 있는데, 아무래도 ConcurrentQueue 쪽이 의심된다는 건가요?

0.5초라면 500ms인데 ConcurrentQueue가 그렇게까지 성능이 낮은 자료 구조는 아닐 것입니다. 일례로, 그냥 thread-safe한 Queue 하나를 직접 제작해서 만들더라도 아마 그 문제는 해결되지 않을 거라고 봅니다. 좀 더 근원적인 문제가 있지 않을까요? ^^ 그게 뭔지는 모르겠지만.

참고로, 저도 ffmpeg에 대해서는 완전 초보입니다. ^^ 개인적으로는 아직 비디오와 오디오의 싱크를 맞춰 본 적도 없습니다.
정성태
2022-04-18 03시20분
[주니어] 아닙니다
오디오도 ConcurrentQueue를 이용하고 있습니다

비디오와 오디오에서 새로운 프레임/패킷이 들어올 때마다 pts를 직접 증가시켜 파라미터로 넘겨서 해결했습니다

이전 로직에서는 ffmpeg mediawriter에서 encode 데이터를 넣어줄 때마다 pts를 증가시켰더니 에러가 난 거 같습니다ㅠ
[guest]

... 91  92  93  [94]  95  96  97 
NoWriterDateCnt.TitleFile(s)
111정성태3/19/20059779    답변글 [답변]: 닷넷 프레임워크 배포
107안연준3/17/20059031[-_-]스마트 클라이언트에 관련 된 질문[-_-]
110정성태3/19/20059831    답변글 [답변]: [-_-]스마트 클라이언트에 관련 된 질문[-_-]
116안연준3/21/20059429        답변글 [답변]: 친절한 답변 고맙습니다.
98김용국3/18/200511175정성태님... 연결이 준비됬습니다
99정성태3/2/200512071    답변글 [답변]: 정성태님... 연결이 준비됬습니다
100김용국3/18/20058908        답변글 [답변]: 죄송합니다! 급히올리느라 file path의 변경을 하지않고 그냥올렸네요....!
101정성태3/2/20059162            답변글 [답변]: [답변]: 죄송합니다! 급히올리느라 file path의 변경을 하지않고 그냥올렸네요....!
102김용국3/18/20059231                답변글 [답변]: 거듭죄송하네요..... 후~~~주소를 변경하고 빌드를 다시 했습니다....
103정성태3/2/20059115                    답변글 [답변]: [답변]: 거듭죄송하네요..... 후~~~주소를 변경하고 빌드를 다시 했습니다....
104김용국3/2/20059326                        답변글 [답변]: 네... 빨리 검토해 봐 주셔서 감사합니다~~
105정성태3/2/20058553                            답변글 [답변]: [답변]: 네... 빨리 검토해 봐 주셔서 감사합니다~~
106김용국3/2/20059025                                답변글 [답변]: 답변감사합니다!
91김용국2/28/200510834IE에 WindowsFormControl을 올려 실행하면 이런에러가 나네요???파일 다운로드1
92정성태2/28/200512139    답변글 [답변]: IE에 WindowsFormControl을 올려 실행하면 이런에러가 나네요???
93김용국2/28/200511079        답변글 [답변]: 답변감사합니다... 재질문을 드립니다
94정성태2/28/200511659            답변글 [답변]: [답변]: 답변감사합니다... 재질문을 드립니다
95김용국2/28/200511735                답변글 [답변]: IE주소창에서 해당주소로 실행을 해보니....디버깅 PopUp화면이...^
96정성태2/28/200510789                    답변글 [답변]: [답변]: IE주소창에서 해당주소로 실행을 해보니....디버깅 PopUp화면이...^
97김용국3/1/200511318                        답변글 [답변]: 준비되는데로 말씀드리겠습니다 ^^
88안지환2/22/200512869^^ 사이트 잘 들러보았습니다.
89정성태2/22/200512834    답변글 [답변]: ^^ 사이트 잘 들러보았습니다.
85한기열2/22/200511447정성태님 홈같은 부드러운 페이지 넘김?은 어떻게 구현하나요?
86정성태2/22/200512163    답변글 [답변]: 정성태님 홈같은 부드러운 페이지 넘김?은 어떻게 구현하나요? [2]
84김용국2/21/200512228Smart Client에 관한 문의 드립니다.
87정성태2/22/200512289    답변글 [답변]: Smart Client에 관한 문의 드립니다.
... 91  92  93  [94]  95  96  97