Recherche avancée

Médias (0)

Mot : - Tags -/médias

Aucun média correspondant à vos critères n’est disponible sur le site.

Autres articles (83)

  • Websites made ​​with MediaSPIP

    2 mai 2011, par

    This page lists some websites based on MediaSPIP.

  • Participer à sa traduction

    10 avril 2011

    Vous pouvez nous aider à améliorer les locutions utilisées dans le logiciel ou à traduire celui-ci dans n’importe qu’elle nouvelle langue permettant sa diffusion à de nouvelles communautés linguistiques.
    Pour ce faire, on utilise l’interface de traduction de SPIP où l’ensemble des modules de langue de MediaSPIP sont à disposition. ll vous suffit de vous inscrire sur la liste de discussion des traducteurs pour demander plus d’informations.
    Actuellement MediaSPIP n’est disponible qu’en français et (...)

  • Creating farms of unique websites

    13 avril 2011, par

    MediaSPIP platforms can be installed as a farm, with a single "core" hosted on a dedicated server and used by multiple websites.
    This allows (among other things) : implementation costs to be shared between several different projects / individuals rapid deployment of multiple unique sites creation of groups of like-minded sites, making it possible to browse media in a more controlled and selective environment than the major "open" (...)

Sur d’autres sites (14556)

  • Can I use the file buffer or stream as input for fluent-ffmpeg ? I am trying to avoid saving the video locally to get its path before removing

    22 avril 2023, par Moath Thawahreh

    I am receiving the file via an api, I was trying to process the file.buffer as input for FFmpeg but it did not work, I had to save the video locally first and then process the path and remove the saved video later on.
I don't want to believe that there is no other way to solve this and I have been looking for solutions and workarounds but it was all about ffmpeg input as a path.

    


    I would love to find a solution using fluent-ffmpeg because it has some other great features, but I won't mind any suggestions for compressing the video using any different approaches if it's more efficient

    


    Again my code below works fine but I have to save the video and then remove it I am hoping for a more efficient solution :

    


      fs.writeFileSync(&#x27;temp.mp4&#x27;, file.buffer);&#xA;&#xA;    // Resize the temporary file using ffmpeg&#xA;    ffmpeg(&#x27;temp.mp4&#x27;) // here I tried pass file.buffer as readable stream,it receives paths only &#xA;      .format(&#x27;mp4&#x27;)&#xA;      .size(&#x27;50%&#x27;)&#xA;      .save(&#x27;resized.mp4&#x27;)&#xA;      .on(&#x27;end&#x27;, async () => {&#xA;        // Upload the resized file to Firebase&#xA;        const resizedFileStream = bucket.file(`video/${uniqueId}`).createWriteStream();&#xA;        fs.createReadStream(&#x27;resized.mp4&#x27;).pipe(resizedFileStream);&#xA;&#xA;        await new Promise<void>((resolve, reject) => {&#xA;          resizedFileStream&#xA;            .on(&#x27;finish&#x27;, () => {&#xA;              // Remove the local files after they have been uploaded&#xA;              fs.unlinkSync(&#x27;temp.mp4&#x27;);&#xA;              fs.unlinkSync(&#x27;resized.mp4&#x27;);&#xA;              resolve();&#xA;            })&#xA;            .on(&#x27;error&#x27;, reject);&#xA;        });&#xA;&#xA;        // Get the URL of the uploaded resized version&#xA;        const resizedFile = bucket.file(`video/${uniqueId}`);&#xA;        const url = await resizedFile.getSignedUrl({&#xA;          action: &#x27;read&#x27;,&#xA;          expires: &#x27;03-17-2025&#x27;, // Change this to a reasonable expiration date&#xA;        });&#xA;&#xA;        console.log(&#x27;Resized file uploaded successfully.&#x27;);&#xA;      })&#xA;      .on(&#x27;error&#x27;, (err) => {&#xA;        console.log(&#x27;An error occurred: &#x27; &#x2B; err.message);&#xA;      });&#xA;</void>

    &#xA;

  • NumPy array of a video changes from the original after writing into the same video

    29 mars 2021, par Rashiq

    I have a video (test.mkv) that I have converted into a 4D NumPy array - (frame, height, width, color_channel). I have even managed to convert that array back into the same video (test_2.mkv) without altering anything. However, after reading this new, test_2.mkv, back into a new NumPy array, the array of the first video is different from the second video's array i.e. their hashes don't match and the numpy.array_equal() function returns false. I have tried using both python-ffmpeg and scikit-video but cannot get the arrays to match.

    &#xA;

    Python-ffmpeg attempt :

    &#xA;

    import ffmpeg&#xA;import numpy as np&#xA;import hashlib&#xA;&#xA;file_name = &#x27;test.mkv&#x27;&#xA;&#xA;# Get video dimensions and framerate&#xA;probe = ffmpeg.probe(file_name)&#xA;video_stream = next((stream for stream in probe[&#x27;streams&#x27;] if stream[&#x27;codec_type&#x27;] == &#x27;video&#x27;), None)&#xA;width = int(video_stream[&#x27;width&#x27;])&#xA;height = int(video_stream[&#x27;height&#x27;])&#xA;frame_rate = video_stream[&#x27;avg_frame_rate&#x27;]&#xA;&#xA;# Read video into buffer&#xA;out, error = (&#xA;    ffmpeg&#xA;        .input(file_name, threads=120)&#xA;        .output("pipe:", format=&#x27;rawvideo&#x27;, pix_fmt=&#x27;rgb24&#x27;)&#xA;        .run(capture_stdout=True)&#xA;)&#xA;&#xA;# Convert video buffer to array&#xA;video = (&#xA;    np&#xA;        .frombuffer(out, np.uint8)&#xA;        .reshape([-1, height, width, 3])&#xA;)&#xA;&#xA;# Convert array to buffer&#xA;video_buffer = (&#xA;    np.ndarray&#xA;        .flatten(video)&#xA;        .tobytes()&#xA;)&#xA;&#xA;# Write buffer back into a video&#xA;process = (&#xA;    ffmpeg&#xA;        .input(&#x27;pipe:&#x27;, format=&#x27;rawvideo&#x27;, s=&#x27;{}x{}&#x27;.format(width, height))&#xA;        .output("test_2.mkv", r=frame_rate)&#xA;        .overwrite_output()&#xA;        .run_async(pipe_stdin=True)&#xA;)&#xA;process.communicate(input=video_buffer)&#xA;&#xA;# Read the newly written video&#xA;out_2, error = (&#xA;    ffmpeg&#xA;        .input("test_2.mkv", threads=40)&#xA;        .output("pipe:", format=&#x27;rawvideo&#x27;, pix_fmt=&#x27;rgb24&#x27;)&#xA;        .run(capture_stdout=True)&#xA;)&#xA;&#xA;# Convert new video into array&#xA;video_2 = (&#xA;    np&#xA;        .frombuffer(out_2, np.uint8)&#xA;        .reshape([-1, height, width, 3])&#xA;)&#xA;&#xA;# Video dimesions change&#xA;print(f&#x27;{video.shape} vs {video_2.shape}&#x27;) # (844, 1080, 608, 3) vs (2025, 1080, 608, 3)&#xA;print(f&#x27;{np.array_equal(video, video_2)}&#x27;) # False&#xA;&#xA;# Hashes don&#x27;t match&#xA;print(hashlib.sha256(bytes(video_2)).digest()) # b&#x27;\x88\x00\xc8\x0ed\x84!\x01\x9e\x08 \xd0U\x9a(\x02\x0b-\xeeA\xecU\xf7\xad0xa\x9e\\\xbck\xc3&#x27;&#xA;print(hashlib.sha256(bytes(video)).digest()) # b&#x27;\x9d\xc1\x07xh\x1b\x04I\xed\x906\xe57\xba\xf3\xf1k\x08\xfa\xf1\xfaM\x9a\xcf\xa9\t8\xf0\xc9\t\xa9\xb7&#x27;&#xA;

    &#xA;

    Scikit-video attempt :

    &#xA;

    import skvideo.io as sk&#xA;import numpy as np&#xA;&#xA;video_data = sk.vread(&#x27;test.mkv&#x27;)&#xA;&#xA;sk.vwrite(&#x27;test_2_ski.mkv&#x27;, video_data)&#xA;&#xA;video_data_2 = sk.vread(&#x27;test_2_ski.mkv&#x27;)&#xA;&#xA;# Dimensions match but...&#xA;print(video_data.shape) # (844, 1080, 608, 3)&#xA;print(video_data_2.shape) # (844, 1080, 608, 3)&#xA;&#xA;# ...array elements don&#x27;t&#xA;print(np.array_equal(video_data, video_data_2)) # False&#xA;&#xA;# Hashes don&#x27;t match either&#xA;print(hashlib.sha256(bytes(video_2)).digest()) # b&#x27;\x8b?]\x8epD:\xd9B\x14\xc7\xba\xect\x15G\xfaRP\xde\xad&amp;EC\x15\xc3\x07\n{a[\x80&#x27;&#xA;print(hashlib.sha256(bytes(video)).digest()) # b&#x27;\x9d\xc1\x07xh\x1b\x04I\xed\x906\xe57\xba\xf3\xf1k\x08\xfa\xf1\xfaM\x9a\xcf\xa9\t8\xf0\xc9\t\xa9\xb7&#x27;&#xA;

    &#xA;

    I don't understand where I'm going wrong and both the respective documentations do not highlight how to do this particular task. Any help is appreciated. Thank you.

    &#xA;

  • Error : Output format mp4 is not available

    12 avril 2024, par alpaca pwaa

    I'm using fluent-ffmpeg in my nextjs application, I'm trying to process the video and specified a format to stream on my s3 bucket but it keeps on failing. My terminal keeps on throwing "Error : Error : Output format mp4 is not available". I already verify my ffmpeg format "ffmpeg -format" and confirm that it supports encoding and decoding mp4 files. I've already tried solutions from other forums but it's not working for me.

    &#xA;

    createVideo: privateProcedure&#xA;    .input(&#xA;      z.object({&#xA;        fileId: z.string(),&#xA;      })&#xA;    )&#xA;    .mutation(async ({ ctx, input }) => {&#xA;      const { getUser } = getKindeServerSession();&#xA;      const user = await getUser();&#xA;&#xA;      if (!user || !user.id || !user.email) {&#xA;        throw new TRPCError({ code: "UNAUTHORIZED" });&#xA;      }&#xA;&#xA;      const dbUser = await db.user.findFirst({&#xA;        where: {&#xA;          id: user.id,&#xA;        },&#xA;      });&#xA;&#xA;      if (!dbUser) {&#xA;        throw new TRPCError({&#xA;          code: "UNAUTHORIZED",&#xA;          message: "User not found in the database.",&#xA;        });&#xA;      }&#xA;&#xA;      const putObjectCommand = new PutObjectCommand({&#xA;        Bucket: process.env.AWS_BUCKET_NAME!,&#xA;        Key: generateFileName(),&#xA;      });&#xA;&#xA;      const s3 = new S3Client({&#xA;        region: process.env.AWS_BUCKET_REGION!,&#xA;        credentials: {&#xA;          accessKeyId: process.env.AWS_ACCESS_KEY!,&#xA;          secretAccessKey: process.env.AWS_SECRET_ACCESS_KEY!,&#xA;        },&#xA;      });&#xA;&#xA;      const singedURL = await getSignedUrl(s3, putObjectCommand, {&#xA;        expiresIn: 60,&#xA;      });&#xA;&#xA;      const ffmpeg = require("fluent-ffmpeg");&#xA;      const passthroughStream = new PassThrough();&#xA;&#xA;      ffmpeg({ source: "./template1.mp4" })&#xA;        .on("end", async () => {&#xA;          console.log("Job done");&#xA;          await uploadToS3(passthroughStream);&#xA;        })&#xA;        .on("error", (error: string) => {&#xA;          console.error("Error:", error);&#xA;          throw new Error("Error processing video");&#xA;        })&#xA;        .videoFilter({&#xA;          filter: "drawtext",&#xA;          options: {&#xA;            text: "hi",&#xA;            fontsize: 24,&#xA;            fontcolor: "white",&#xA;            x: "(w-text_w)/2",&#xA;            y: "(h-text_h)/2",&#xA;            box: 1,&#xA;            boxcolor: "black@0.5",&#xA;            boxborderw: 5,&#xA;            fontfile: "/Windows/fonts/calibri.ttf",&#xA;          },&#xA;        })&#xA;        .videoCodec("libx264")&#xA;        .outputFormat("mp4")&#xA;        .outputOptions(["-movflags frag_keyframe&#x2B;empty_moov"])&#xA;        .pipe(passthroughStream, { end: true });&#xA;&#xA;      const uploadToS3 = async (stream: PassThrough) => {&#xA;        const upload = new Upload({&#xA;          client: s3,&#xA;          params: {&#xA;            Bucket: process.env.AWS_BUCKET_NAME!,&#xA;            Key: generateFileName(),&#xA;            Body: stream,&#xA;          },&#xA;        });&#xA;        await upload.done();&#xA;      };&#xA;&#xA;      await new Promise((resolve, reject) => {&#xA;        passthroughStream.on("end", resolve);&#xA;        passthroughStream.on("error", reject);&#xA;      });&#xA;&#xA;      const createdVideo = await db.video.create({&#xA;        data: {&#xA;          name: "Test Name",&#xA;          url: singedURL.split("?")[0],&#xA;          key: singedURL,&#xA;          fileId: input.fileId,&#xA;        },&#xA;      });&#xA;&#xA;      return createdVideo;&#xA;    }),&#xA;

    &#xA;

    Here's the ffmpeg log.

    &#xA;

    ffmpeg started on 2024-04-11 at 20:58:56&#xA;Report written to "ffmpeg-20240411-205856.log"&#xA;Log level: 48&#xA;Command line:&#xA;"C:\\ProgramData\\chocolatey\\lib\\ffmpeg-full\\tools\\ffmpeg\\bin\\ffmpeg.exe" -i ./template1.mp4 -filter:v "drawtext=text=hi:fontsize=24:fontcolor=white:x=(w-text_w)/2:y=(h-text_h)/2:box=1:boxcolor=black@0.5:boxborderw=5:fontfile=/Windows/fonts/calibri.ttf" -report pipe:1&#xA;ffmpeg version 7.0-full_build-www.gyan.dev Copyright (c) 2000-2024 the FFmpeg developers&#xA;  built with gcc 13.2.0 (Rev5, Built by MSYS2 project)&#xA;  configuration: --enable-gpl --enable-version3 --enable-static --disable-w32threads --disable-autodetect --enable-fontconfig --enable-iconv --enable-gnutls --enable-libxml2 --enable-gmp --enable-bzlib --enable-lzma --enable-libsnappy --enable-zlib --enable-librist --enable-libsrt --enable-libssh --enable-libzmq --enable-avisynth --enable-libbluray --enable-libcaca --enable-sdl2 --enable-libaribb24 --enable-libaribcaption --enable-libdav1d --enable-libdavs2 --enable-libuavs3d --enable-libxevd --enable-libzvbi --enable-librav1e --enable-libsvtav1 --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxavs2 --enable-libxeve --enable-libxvid --enable-libaom --enable-libjxl --enable-libopenjpeg --enable-libvpx --enable-mediafoundation --enable-libass --enable-frei0r --enable-libfreetype --enable-libfribidi --enable-libharfbuzz --enable-liblensfun --enable-libvidstab --enable-libvmaf --enable-libzimg --enable-amf --enable-cuda-llvm --enable-cuvid --enable-dxva2 --enable-d3d11va --enable-d3d12va --enable-f  libavutil      59.  8.100 / 59.  8.100&#xA;  libavcodec     61.  3.100 / 61.  3.100&#xA;  libavformat    61.  1.100 / 61.  1.100&#xA;  libavdevice    61.  1.100 / 61.  1.100&#xA;  libavfilter    10.  1.100 / 10.  1.100&#xA;  libswscale      8.  1.100 /  8.  1.100&#xA;  libswresample   5.  1.100 /  5.  1.100&#xA;  libpostproc    58.  1.100 / 58.  1.100&#xA;Splitting the commandline.&#xA;Reading option &#x27;-i&#x27; ... matched as input url with argument &#x27;./template1.mp4&#x27;.&#xA;Reading option &#x27;-filter:v&#x27; ... matched as option &#x27;filter&#x27; (apply specified filters to audio/video) with argument &#x27;drawtext=text=hi:fontsize=24:fontcolor=white:x=(w-text_w)/2:y=(h-text_h)/2:box=1:boxcolor=black@0.5:boxborderw=5:fontfile=/Windows/fonts/calibri.ttf&#x27;.&#xA;Reading option &#x27;-report&#x27; ... matched as option &#x27;report&#x27; (generate a report) with argument &#x27;1&#x27;.&#xA;Reading option &#x27;pipe:1&#x27; ... matched as output url.&#xA;Finished splitting the commandline.&#xA;Parsing a group of options: global .&#xA;Applying option report (generate a report) with argument 1.&#xA;Successfully parsed a group of options.&#xA;Parsing a group of options: input url ./template1.mp4.&#xA;Successfully parsed a group of options.&#xA;Opening an input file: ./template1.mp4.&#xA;[AVFormatContext @ 00000262cd0888c0] Opening &#x27;./template1.mp4&#x27; for reading&#xA;[file @ 00000262cd0a94c0] Setting default whitelist &#x27;file,crypto,data&#x27;&#xA;[mov,mp4,m4a,3gp,3g2,mj2 @ 00000262cd0888c0] Format mov,mp4,m4a,3gp,3g2,mj2 probed with size=2048 and score=100&#xA;[mov,mp4,m4a,3gp,3g2,mj2 @ 00000262cd0888c0] ISO: File Type Major Brand: isom&#xA;[mov,mp4,m4a,3gp,3g2,mj2 @ 00000262cd0888c0] Unknown dref type 0x206c7275 size 12&#xA;[mov,mp4,m4a,3gp,3g2,mj2 @ 00000262cd0888c0] Processing st: 0, edit list 0 - media time: 1024, duration: 126981&#xA;[mov,mp4,m4a,3gp,3g2,mj2 @ 00000262cd0888c0] Offset DTS by 1024 to make first pts zero.&#xA;[mov,mp4,m4a,3gp,3g2,mj2 @ 00000262cd0888c0] Setting codecpar->delay to 2 for stream st: 0&#xA;[mov,mp4,m4a,3gp,3g2,mj2 @ 00000262cd0888c0] Before avformat_find_stream_info() pos: 6965 bytes read:32768 seeks:0 nb_streams:1&#xA;[h264 @ 00000262cd0bb140] nal_unit_type: 7(SPS), nal_ref_idc: 3&#xA;[h264 @ 00000262cd0bb140] Decoding VUI&#xA;[h264 @ 00000262cd0bb140] nal_unit_type: 8(PPS), nal_ref_idc: 3&#xA;[h264 @ 00000262cd0bb140] nal_unit_type: 7(SPS), nal_ref_idc: 3&#xA;[h264 @ 00000262cd0bb140] Decoding VUI&#xA;[h264 @ 00000262cd0bb140] nal_unit_type: 8(PPS), nal_ref_idc: 3&#xA;[h264 @ 00000262cd0bb140] Decoding VUI&#xA;[h264 @ 00000262cd0bb140] nal_unit_type: 6(SEI), nal_ref_idc: 0&#xA;[h264 @ 00000262cd0bb140] nal_unit_type: 7(SPS), nal_ref_idc: 3&#xA;[h264 @ 00000262cd0bb140] nal_unit_type: 8(PPS), nal_ref_idc: 3&#xA;[h264 @ 00000262cd0bb140] nal_unit_type: 5(IDR), nal_ref_idc: 3&#xA;[h264 @ 00000262cd0bb140] Decoding VUI&#xA;[h264 @ 00000262cd0bb140] Format yuv420p chosen by get_format().&#xA;[h264 @ 00000262cd0bb140] Reinit context to 1088x1920, pix_fmt: yuv420p&#xA;[h264 @ 00000262cd0bb140] no picture &#xA;[mov,mp4,m4a,3gp,3g2,mj2 @ 00000262cd0888c0] All info found&#xA;[mov,mp4,m4a,3gp,3g2,mj2 @ 00000262cd0888c0] After avformat_find_stream_info() pos: 82242 bytes read:82242 seeks:0 frames:1&#xA;Input #0, mov,mp4,m4a,3gp,3g2,mj2, from &#x27;./template1.mp4&#x27;:&#xA;  Metadata:&#xA;    major_brand     : isom&#xA;    minor_version   : 512&#xA;    compatible_brands: isomiso2avc1mp41&#xA;    encoder         : Lavf58.76.100&#xA;  Duration: 00:00:08.27, start: 0.000000, bitrate: 3720 kb/s&#xA;  Stream #0:0[0x1](und), 1, 1/15360: Video: h264 (High) (avc1 / 0x31637661), yuv420p(tv, bt709, progressive), 1080x1920, 3714 kb/s, 30 fps, 30 tbr, 15360 tbn (default)&#xA;      Metadata:&#xA;        handler_name    : VideoHandler&#xA;        vendor_id       : [0][0][0][0]&#xA;Successfully opened the file.&#xA;Parsing a group of options: output url pipe:1.&#xA;Applying option filter:v (apply specified filters to audio/video) with argument drawtext=text=hi:fontsize=24:fontcolor=white:x=(w-text_w)/2:y=(h-text_h)/2:box=1:boxcolor=black@0.5:boxborderw=5:fontfile=/Windows/fonts/calibri.ttf.&#xA;Successfully parsed a group of options.&#xA;Opening an output file: pipe:1.&#xA;[AVFormatContext @ 00000262cd0b2240] Unable to choose an output format for &#x27;pipe:1&#x27;; use a standard extension for the filename or specify the format manually.&#xA;[out#0 @ 00000262cd0bb300] Error initializing the muxer for pipe:1: Invalid argument&#xA;Error opening output file pipe:1.&#xA;Error opening output files: Invalid argument&#xA;[AVIOContext @ 00000262cd0a9580] Statistics: 82242 bytes read, 0 seeks&#xA;

    &#xA;

    I should be able to stream the processed video to my s3, but it keeps on throwing "Error : Error : Output format mp4 is not available"

    &#xA;