Recherche avancée

Médias (91)

Autres articles (31)

  • Librairies et binaires spécifiques au traitement vidéo et sonore

    31 janvier 2010, par

    Les logiciels et librairies suivantes sont utilisées par SPIPmotion d’une manière ou d’une autre.
    Binaires obligatoires FFMpeg : encodeur principal, permet de transcoder presque tous les types de fichiers vidéo et sonores dans les formats lisibles sur Internet. CF ce tutoriel pour son installation ; Oggz-tools : outils d’inspection de fichiers ogg ; Mediainfo : récupération d’informations depuis la plupart des formats vidéos et sonores ;
    Binaires complémentaires et facultatifs flvtool2 : (...)

  • Support audio et vidéo HTML5

    10 avril 2011

    MediaSPIP utilise les balises HTML5 video et audio pour la lecture de documents multimedia en profitant des dernières innovations du W3C supportées par les navigateurs modernes.
    Pour les navigateurs plus anciens, le lecteur flash Flowplayer est utilisé.
    Le lecteur HTML5 utilisé a été spécifiquement créé pour MediaSPIP : il est complètement modifiable graphiquement pour correspondre à un thème choisi.
    Ces technologies permettent de distribuer vidéo et son à la fois sur des ordinateurs conventionnels (...)

  • De l’upload à la vidéo finale [version standalone]

    31 janvier 2010, par

    Le chemin d’un document audio ou vidéo dans SPIPMotion est divisé en trois étapes distinctes.
    Upload et récupération d’informations de la vidéo source
    Dans un premier temps, il est nécessaire de créer un article SPIP et de lui joindre le document vidéo "source".
    Au moment où ce document est joint à l’article, deux actions supplémentaires au comportement normal sont exécutées : La récupération des informations techniques des flux audio et video du fichier ; La génération d’une vignette : extraction d’une (...)

Sur d’autres sites (5175)

  • ffmpeg generates "unconnected output" error using -filte_complext [closed]

    25 juillet 2023, par ConiferRod

    I'm trying to combine the rtsp streams of 4 Wyze cameras into a single stream and pipe the result into ffplay (Windows 11). My -filter_complex generates an 'unconnected output' error.

    


    The command :
"C :\Program Files\ffmpeg\ffmpeg.exe" ^
-i rtsp ://user:password@10.0.0.239/live ^
-i rtsp ://user:password@10.0.0.181/live ^
-i rtsp ://user:password@10.0.0.251/live ^
-i rtsp ://user:password@10.0.0.252/live ^
-filter_complex "[0:v][1:v][2:v][3:v]xstack=inputs=4:layout=0_0|w0_0|0_h0|w0_h0[v]" -map '[v]' ^
| "C :\Program Files\ffmpeg\ffplay.exe" -

    


    The error :
[fc#0 @ 000001f45c979d40] Filter xstack:default has an unconnected output
Error : Invalid argument
fd: : Invalid data found when processing input 0KB sq= 0B f=0/0

    


  • avcodec/h264dec : Fix data race when updating decode_error_flags

    12 septembre 2023, par Andreas Rheinhardt
    avcodec/h264dec : Fix data race when updating decode_error_flags
    

    When using multi-threaded decoding, every decoding thread
    has its own DBP consisting of H264Pictures and each of these
    points to its own AVFrames. They are synced during
    update_thread_context via av_frame_ref() and therefore
    the threads actually decoding (as well as all the others)
    must not modify any field that is copied by av_frame_ref()
    after ff_thread_finish_setup().

    Yet this is exactly what happens when an error occurs
    during decoding and the AVFrame's decode_error_flags are updated.
    Given that these errors only become apparent during decoding,
    this can't be set before ff_thread_finish_setup() without
    defeating the point of frame-threading ; in practice,
    this meant that the decoder did not set these flags correctly
    in case frame-threading was in use. (This means that e.g.
    the ffmpeg cli tool fails to output its "corrupt decoded frame"
    message in a nondeterministic fashion.)

    This commit fixes this by adding a new H264Picture field
    that is actually propagated across threads ; the field
    is an AVBufferRef* whose data is an atomic_int ; it is
    atomic in order to allow multiple threads to update it
    concurrently and not to provide synchronization
    between the threads setting the field and the thread
    ultimately returning the AVFrame.

    This unfortunately has the overhead of one allocation
    per H264Picture (both the original one as well as
    creating a reference to an existing one), even in case
    of no errors. In order to mitigate this, an AVBufferPool
    has been used and only if frame-threading is actually
    in use. This expense will be removed as soon as
    a proper API for refcounted objects (not based upon
    AVBuffer) is in place.

    Signed-off-by : Andreas Rheinhardt <andreas.rheinhardt@outlook.com>

    • [DH] libavcodec/h264_picture.c
    • [DH] libavcodec/h264_slice.c
    • [DH] libavcodec/h264dec.c
    • [DH] libavcodec/h264dec.h
  • yt_dlp gives a strange message : "Seek to desired resync point failed. Seeking to earliest point available instead." and "File ended prematurely"

    16 septembre 2023, par nikita goncharov

    I have a discord bot (discord.py) in python and it can play music. Lastly it had trouble in playing the music, giving some random warnings but it mostly worked. But now it gives me this message :

    &#xA;

    [matroska,webm @ 000001570fe92d40] Seek to desired resync point failed. Seeking to earliest point available instead.&#xA;

    &#xA;

    [matroska,webm @ 000001570fe92d40] File ended prematurely&#xA;

    &#xA;

    and also this one

    &#xA;

    Warning: program compiled against libxml 211 using older 209&#xA;

    &#xA;

    As I saw this is a very common warning but I still have no Idea how to fix it.

    &#xA;

    I will leave the code of the bot down bellow :

    &#xA;

    Ytdlp setup (I have renamed the librarie to be youtube_dl)

    &#xA;

    youtube_dl.utils.bug_reports_message = lambda: &#x27;&#x27;&#xA;&#xA;&#xA;ytdl_format_options = {&#xA;    &#x27;format&#x27;: &#x27;bestaudio/best&#x27;,&#xA;    &#x27;outtmpl&#x27;: &#x27;%(extractor)s-%(id)s-%(title)s.%(ext)s&#x27;,&#xA;    &#x27;restrictfilenames&#x27;: True,&#xA;    &#x27;noplaylist&#x27;: True,&#xA;    &#x27;nocheckcertificate&#x27;: True,&#xA;    &#x27;ignoreerrors&#x27;: False,&#xA;    &#x27;logtostderr&#x27;: True,&#xA;    &#x27;quiet&#x27;: True,&#xA;    &#x27;no_warnings&#x27;: False,&#xA;    &#x27;default_search&#x27;: &#x27;auto&#x27;,&#xA;    &#x27;source_address&#x27;: &#x27;0.0.0.0&#x27;,  # bind to ipv4 since ipv6 addresses cause issues sometimes&#xA;}&#xA;&#xA;ffmpeg_options = {&#xA;    &#x27;options&#x27;: &#x27;-vn&#x27;,&#xA;}&#xA;&#xA;ytdl = youtube_dl.YoutubeDL(ytdl_format_options)&#xA;&#xA;&#xA;class YTDLSource(discord.PCMVolumeTransformer):&#xA;    def __init__(self, source, *, data, volume=0.5):&#xA;        super().__init__(source, volume)&#xA;&#xA;        self.data = data&#xA;&#xA;        self.title = data.get(&#x27;title&#x27;)&#xA;        self.url = data.get(&#x27;url&#x27;)&#xA;        self.duration = data.get(&#x27;duration&#x27;)&#xA;        img = ""&#xA;        imgs = [&#x27;&#x27;]&#xA;        for image in data.get("thumbnails"):&#xA;            img = image["url"]&#xA;            imgs.append(image["url"])&#xA;        self.image = img&#xA;        self.thumbnails = imgs&#xA;

    &#xA;

    The play command :

    &#xA;

    # if message.author.voice_client is not None:&#xA;try:&#xA;    print(1)&#xA;    sessionChannel = message.author.voice.channel&#xA;except:&#xA;    embedAns = discord.Embed(color=discord.Color.from_rgb(255, 201, 115))&#xA;    # embedImg.set_image(url=player.image)&#xA;    # embedImg.type = "image"&#xA;    embedAns.add_field(name="Player", value=f&#x27;To play audio you must join a voice channel!&#x27;,&#xA;                       inline=True)&#xA;    embedAns.add_field(name="", value=f&#x27;*{message.author.name}*&#x27;, inline=False)&#xA;    # embedImg.image.width = "800"&#xA;    await message.channel.send(embed=embedAns)&#xA;try:&#xA;    print(2)&#xA;    await message.author.voice.channel.connect(reconnect=False)&#xA;    print(2)&#xA;except:&#xA;    pass&#xA;"""embedAns = discord.Embed(color=discord.Color.from_rgb(102, 196, 250))&#xA;# embedImg.set_image(url=player.image)&#xA;# embedImg.type = "image"&#xA;embedAns.add_field(name="Player", value=f&#x27;Succesfuly joined voice channel to play music in {sessionChannel}! Loading in youtube song... Please wait...&#x27;, inline=True)&#xA;embedAns.add_field(name="", value=f&#x27;*{message.author.name}*&#x27;, inline=False)&#xA;# embedImg.image.width = "800"&#xA;await message.channel.send(embed=embedAns)"""&#xA;try:&#xA;    print(3)&#xA;    load = await message.channel.send(&#xA;        f&#x27;Succesfuly joined voice channel to play music in {sessionChannel}&#x27;)&#xA;    print(4)&#xA;    url = matched.group(1)&#xA;    player = await YTDLSource.from_url(url, loop=client.loop, stream=True)&#xA;    # Embed = await YTDLSource.from_url(url, loop=client.loop, stream=False)&#xA;    sessionChannel.guild.voice_client.play(player, after=lambda e: print(&#xA;        f&#x27;Player error: {e}&#x27;) if e else None)&#xA;    await load.delete()&#xA;    sec = player.duration % 60&#xA;    temp = player.duration // 60&#xA;    min = temp % 60&#xA;    hour = temp // 60&#xA;    if hour == 0:&#xA;        timeStr = f"{min:02d}:{sec:02d}"&#xA;    else:&#xA;        timeStr = f"{hour}:{min:02d}:{sec:02d}"&#xA;    # await message.reply()&#xA;    embedImg = discord.Embed(color=discord.Color.from_rgb(102, 196, 250))&#xA;    # embedImg.set_image(url=player.image)&#xA;    # embedImg.type = "image"&#xA;    embedImg.set_thumbnail(url=player.image)&#xA;    embedImg.add_field(name="Player", value=f&#x27;Now playing: **{player.title}** \n `{timeStr}`&#x27;,&#xA;                       inline=True)&#xA;    embedImg.add_field(name="", value=f&#x27;Requested by: {message.author.name}&#x27;, inline=False)&#xA;    # embedImg.image.width = "800"&#xA;    await message.channel.send(embed=embedImg)&#xA;except Exception as ex:&#xA;    embedAns = discord.Embed(color=discord.Color.from_rgb(255, 119, 115))&#xA;    # embedImg.set_image(url=player.image)&#xA;    # embedImg.type = "image"&#xA;    # embedImg.set_thumbnail(url=player.image)&#xA;    embedAns.add_field(name="Player Error",&#xA;                       value=f&#x27;Couldent play audio on {sessionChannel} \n`{ex}`&#x27;, inline=True)&#xA;    embedAns.add_field(name="", value=f&#x27;Requested by: {message.author.name}&#x27;, inline=False)&#xA;

    &#xA;