X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Frenderer.cpp;h=3e18730174c408034b15898a708d2a7d5a72019b;hb=fefb8e4376d675868a11c438f18c1a059d0cfced;hp=6728fdde04b4799cd8e2b8d98e748a08ce80b3a3;hpb=39e387e732db729eaf44c1826d86cd45e3878482;p=kdenlive diff --git a/src/renderer.cpp b/src/renderer.cpp index 6728fdde..3e187301 100644 --- a/src/renderer.cpp +++ b/src/renderer.cpp @@ -71,14 +71,21 @@ static void consumer_frame_show(mlt_consumer, Render * self, mlt_frame frame_ptr if (self->analyseAudio) { self->showAudio(frame); } - if (frame.get_double("_speed") == 0.0) { - self->emitConsumerStopped(); - } else if (frame.get_double("_speed") < 0.0 && mlt_frame_get_position(frame_ptr) <= 0) { + if (frame.get_double("_speed") < 0.0 && mlt_frame_get_position(frame_ptr) <= 0) { self->pause(); self->emitConsumerStopped(); } } + +static void consumer_paused(mlt_consumer, Render * self, mlt_frame /*frame_ptr*/) +{ + // detect if the producer has finished playing. Is there a better way to do it? + if (self->m_isBlocked) return; + self->emitConsumerStopped(); +} + + static void consumer_gl_frame_show(mlt_consumer, Render * self, mlt_frame frame_ptr) { // detect if the producer has finished playing. Is there a better way to do it? @@ -240,6 +247,7 @@ void Render::buildConsumer(const QString profileName) m_mltConsumer = new Mlt::Consumer(*m_mltProfile, "sdl_preview"); // FIXME: the event object returned by the listen gets leaked... m_mltConsumer->listen("consumer-frame-show", this, (mlt_listener) consumer_frame_show); + m_mltConsumer->listen("consumer-sdl-paused", this, (mlt_listener) consumer_paused); m_mltConsumer->set("window_id", m_winid); } m_mltConsumer->set("resize", 1); @@ -1314,36 +1322,24 @@ void Render::pause() m_mltConsumer->purge(); } -void Render::switchPlay() +void Render::switchPlay(bool play) { if (!m_mltProducer || !m_mltConsumer) return; if (m_isZoneMode) resetZoneMode(); - if (m_mltProducer->get_speed() == 0.0) { + if (play && m_mltProducer->get_speed() == 0.0) { m_isBlocked = false; if (m_name == "clip" && m_framePosition == (int) m_mltProducer->get_out()) m_mltProducer->seek(0); m_mltProducer->set_speed(1.0); m_mltConsumer->set("refresh", 1); - } else { + } else if (!play) { m_isBlocked = true; m_mltConsumer->set("refresh", 0); m_mltProducer->set_speed(0.0); //emit rendererPosition(m_framePosition); m_mltProducer->seek(m_framePosition); - m_mltConsumer->purge(); - //kDebug()<<" ********* RENDER PAUSE: "<get_speed(); - //m_mltConsumer->set("refresh", 0); - /*mlt_position position = mlt_producer_position( m_mltProducer->get_producer() ); - m_mltProducer->set_speed(0); - m_mltProducer->seek( position ); - //m_mltProducer->seek((int) m_framePosition); - m_isBlocked = false;*/ + //m_mltConsumer->purge(); } - /*if (speed == 0.0) { - m_mltProducer->seek((int) m_framePosition + 1); - m_mltConsumer->purge(); - }*/ - //refresh(); } void Render::play(double speed) @@ -4026,17 +4022,7 @@ void Render::mltDeleteTrack(int ix) tractor.removeChild(track); //kDebug() << "/////////// RESULT SCENE: \n" << doc.toString(); setSceneList(doc.toString(), m_framePosition); - - /* if (m_mltProducer != NULL) { - Mlt::Producer parentProd(m_mltProducer->parent()); - if (parentProd.get_producer() != NULL) { - Mlt::Service service(parentProd.get_service()); - if (service.type() == tractor_type) { - Mlt::Tractor tractor(service); - mltCheckLength(&tractor); - } - } - }*/ + emit refreshDocumentProducers(false); }