readFrame
다음 비디오 프레임 읽기
설명
예제
샘플 비디오 파일 xylophone_video.mp4에 대한 VideoReader 객체를 만듭니다.
v = VideoReader("xylophone_video.mp4");비디오에서 모든 프레임을 한 번에 한 프레임씩 읽습니다.
while hasFrame(v) frame = readFrame(v); end
readFrame에서 반환되는 마지막 프레임에 대한 정보를 표시합니다.
whos frameName Size Bytes Class Attributes frame 240x320x3 230400 uint8
VideoReader 객체를 지웁니다.
clear v샘플 비디오 파일 xylophone_video.mp4에 대한 VideoReader 객체를 만듭니다.
v = VideoReader("xylophone_video.mp4");비디오 시작부터 2.5초 후에 프레임 읽어오기가 시작되도록 지정합니다.
v.CurrentTime = 2.5;
프레임을 표시하기 위한 axes 객체를 만듭니다. 그런 다음 읽을 수 있는 프레임이 더 없을 때까지 계속 비디오 프레임을 읽고 표시합니다.
currAxes = axes; while hasFrame(v) vidFrame = readFrame(v); image(vidFrame,"Parent",currAxes) currAxes.Visible = "off"; pause(1/v.FrameRate) end


VideoReader 객체를 지웁니다.
clear v샘플 비디오 파일 xylophone_video.mp4에 대한 VideoReader 객체를 만듭니다. 그런 다음 비디오의 너비와 높이를 확인합니다.
xyloObj = VideoReader("xylophone_video.mp4");
vidWidth = xyloObj.Width;
vidHeight = xyloObj.Height;비디오 구조체형 배열을 만듭니다.
mov = struct("cdata",zeros(vidHeight,vidWidth,3,"uint8"),colormap=[]);
비디오의 끝까지 한 번에 한 프레임씩 읽어옵니다.
k = 1; while hasFrame(xyloObj) mov(k).cdata = readFrame(xyloObj); k = k+1; end
비디오의 너비와 높이에 기반하여 Figure 크기를 정한 다음 비디오를 한 번 재생합니다.
vf = figure(Position=[0 0 xyloObj.Width xyloObj.Height]);
imshow(mov(1).cdata,Border="tight")
movie(vf,mov,1,xyloObj.FrameRate)
VideoReader 객체를 지웁니다.
clear xyloObj입력 인수
입력 VideoReader 객체입니다. VideoReader 함수를 사용하여 비디오 파일에서 VideoReader 객체를 만듭니다.
출력 인수
비디오 프레임 데이터로, 배열로 반환됩니다. video의 차원과 데이터형은 obj의 VideoFormat 속성에 따라 달라집니다.
다음 표에서 대부분의 파일에 대한 video의 데이터형과 차원을 나열합니다. H는 이미지 프레임 높이이고 W는 이미지 프레임 너비입니다. obj의 VideoFormat 속성이 'Indexed'일 때 video의 데이터형과 차원은 readFrame을 'native' 인수와 함께 호출하는지에 따라 달라집니다.
obj.VideoFormat의 값 | video의 데이터형 | video의 차원 | 설명 |
|---|---|---|---|
'RGB24'('native'를 지정하거나 지정하지 않음) | uint8 |
| RGB24 이미지 |
'Grayscale'('native'를 지정하지 않음) | uint8 |
| 회색조 이미지 |
'Indexed'('native'를 지정하지 않음) | uint8 |
| RGB24 이미지 |
'Grayscale' 또는 'Indexed'('native'를 지정함) | struct | 1×1 | 각각 |
Motion JPEG 2000 파일의 경우, video의 데이터형과 차원은 다음과 같습니다.
obj.VideoFormat의 값 | video의 데이터형 | video의 차원 | 설명 |
|---|---|---|---|
'Mono8' | uint8 |
| 단색 이미지 |
'Mono8 Signed' | int8 |
| 단색의 부호 있는 이미지 |
'Mono16' | uint16 |
| 단색 이미지 |
'Mono16 Signed' | int16 |
| 단색의 부호 있는 이미지 |
'RGB24' | uint8 |
| RGB24 이미지 |
'RGB24 Signed' | int8 |
| RGB24의 부호 있는 이미지 |
'RGB48' | uint16 |
| RGB48 이미지 |
'RGB48 Signed' | int16 |
| RGB48의 부호 있는 이미지 |
제한 사항
Windows®에서 일부 AVI, MOV 또는 MP4 파일의 경우,
readFrame함수를 사용하여 파일의 모든 프레임을 읽어 들이면VideoReader객체의NumFrames속성에서 반환된 값과 다른 개수의 프레임이 생성될 수 있습니다.
확장 기능
사용법 관련 참고 및 제한 사항:
readFrame에 대한 코드 생성 시 선택적 위치 인수native는 지원되지 않습니다.행 우선 레이아웃을 사용하는 코드 생성 — Generate Code That Uses Row-Major Array Layout (MATLAB Coder).
배열 크기 제한 — 코드 생성 시 배열의 최대 요소 개수는 코드 생성기와 타깃 하드웨어에 의해 제한됩니다. 자세한 내용은 Array Size Restrictions for Code Generation (MATLAB Coder) 항목을 참조하십시오.
버전 내역
R2014b에 개발됨
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
웹사이트 선택
번역된 콘텐츠를 보고 지역별 이벤트와 혜택을 살펴보려면 웹사이트를 선택하십시오. 현재 계신 지역에 따라 다음 웹사이트를 권장합니다:
또한 다음 목록에서 웹사이트를 선택하실 수도 있습니다.
사이트 성능 최적화 방법
최고의 사이트 성능을 위해 중국 사이트(중국어 또는 영어)를 선택하십시오. 현재 계신 지역에서는 다른 국가의 MathWorks 사이트 방문이 최적화되지 않았습니다.
미주
- América Latina (Español)
- Canada (English)
- United States (English)
유럽
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)