Recherche avancée

Médias (16)

Mot : - Tags -/mp3

Autres articles (66)

  • Keeping control of your media in your hands

    13 avril 2011, par

    The vocabulary used on this site and around MediaSPIP in general, aims to avoid reference to Web 2.0 and the companies that profit from media-sharing.
    While using MediaSPIP, you are invited to avoid using words like "Brand", "Cloud" and "Market".
    MediaSPIP is designed to facilitate the sharing of creative media online, while allowing authors to retain complete control of their work.
    MediaSPIP aims to be accessible to as many people as possible and development is based on expanding the (...)

  • Gestion générale des documents

    13 mai 2011, par

    MédiaSPIP ne modifie jamais le document original mis en ligne.
    Pour chaque document mis en ligne il effectue deux opérations successives : la création d’une version supplémentaire qui peut être facilement consultée en ligne tout en laissant l’original téléchargeable dans le cas où le document original ne peut être lu dans un navigateur Internet ; la récupération des métadonnées du document original pour illustrer textuellement le fichier ;
    Les tableaux ci-dessous expliquent ce que peut faire MédiaSPIP (...)

  • Personnaliser les catégories

    21 juin 2013, par

    Formulaire de création d’une catégorie
    Pour ceux qui connaissent bien SPIP, une catégorie peut être assimilée à une rubrique.
    Dans le cas d’un document de type catégorie, les champs proposés par défaut sont : Texte
    On peut modifier ce formulaire dans la partie :
    Administration > Configuration des masques de formulaire.
    Dans le cas d’un document de type média, les champs non affichés par défaut sont : Descriptif rapide
    Par ailleurs, c’est dans cette partie configuration qu’on peut indiquer le (...)

Sur d’autres sites (12480)

  • Is there a way to program the (Download) button to save a group of images as a one video ?

    9 février 2024, par Lina Al-fawzan

    This is my entire code. Its function is that everything the user writes or says will have images returned to him according to what he wrote/said, and the next image will be shown to him after he presses “close,” and he can save each image separately. I want to make a simple modification to it. First, instead of a close button, I want each image to be displayed for 3 seconds and the next one to be displayed, and so on... “all of them in one window”, and for the “download” button to be when the last image is displayed, and for them all to be saved in one video.

    


    import &#x27;package:flutter/material.dart&#x27;;&#xA;import &#x27;package:flutter/services.dart&#x27; show rootBundle;&#xA;import &#x27;dart:convert&#x27;;&#xA;import &#x27;dart:typed_data&#x27;;&#xA;import &#x27;package:image_gallery_saver/image_gallery_saver.dart&#x27;;&#xA;import &#x27;package:speech_to_text/speech_to_text.dart&#x27; as stt;&#xA;&#xA;void main() {&#xA;  runApp(MyApp());&#xA;}&#xA;&#xA;class MyApp extends StatelessWidget {&#xA;  @override&#xA;  Widget build(BuildContext context) {&#xA;    return MaterialApp(&#xA;      home: MyHomePage(),&#xA;    );&#xA;  }&#xA;}&#xA;&#xA;class MyHomePage extends StatefulWidget {&#xA;  @override&#xA;  _MyHomePageState createState() => _MyHomePageState();&#xA;}&#xA;&#xA;class _MyHomePageState extends State<myhomepage> {&#xA;  TextEditingController _textEditingController = TextEditingController();&#xA;  late stt.SpeechToText _speech;&#xA;  bool _isListening = false;&#xA;&#xA;  @override&#xA;  void initState() {&#xA;    super.initState();&#xA;    _speech = stt.SpeechToText();&#xA;  }&#xA;&#xA;  void _listen() async {&#xA;    if (!_isListening) {&#xA;      bool available = await _speech.initialize(&#xA;        onStatus: (val) => print(&#x27;onStatus: $val&#x27;),&#xA;        onError: (val) => print(&#x27;onError: $val&#x27;),&#xA;      );&#xA;      if (available) {&#xA;        setState(() => _isListening = true);&#xA;        _speech.listen(&#xA;          onResult: (val) => setState(() {&#xA;            _textEditingController.text = val.recognizedWords;&#xA;            if (val.hasConfidenceRating &amp;&amp; val.confidence > 0) {&#xA;              _showImages(val.recognizedWords);&#xA;            }&#xA;          }),&#xA;        );&#xA;      }&#xA;    } else {&#xA;      setState(() => _isListening = false);&#xA;      _speech.stop();&#xA;    }&#xA;  }&#xA;&#xA;  @override&#xA;  Widget build(BuildContext context) {&#xA;    return Scaffold(&#xA;      appBar: AppBar(&#xA;        title: Text(&#x27;Image Viewer&#x27;),&#xA;      ),&#xA;      body: Padding(&#xA;        padding: const EdgeInsets.all(16.0),&#xA;        child: Column(&#xA;          mainAxisAlignment: MainAxisAlignment.center,&#xA;          children: [&#xA;            TextField(&#xA;              controller: _textEditingController,&#xA;              decoration: const InputDecoration(&#xA;                labelText: &#x27;Enter a word&#x27;,&#xA;              ),&#xA;            ),&#xA;            SizedBox(height: 16.0),&#xA;            ElevatedButton(&#xA;              onPressed: () {&#xA;                String userInput = _textEditingController.text;&#xA;                _showImages(userInput);&#xA;              },&#xA;              child: Text(&#x27;Show Images&#x27;),&#xA;            ),&#xA;            SizedBox(height: 16.0),&#xA;            ElevatedButton(&#xA;              onPressed: _listen,&#xA;              child: Text(_isListening ? &#x27;Stop Listening&#x27; : &#x27;Start Listening&#x27;),&#xA;            ),&#xA;          ],&#xA;        ),&#xA;      ),&#xA;    );&#xA;  }&#xA;&#xA;Future<void> _showImages(String userInput) async {&#xA;  String directoryPath = &#x27;assets/output_images/&#x27;;&#xA;  print("User Input: $userInput");&#xA;  print("Directory Path: $directoryPath");&#xA;&#xA;  List<string> assetFiles = await rootBundle&#xA;      .loadString(&#x27;AssetManifest.json&#x27;)&#xA;      .then((String manifestContent) {&#xA;    final Map manifestMap = json.decode(manifestContent);&#xA;    return manifestMap.keys&#xA;        .where((String key) => key.startsWith(directoryPath))&#xA;        .toList();&#xA;  });&#xA;&#xA;  List<string> imageFiles = assetFiles.where((String assetPath) =>&#xA;      assetPath.toLowerCase().endsWith(&#x27;.jpg&#x27;) ||&#xA;      assetPath.toLowerCase().endsWith(&#x27;.gif&#x27;)).toList();&#xA;&#xA;  List<string> words = userInput.split(&#x27; &#x27;); // Tokenize the sentence into words&#xA;&#xA;  for (String word in words) {&#xA;    String wordImagePath = &#x27;$directoryPath$word.gif&#x27;;&#xA;&#xA;    if (imageFiles.contains(wordImagePath)) {&#xA;      await _showDialogWithImage(wordImagePath);&#xA;    } else {&#xA;      for (int i = 0; i &lt; word.length; i&#x2B;&#x2B;) {&#xA;        String letter = word[i];&#xA;        String letterImagePath = imageFiles.firstWhere(&#xA;          (assetPath) => assetPath.toLowerCase().endsWith(&#x27;$letter.jpg&#x27;),&#xA;          orElse: () => &#x27;&#x27;,&#xA;        );&#xA;        if (letterImagePath.isNotEmpty) {&#xA;          await _showDialogWithImage(letterImagePath);&#xA;        } else {&#xA;          print(&#x27;No image found for $letter&#x27;);&#xA;        }&#xA;      }&#xA;    }&#xA;  }&#xA;}&#xA;&#xA;  &#xA;&#xA;  Future<void> _showDialogWithImage(String imagePath) async {&#xA;    await showDialog<void>(&#xA;      context: context,&#xA;      builder: (BuildContext context) {&#xA;        return AlertDialog(&#xA;          content: Image.asset(imagePath),&#xA;          actions: [&#xA;            TextButton(&#xA;              onPressed: () {&#xA;                Navigator.of(context).pop();&#xA;              },&#xA;              child: Text(&#x27;Close&#x27;),&#xA;            ),&#xA;            TextButton(&#xA;              onPressed: () async {&#xA;                await _downloadImage(imagePath);&#xA;                Navigator.of(context).pop();&#xA;              },&#xA;              child: Text(&#x27;Download&#x27;),&#xA;            ),&#xA;          ],&#xA;        );&#xA;      },&#xA;    );&#xA;  }&#xA;&#xA;  Future<void> _downloadImage(String assetPath) async {&#xA;    try {&#xA;      final ByteData data = await rootBundle.load(assetPath);&#xA;      final List<int> bytes = data.buffer.asUint8List();&#xA;&#xA;      final result = await ImageGallerySaver.saveImage(Uint8List.fromList(bytes));&#xA;&#xA;      if (result != null) {&#xA;        ScaffoldMessenger.of(context).showSnackBar(&#xA;          SnackBar(&#xA;            content: Text(&#x27;Image saved to gallery.&#x27;),&#xA;          ),&#xA;        );&#xA;      } else {&#xA;        ScaffoldMessenger.of(context).showSnackBar(&#xA;          SnackBar(&#xA;            content: Text(&#x27;Failed to save image to gallery.&#x27;),&#xA;          ),&#xA;        );&#xA;      }&#xA;    } catch (e) {&#xA;      print(&#x27;Error downloading image: $e&#x27;);&#xA;    }&#xA;  }&#xA;}&#xA;&#xA;</int></void></void></void></string></string></string></void></myhomepage>

    &#xA;

  • I'm having problem encoding video using Laravel FFMPEG to save it to Minio storage

    8 juillet 2022, par Ibrahim Ahmad

    I am trying to convert video from .mp4 extension into HLS format (.m3u8) using Laravel FFMPEG.

    &#xA;

    FFMpeg::fromDisk(&#x27;minio&#x27;)&#xA;          ->open($videoFile)&#xA;          ->exportForHLS()&#xA;          ->onProgress(function ($percentage) use ($movie) {&#xA;               Cache::put(&#x27;progress-&#x27; . $movie->id, $percentage);&#xA;&#xA;               if($percentage >= 100) {&#xA;                 Cache::forget(&#x27;progress-&#x27; . $movie->id);&#xA;                }&#xA;             })&#xA;             ->toDisk(&#x27;minio&#x27;)&#xA;             ->addFormat($lowBitrate, function (HLSVideoFilters $filter) {&#xA;                 $filter->resize(480, 360);&#xA;             })&#xA;             ->addFormat($midBitrate, function (HLSVideoFilters $filter) {&#xA;                 $filter->resize(852, 480);&#xA;              })&#xA;              ->addFormat($highBitrate, function (HLSVideoFilters $filter) {&#xA;                  $filter->resize(1920, 1080);&#xA;              })&#xA;              ->save($newFile);&#xA;

    &#xA;

    I have a .mp4 video stored in Minio S3 storage, want to export to Minio S3 storage again. And I came up with this error

    &#xA;

    RecursiveDirectoryIterator::__construct(C:\Windows\Temp/52325dd01cfde90a\): Access is deni (code: 5)&#xA;

    &#xA;

    What does the error message say ? But when I export the video file to local, it works totally fine. How do I solve this problem. Thanks.

    &#xA;

    Update :&#xA;The export process requires windows temporary folder, and I cleared the temporary folder, the problem is solved for now. This probably the temporary folder can't hold many files.

    &#xA;

  • ffmpeg : cannot save HLS stream to MKV

    15 juillet 2021, par MasterAler

    I am trying to achieve something straightforward : writing the code that captures a video stream and saves it into an *.mkv file "as-is" (yeah, no demuxing or reencoding or whatever). Just want to store those AVPacket-s and the MKV container looks ready for that.

    &#xA;

    Note that the question is about ffmpeg library usage, the ffmpeg binary works fine and can be used to save the HLS steam data via the following :
    &#xA;ffmpeg -i https://bitdash-a.akamaihd.net/content/sintel/hls/playlist.m3u8 -c:v copy out.ts
    &#xA;I know that but the goal is to save any (or almost any) stream, thus the MKV. Actually, there is some code that already can save the streams' data, it fails specifically when trying it with HLS.

    &#xA;

    After some efforts to provide a short but readable MCVE, here's a sample code that reproduces the problem. The focus is on making the output codec work with HLS streams, thus it may lack a lot of things and details, like extra error checks, corner-cases, optimizations, proper timestamp handling, etc.

    &#xA;

    #include <atomic>&#xA;#include &#xA;#include <deque>&#xA;#include <functional>&#xA;#include <iostream>&#xA;#include <memory>&#xA;#include <mutex>&#xA;#include <thread>&#xA;&#xA;extern "C" {&#xA;#include "libavcodec/avcodec.h"&#xA;#include "libavfilter/avfilter.h"&#xA;#include "libavfilter/buffersink.h"&#xA;#include "libavfilter/buffersrc.h"&#xA;#include <libavcodec></libavcodec>avcodec.h>&#xA;#include <libavdevice></libavdevice>avdevice.h>&#xA;#include <libavformat></libavformat>avformat.h>&#xA;#include <libswscale></libswscale>swscale.h>&#xA;}&#xA;&#xA;// Some public stream. The code works with RTSP, RTMP, MJPEG, etc.&#xA;// static const char SOURCE_NAME[] = "http://81.83.10.9:8001/mjpg/video.mjpg"; // works!&#xA;&#xA;// My goal was an actual cam streaming via HLS, but here are some random HLS streams&#xA;// that reproduce the problem quite well. Playlists may differ, but the error is exactly the same&#xA;static const char SOURCE_NAME[] = "http://qthttp.apple.com.edgesuite.net/1010qwoeiuryfg/sl.m3u8"; // fails!&#xA;// static const char SOURCE_NAME[] = "https://bitdash-a.akamaihd.net/content/MI201109210084_1/m3u8s/f08e80da-bf1d-4e3d-8899-f0f6155f6efa.m3u8"; // fails!&#xA;&#xA;using Pkt = std::unique_ptr;&#xA;std::deque<pkt> frame_buffer;&#xA;std::mutex frame_mtx;&#xA;std::condition_variable frame_cv;&#xA;std::atomic_bool keep_running{true};&#xA;&#xA;AVCodecParameters *common_codecpar = nullptr;&#xA;std::mutex codecpar_mtx;&#xA;std::condition_variable codecpar_cv;&#xA;&#xA;void read_frames_from_source(unsigned N)&#xA;{&#xA;    AVFormatContext *fmt_ctx = avformat_alloc_context();&#xA;&#xA;    int err = avformat_open_input(&amp;fmt_ctx, SOURCE_NAME, nullptr, nullptr);&#xA;    if (err &lt; 0) {&#xA;        std::cerr &lt;&lt; "cannot open input" &lt;&lt; std::endl;&#xA;        avformat_free_context(fmt_ctx);&#xA;        return;&#xA;    }&#xA;&#xA;    err = avformat_find_stream_info(fmt_ctx, nullptr);&#xA;    if (err &lt; 0) {&#xA;        std::cerr &lt;&lt; "cannot find stream info" &lt;&lt; std::endl;&#xA;        avformat_free_context(fmt_ctx);&#xA;        return;&#xA;    }&#xA;&#xA;    // Simply finding the first video stream, preferrably H.264. Others are ignored below&#xA;    int video_stream_id = -1;&#xA;    for (unsigned i = 0; i &lt; fmt_ctx->nb_streams; i&#x2B;&#x2B;) {&#xA;        auto *c = fmt_ctx->streams[i]->codecpar;&#xA;        if (c->codec_type == AVMEDIA_TYPE_VIDEO) {&#xA;            video_stream_id = i;&#xA;            if (c->codec_id == AV_CODEC_ID_H264)&#xA;                break;&#xA;        }&#xA;    }&#xA;&#xA;    if (video_stream_id &lt; 0) {&#xA;        std::cerr &lt;&lt; "failed to find find video stream" &lt;&lt; std::endl;&#xA;        avformat_free_context(fmt_ctx);&#xA;        return;&#xA;    }&#xA;&#xA;    {   // Here we have the codec params and can launch the writer&#xA;        std::lock_guard locker(codecpar_mtx);&#xA;        common_codecpar = fmt_ctx->streams[video_stream_id]->codecpar;&#xA;    }&#xA;    codecpar_cv.notify_all();&#xA;&#xA;    unsigned cnt = 0;&#xA;    while (&#x2B;&#x2B;cnt &lt;= N) { // we read some limited number of frames&#xA;        Pkt pkt{av_packet_alloc(), [](AVPacket *p) { av_packet_free(&amp;p); }};&#xA;&#xA;        err = av_read_frame(fmt_ctx, pkt.get());&#xA;        if (err &lt; 0) {&#xA;            std::cerr &lt;&lt; "read packet error" &lt;&lt; std::endl;&#xA;            continue;&#xA;        }&#xA;&#xA;        // That&#x27;s why the cycle above, we write only one video stream here&#xA;        if (pkt->stream_index != video_stream_id)&#xA;            continue;&#xA;&#xA;        {&#xA;            std::lock_guard locker(frame_mtx);&#xA;            frame_buffer.push_back(std::move(pkt));&#xA;        }&#xA;        frame_cv.notify_one();&#xA;    }&#xA;&#xA;    keep_running.store(false);&#xA;    avformat_free_context(fmt_ctx);&#xA;}&#xA;&#xA;void write_frames_into_file(std::string filepath)&#xA;{&#xA;    AVFormatContext *out_ctx = nullptr;&#xA;    int err = avformat_alloc_output_context2(&amp;out_ctx, nullptr, "matroska", filepath.c_str());&#xA;    if (err &lt; 0) {&#xA;        std::cerr &lt;&lt; "avformat_alloc_output_context2 failed" &lt;&lt; std::endl;&#xA;        return;&#xA;    }&#xA;&#xA;    AVStream *video_stream = avformat_new_stream(out_ctx, avcodec_find_encoder(common_codecpar->codec_id)); // the proper way&#xA;    // AVStream *video_stream = avformat_new_stream(out_ctx, avcodec_find_encoder(AV_CODEC_ID_H264)); // forcing the H.264&#xA;    // ------>> HERE IS THE TROUBLE, NO CODEC WORKS WITH HLS &lt;&lt;------&#xA;&#xA;    int video_stream_id = video_stream->index;&#xA;&#xA;    err = avcodec_parameters_copy(video_stream->codecpar, common_codecpar);&#xA;    if (err &lt; 0) {&#xA;        std::cerr &lt;&lt; "avcodec_parameters_copy failed" &lt;&lt; std::endl;&#xA;    }&#xA;&#xA;    if (!(out_ctx->flags &amp; AVFMT_NOFILE)) {&#xA;        err =  avio_open(&amp;out_ctx->pb, filepath.c_str(), AVIO_FLAG_WRITE);&#xA;        if (err &lt; 0) {&#xA;            std::cerr &lt;&lt; "avio_open fail" &lt;&lt; std::endl;&#xA;            return;&#xA;        }&#xA;    }&#xA;&#xA;    err = avformat_write_header(out_ctx, nullptr); // &lt;&lt;--- ERROR WITH HLS HERE&#xA;    if (err &lt; 0) {&#xA;        std::cerr &lt;&lt; "avformat_write_header failed" &lt;&lt; std::endl;&#xA;        return; // here we go with hls&#xA;    }&#xA;&#xA;    unsigned cnt = 0;&#xA;    while (true) {&#xA;        std::unique_lock locker(frame_mtx);&#xA;        frame_cv.wait(locker, [&amp;] { return !frame_buffer.empty() || !keep_running; });&#xA;&#xA;        if (!keep_running)&#xA;            break;&#xA;&#xA;        Pkt pkt = std::move(frame_buffer.front());&#xA;        frame_buffer.pop_front();&#xA;        &#x2B;&#x2B;cnt;&#xA;        locker.unlock();&#xA;&#xA;        pkt->stream_index = video_stream_id; // mandatory&#xA;        err = av_write_frame(out_ctx, pkt.get());&#xA;        if (err &lt; 0) {&#xA;            std::cerr &lt;&lt; "av_write_frame failed " &lt;&lt; cnt &lt;&lt; std::endl;&#xA;        } else if (cnt % 25 == 0) {&#xA;            std::cout &lt;&lt; cnt &lt;&lt; " OK" &lt;&lt; std::endl;&#xA;        }&#xA;    }&#xA;&#xA;    av_write_trailer(out_ctx);&#xA;    avformat_free_context(out_ctx);&#xA;}&#xA;&#xA;int main()&#xA;{&#xA;    std::thread reader(std::bind(&amp;read_frames_from_source, 1000));&#xA;    std::thread writer;&#xA;&#xA;    // Writer wont start until reader&#x27;s got AVCodecParameters&#xA;    // In this example it spares us from setting writer&#x27;s params properly manually&#xA;&#xA;    {   // Waiting for codec params to be set&#xA;        std::unique_lock locker(codecpar_mtx);&#xA;        codecpar_cv.wait(locker, [&amp;] { return common_codecpar != nullptr; });&#xA;        writer = std::thread(std::bind(&amp;write_frames_into_file, "out.mkv"));&#xA;    }&#xA;&#xA;    reader.join();&#xA;    keep_running.store(false);&#xA;    writer.join();&#xA;&#xA;    return 0;&#xA;}&#xA;&#xA;</pkt></thread></mutex></memory></iostream></functional></deque></atomic>

    &#xA;

    What happens here ? Simply put :

    &#xA;

      &#xA;
    1. Two threads are spawned, one reads packets from source and stores them in a buffer
    2. &#xA;

    3. The writer waits for the reader to get the AVCodecParameters, so that you can see they are the same being used, almost no manual param setting here
    4. &#xA;

    5. The reader is supposed to read N packets and finish, then the writer follows him. That's how it works with RTSP, RTMP, MJPEG, etc.
    6. &#xA;

    &#xA;

    What's the problem ? Once an HLS stream is tried, there goes the following error :

    &#xA;

    &#xA;

    Tag [27][0][0][0] incompatible with output codec id '27' (H264)

    &#xA;

    &#xA;

    After that the writer segfaults on any write attempt via it's context (that is avformat_write_header here) avformat_write_header fails with an error (see UPD2 below) and thus no successfull write operation is possible.

    &#xA;

    What's been tried :

    &#xA;

      &#xA;
    1. Forcing arbitrary codecs (ex. : AV_CODEC_ID_H264). No luck there.
    2. &#xA;

    3. Trying the AV_CODEC_ID_MPEGTS. No way, it's documented as a "fake" codec for internal needs.
    4. &#xA;

    5. Switching some of the multiple options for input or output contexts, no luck there
    6. &#xA;

    &#xA;

    I'm currenly confused a lot 'coz the error sounds like "Tag H264 is not compatible with codec H264". The ffmpeg logs look like the library managed to comprehend it's dealing with MPEG-TS being sent via HLS, reading is fine but writing into the chosen media container fails :

    &#xA;

    [hls @ 0x7f94b0000900] Opening &#x27;https://bitdash-a.akamaihd.net/content/MI201109210084_1/video/540_1200000/hls/segment_0.ts&#x27; for reading&#xA;[hls @ 0x7f94b0000900] Opening &#x27;https://bitdash-a.akamaihd.net/content/MI201109210084_1/video/540_1200000/hls/segment_1.ts&#x27; for reading&#xA;[hls @ 0x7f94b0000900] Opening &#x27;https://bitdash-a.akamaihd.net/content/MI201109210084_1/video/720_2400000/hls/segment_0.ts&#x27; for reading&#xA;[hls @ 0x7f94b0000900] Opening &#x27;https://bitdash-a.akamaihd.net/content/MI201109210084_1/video/720_2400000/hls/segment_1.ts&#x27; for reading&#xA;[hls @ 0x7f94b0000900] Opening &#x27;https://bitdash-a.akamaihd.net/content/MI201109210084_1/video/1080_4800000/hls/segment_0.ts&#x27; for reading&#xA;[hls @ 0x7f94b0000900] Opening &#x27;https://bitdash-a.akamaihd.net/content/MI201109210084_1/video/1080_4800000/hls/segment_1.ts&#x27; for reading&#xA;[hls @ 0x7f94b0000900] Could not find codec parameters for stream 0 (Audio: aac ([15][0][0][0] / 0x000F), 0 channels, 112 kb/s): unspecified sample rate&#xA;Consider increasing the value for the &#x27;analyzeduration&#x27; and &#x27;probesize&#x27; options&#xA;[matroska @ 0x7f94a8000900] Tag [27][0][0][0] incompatible with output codec id &#x27;27&#x27; (H264)&#xA;avformat_write_header failed&#xA;Segmentation fault (core dumped)&#xA;

    &#xA;

    No hard googling helped, I'm a bit desperate.
    &#xA;Plz, share your ideas, would be grateful for any.

    &#xA;

    UPD

    &#xA;

      &#xA;
    • ffmpeg -i https://bitdash-a.akamaihd.net/content/sintel/hls/playlist.m3u8 out.mkv works fine
    • &#xA;

    • ffmpeg -i http://qthttp.apple.com.edgesuite.net/1010qwoeiuryfg/sl.m3u8 -c:v copy out.mkv also works fine
    • &#xA;

    &#xA;

    ... which means ffmpeg can do the trick and the desired result can be achieved

    &#xA;

    UPD2

    &#xA;

    It occured that the tag error can be suppressed via
    &#xA;out_ctx->strict_std_compliance = FF_COMPLIANCE_UNOFFICIAL;
    &#xA;I assume it's smth about spelling the "h264" properly in a string tag, doesn't look serious.

    &#xA;

    Also, after a closer look it occured that it's av_write_frame that actually segfaults. No wonder — with HLS streams avformat_write_header fails and returns error :

    &#xA;

    &#xA;

    Invalid data found when processing input

    &#xA;

    &#xA;

    That still leaves me with no clues, where's the problem here =((

    &#xA;