From 26826b02c24633c1cb56a261a463778d3778ecca Mon Sep 17 00:00:00 2001 From: ArsenArsen Date: Tue, 13 Jun 2017 10:56:08 +0200 Subject: [PATCH] Recording mostly completed. Who's excited? Left to do: Error handling. Yep. --- recording/encoders/encoder.cpp | 9 ++++++++- recording/encoders/encoder.hpp | 2 -- uploaders/default/clipboarduploader.cpp | 4 ++-- 3 files changed, 10 insertions(+), 5 deletions(-) diff --git a/recording/encoders/encoder.cpp b/recording/encoders/encoder.cpp index 17a500f..bddafff 100644 --- a/recording/encoders/encoder.cpp +++ b/recording/encoders/encoder.cpp @@ -36,6 +36,7 @@ Encoder::Encoder(QString &targetFile, QSize res) { int fps = settings::settings().value("recording/framerate", 30).toInt(); out->enc->codec_id = codec->id; + out->enc->codec = codec; out->enc->bit_rate = 400000; out->enc->width = res.width() % 2 ? res.width() - 1 : res.width(); @@ -50,6 +51,8 @@ Encoder::Encoder(QString &targetFile, QSize res) { out->enc->max_b_frames = 2; else if (out->enc->codec_id == AV_CODEC_ID_MPEG1VIDEO) out->enc->mb_decision = 2; + else if (out->enc->codec_id == AV_CODEC_ID_GIF) + out->enc->pix_fmt = AV_PIX_FMT_RGB8; ret = avcodec_open2(out->enc, codec, NULL); @@ -98,6 +101,9 @@ bool Encoder::addFrame(QImage frm) { if (frm.format() != QImage::Format_RGB888) frm = frm.convertToFormat(QImage::Format_RGB888); uint8_t *frameData = (uint8_t *)frm.bits(); setFrameRGB(frameData); + AVPacket pkt; + pkt.size = 0; + pkt.data = NULL; av_init_packet(&pkt); int gotPack = 0; int ret = avcodec_encode_video2(out->enc, &pkt, out->frame, &gotPack); @@ -132,7 +138,8 @@ cleanup: av_frame_free(&out->frame); sws_freeContext(out->sws); delete out; - if (!(fc->oformat->flags & AVFMT_NOFILE)) avio_closep(&fc->pb); + if (!(fc->oformat->flags & AVFMT_NOFILE)) // + avio_closep(&fc->pb); avformat_free_context(fc); return success; } diff --git a/recording/encoders/encoder.hpp b/recording/encoders/encoder.hpp index a826c84..1bc972e 100644 --- a/recording/encoders/encoder.hpp +++ b/recording/encoders/encoder.hpp @@ -3,7 +3,6 @@ #include #include -#include extern "C" { #include #include @@ -34,7 +33,6 @@ private: OutputStream *out = new OutputStream; AVFormatContext *fc = NULL; - AVPacket pkt; bool success = false; diff --git a/uploaders/default/clipboarduploader.cpp b/uploaders/default/clipboarduploader.cpp index c5e3723..57aa7a2 100644 --- a/uploaders/default/clipboarduploader.cpp +++ b/uploaders/default/clipboarduploader.cpp @@ -12,7 +12,7 @@ void ClipboardUploader::doUpload(QByteArray imgData, QString format) { auto data = new QMimeData(); data->setData(formats::recordingFormatMIME(f), imgData); QApplication::clipboard()->setMimeData(data); - } - QApplication::clipboard()->setImage(QImage::fromData(imgData, format.toLocal8Bit().constData())); + } else + QApplication::clipboard()->setImage(QImage::fromData(imgData, format.toLocal8Bit().constData())); notifications::notify("KShare", "Copied to clipboard!"); }