static void kdenlive_callback(void* /*ptr*/, int level, const char* fmt, va_list vl)
{
-// kDebug() << "log level" << level << QString().vsprintf(fmt, vl).simplified();
if (level > MLT_LOG_ERROR) return;
+ //kDebug() << "log level" << level << QString().vsprintf(fmt, vl).simplified();
QString error;
QApplication::postEvent(qApp->activeWindow(), new MltErrorEvent(error.vsprintf(fmt, vl).simplified()));
va_end(vl);
m_mltProducer->seek(time);
if (m_paused && !externalConsumer) {
m_mltConsumer->set("refresh", 1);
+ m_paused = false;
}
else if (m_mltProducer->get_speed() == 0) {
// workaround specific bug in MLT's SDL consumer
emit frameUpdated(qimage.rgbSwapped());
}
+int Render::getCurrentSeekPosition() const
+{
+ if (requestedSeekPosition != SEEK_INACTIVE) return requestedSeekPosition;
+ return (int) m_mltProducer->position();
+}
+
void Render::emitFrameNumber()
{
int currentPos = m_mltConsumer->position();
if (requestedSeekPosition != SEEK_INACTIVE) {
m_mltConsumer->purge();
m_mltProducer->seek(requestedSeekPosition);
- if (m_mltProducer->get_speed() == 0) m_mltConsumer->set("refresh", 1);
+ if (m_mltProducer->get_speed() == 0 && m_paused) {
+ m_paused = false;
+ m_mltConsumer->set("refresh", 1);
+ }
requestedSeekPosition = SEEK_INACTIVE;
}
}