Recherche avancée

Médias (2)

Mot : - Tags -/doc2img

Autres articles (55)

  • 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 (...)

  • Publier sur MédiaSpip

    13 juin 2013

    Puis-je poster des contenus à partir d’une tablette Ipad ?
    Oui, si votre Médiaspip installé est à la version 0.2 ou supérieure. Contacter au besoin l’administrateur de votre MédiaSpip pour le savoir

  • Ajouter notes et légendes aux images

    7 février 2011, par

    Pour pouvoir ajouter notes et légendes aux images, la première étape est d’installer le plugin "Légendes".
    Une fois le plugin activé, vous pouvez le configurer dans l’espace de configuration afin de modifier les droits de création / modification et de suppression des notes. Par défaut seuls les administrateurs du site peuvent ajouter des notes aux images.
    Modification lors de l’ajout d’un média
    Lors de l’ajout d’un média de type "image" un nouveau bouton apparait au dessus de la prévisualisation (...)

Sur d’autres sites (7322)

  • Anomalie #3362 (Nouveau) : Erreur de syntaxe CSS du style embarqué

    9 décembre 2014, par Fred Barboteu

    Ligne 139 dans ajaxCallback.js (SPIP 3.0.14) :
    ...

    ...
    Il manque les "px" sur left et top : provoque l’affichage d’une erreur CSS, et l’absence d’effet du positionnement souhaité.

  • Meteor Spawn_Child_Process for FFMpeg [duplicate]

    2 mars 2013, par user2009114

    Hi I am trying to use Meteor and javascript (Node) to spawn an ffmpeg transcoding event and then stream it live through HTML5 video tags. However, though I can get it working with node.js it seems to hang on the Meteor server and not stream anything though it does seem to be transcoding okay. It appears that the transcoding thread hangs up the server, or is not even a different thread at all ? I am pasting the relevant server side code followed by the client code calling it. One JQuery function calls the transcoding process and the PollForPlaylist is called from the video tags by the hls/. Any help would be much appreciated in solving this. I am wondering if there is a meteor function which I can call to spawn a thread for the ffmpeg function ? Or maybe there is another way to push data to the video tag through jQuery ?

    var spawnNewProcess = function(file, playlistPath) {
       var outputUrlPrefix = '/segment/';
       var args = ['-i', file, '-async', '1', '-acodec', 'libmp3lame', '-b:a', 128 + 'k', '-vf', 'scale=min(' + targetWidth + '\\, iw):-1', '-b:v', videoBitrate + 'k', '-ar', '44100', '-ac', '2', '-vcodec', 'libx264', '-x264opts', 'level=3.0', '-profile:v', 'baseline', '-preset:v' ,'superfast', '-threads', '0', '-flags', '-global_header', '-map', '0', '-f', 'segment', '-segment_time', '10', '-segment_list', 'stream.m3u8', '-segment_format', 'mpegts', '-segment_list_flags', 'live', 'stream%05d.ts'];

       var encoderChild = childProcess.spawn(transcoderPath, args, {cwd: outputPath});

       console.log(transcoderPath + args);

       encoderProcesses[file] = encoderChild;
       currentFile = file;

       console.log('Spawned transcoder instance');

       if (debug) {
           encoderChild.stderr.on('data', function(data) {
               console.log(data.toString());
           });
       }

       encoderChild.on('exit', function(code) {
           console.log('Transcoder exited with code ' + code);

           delete encoderProcesses[file];
       });

       // Kill any "zombie" processes
       setTimeout(function() {
           if (encoderProcesses[file]) {
               console.log('Killing long running process');

               killProcess(encoderProcesses[file]);
           }
       }, processCleanupTimeout);
    };

    var pollForPlaylist = function(file, response) {
       var numTries = 0;
       console.log("IN POLL FOR PLAYLIST");

       var tryOpenFile = function() {
           if (numTries > 20) {
               console.log('Gave up trying to open m3u8 file');
               response.writeHead(500);
               response.end();
           }
           else {
               console.log("IN ELSE");
               fs.readFile(playlistPath, function (err, data) {
                   console.log("Trying to read file");
                   if (err || data.length === 0) {
                       numTries++;
                       setTimeout(tryOpenFile, 200);
                       console.log("ERROR, number of tries", numTries);
                   }
                   else {
                       if (!debug) {
                           response.setHeader('Content-Type', 'application/x-mpegURL');
                       }
                       console.log('response: ' + data);
                       response.write(data);
                       response.end();
                   }
               });
           }
       };
           console.log("Try open");
           tryOpenFile();
    };

    var killProcess = function(processToKill, callback) {
       processToKill.kill();

       setTimeout(function() {
           processToKill.kill('SIGKILL');
       }, 5000);

       processToKill.on('exit', function(code) {
           if (callback) callback();
       });
    }

    var handlePlaylistRequest = function(file, request, response) {
       if (!file) {
           request.writeHead(400);
           request.end();
       }

       if (lock) {
           console.log('Ongoing spawn process not finished, denying request');
           response.writeHead(503);
           response.end();
           return;
       }

       file = path.join('/', file); // Remove ".." etc
       file = path.join(rootPath, file);

       console.log("PLAYLIST PATH", playlistPath);
       if (currentFile != file) {
           lock = true;

           console.log('New file to encode chosen');

           // Make sure old one gets killed
           if (encoderProcesses[currentFile]) {
               killProcess(encoderProcesses[currentFile], function() {
                   fs.unlink(playlistPath, function (err) {
                       spawnNewProcess(file, playlistPath, outputPath);
                       lock = false;
                   });
               });
           }
           else {
               fs.unlink(playlistPath, function (err) {
                   spawnNewProcess(file, playlistPath, outputPath);
                   lock = false;
               });
           }
           currentFile = file;
       }
    };

    The Client side code which calls this is :

    var videoNode = document.querySelector('video');
    $.get('hls/?file='+file);
    videoNode.src = "hls/" + file;
  • What kind of stream GStreamer produce ?

    16 novembre 2014, par Max

    I use following 2 commands to stream video from Raspberry Pi

    RaPi

    raspivid -t 999999 -h 720 -w 1080 -fps 25 -hf -b 2000000 -o - | gst-launch-1.0 -v fdsrc ! h264parse !  rtph264pay config-interval=1 pt=96 ! gdppay ! tcpserversink host=$RA-IP-ADDR port=5000

    Linux Box

    gst-launch-1.0 -v tcpclientsrc host=$RA-IP-ADDR port=5000  ! gdpdepay !  rtph264depay ! avdec_h264 ! videoconvert ! autovideosink sync=false

    But what kind of stream is it ? Can I read it with OpenCV ? or convert with avconv|ffmpeg nc $RA-IP-ADDR 5000 | avconv ? or watch with VLC ?