gstreamer-rs/examples/src/bin/queries.rs

99 lines
2.7 KiB
Rust
Raw Normal View History

2017-07-29 14:33:26 +00:00
extern crate gstreamer as gst;
use gst::prelude::*;
2017-07-29 14:33:26 +00:00
extern crate glib;
use std::env;
2017-11-12 18:07:02 +00:00
#[path = "../examples-common.rs"]
mod examples_common;
fn example_main() {
2017-07-29 14:33:26 +00:00
let pipeline_str = env::args().collect::<Vec<String>>()[1..].join(" ");
gst::init().unwrap();
let main_loop = glib::MainLoop::new(None, false);
2017-07-29 14:33:26 +00:00
let pipeline = gst::parse_launch(&pipeline_str).unwrap();
let bus = pipeline.get_bus().unwrap();
let ret = pipeline.set_state(gst::State::Playing);
assert_ne!(ret, gst::StateChangeReturn::Failure);
let main_loop_clone = main_loop.clone();
let pipeline_weak = pipeline.downgrade();
let timeout_id = glib::timeout_add_seconds(1, move || {
let pipeline = match pipeline_weak.upgrade() {
Some(pipeline) => pipeline,
None => return glib::Continue(true),
};
2017-07-29 14:33:26 +00:00
//let pos = pipeline.query_position(gst::Format::Time).unwrap_or(-1);
//let dur = pipeline.query_duration(gst::Format::Time).unwrap_or(-1);
2017-07-29 14:33:26 +00:00
let pos = {
let mut q = gst::Query::new_position(gst::Format::Time);
if pipeline.query(&mut q) {
Some(q.get_result())
} else {
None
2017-07-29 14:33:26 +00:00
}
2018-10-08 12:02:23 +00:00
}
.and_then(|pos| pos.try_into_time().ok())
2018-10-08 06:32:08 +00:00
.unwrap();
2017-07-29 14:33:26 +00:00
let dur = {
let mut q = gst::Query::new_duration(gst::Format::Time);
if pipeline.query(&mut q) {
Some(q.get_result())
} else {
None
2017-07-29 14:33:26 +00:00
}
2018-10-08 12:02:23 +00:00
}
.and_then(|dur| dur.try_into_time().ok())
2018-10-08 06:32:08 +00:00
.unwrap();
2017-07-29 14:33:26 +00:00
println!("{} / {}", pos, dur);
glib::Continue(true)
});
//bus.add_signal_watch();
//bus.connect_message(move |_, msg| {
bus.add_watch(move |_, msg| {
use gst::MessageView;
2017-07-29 14:33:26 +00:00
let main_loop = &main_loop_clone;
match msg.view() {
MessageView::Eos(..) => main_loop.quit(),
2017-07-29 14:33:26 +00:00
MessageView::Error(err) => {
println!(
"Error from {:?}: {} ({:?})",
err.get_src().map(|s| s.get_path_string()),
2017-07-29 14:33:26 +00:00
err.get_error(),
err.get_debug()
);
main_loop.quit();
}
_ => (),
};
glib::Continue(true)
});
main_loop.run();
let ret = pipeline.set_state(gst::State::Null);
assert_ne!(ret, gst::StateChangeReturn::Failure);
bus.remove_watch();
glib::source_remove(timeout_id);
2017-07-29 14:33:26 +00:00
}
2017-11-12 18:07:02 +00:00
fn main() {
// tutorials_common::run is only required to set up the application environent on macOS
// (but not necessary in normal Cocoa applications where this is set up autmatically)
examples_common::run(example_main);
}