decoder
This commit is contained in:
@ -5,7 +5,7 @@ from .packet import Packet
|
|||||||
from .frame import Frame
|
from .frame import Frame
|
||||||
|
|
||||||
class Decoder:
|
class Decoder:
|
||||||
__slots__ = '_context', '_index'
|
__slots__ = '_context'
|
||||||
|
|
||||||
def __init__(self, stream):
|
def __init__(self, stream):
|
||||||
self._context = libav.codec_alloc_context(stream.codec)
|
self._context = libav.codec_alloc_context(stream.codec)
|
||||||
@ -19,7 +19,6 @@ class Decoder:
|
|||||||
if errcode < 0:
|
if errcode < 0:
|
||||||
libav.codec_free_context(self._context)
|
libav.codec_free_context(self._context)
|
||||||
raise Exception("Failed to open codec context")
|
raise Exception("Failed to open codec context")
|
||||||
self._index = 0
|
|
||||||
|
|
||||||
def __del__(self):
|
def __del__(self):
|
||||||
if self._context:
|
if self._context:
|
||||||
@ -46,3 +45,6 @@ class Decoder:
|
|||||||
errstring = libav.strerror(errcode)
|
errstring = libav.strerror(errcode)
|
||||||
raise Exception(f"Failed to send packet: {errstring}")
|
raise Exception(f"Failed to send packet: {errstring}")
|
||||||
return self._receive()
|
return self._receive()
|
||||||
|
|
||||||
|
def flush(self):
|
||||||
|
return self.decode(None)
|
||||||
|
|||||||
@ -22,6 +22,12 @@ class Demuxer:
|
|||||||
self.video_stream = self._find_stream(libav.AVMEDIA_TYPE_VIDEO)
|
self.video_stream = self._find_stream(libav.AVMEDIA_TYPE_VIDEO)
|
||||||
self.audio_stream = self._find_stream(libav.AVMEDIA_TYPE_AUDIO)
|
self.audio_stream = self._find_stream(libav.AVMEDIA_TYPE_AUDIO)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def nb_streams(self):
|
||||||
|
if not self._context:
|
||||||
|
return 0
|
||||||
|
return self._context.contents.nb_streams
|
||||||
|
|
||||||
def _find_stream(self, type):
|
def _find_stream(self, type):
|
||||||
index, codec_ref = libav.format_find_best_stream(self._context, type)
|
index, codec_ref = libav.format_find_best_stream(self._context, type)
|
||||||
if index < 0 or not codec_ref:
|
if index < 0 or not codec_ref:
|
||||||
|
|||||||
9
pve.py
9
pve.py
@ -5,8 +5,9 @@ from mp4.decoder import Decoder
|
|||||||
|
|
||||||
demuxer = Demuxer('test.mp4')
|
demuxer = Demuxer('test.mp4')
|
||||||
|
|
||||||
print(demuxer.video_stream.codec.name)
|
print(f"nb_streams = {demuxer.nb_streams}")
|
||||||
print(demuxer.audio_stream.codec.name)
|
print(f"video codec = {demuxer.video_stream.codec.name}")
|
||||||
|
print(f"audio codec = {demuxer.audio_stream.codec.name}")
|
||||||
|
|
||||||
video_decoder = Decoder(demuxer.video_stream)
|
video_decoder = Decoder(demuxer.video_stream)
|
||||||
audio_decoder = Decoder(demuxer.audio_stream)
|
audio_decoder = Decoder(demuxer.audio_stream)
|
||||||
@ -26,10 +27,10 @@ while True:
|
|||||||
else:
|
else:
|
||||||
print("unkown packet")
|
print("unkown packet")
|
||||||
|
|
||||||
video_frames = video_decoder.decode(None)
|
video_frames = video_decoder.flush()
|
||||||
print(f"flushed {len(video_frames)} video frames")
|
print(f"flushed {len(video_frames)} video frames")
|
||||||
|
|
||||||
audio_frames = audio_decoder.decode(None)
|
audio_frames = audio_decoder.flush()
|
||||||
print(f"flushed {len(audio_frames)} audio frames")
|
print(f"flushed {len(audio_frames)} audio frames")
|
||||||
|
|
||||||
demuxer.close()
|
demuxer.close()
|
||||||
|
|||||||
Reference in New Issue
Block a user