mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer-rs.git
synced 2025-01-25 00:18:26 +00:00
add option to ges.rs to render to a file instead
This commit is contained in:
parent
ce09e333b3
commit
acb2a9e522
1 changed files with 45 additions and 7 deletions
|
@ -45,7 +45,39 @@ use std::env;
|
||||||
#[path = "../examples-common.rs"]
|
#[path = "../examples-common.rs"]
|
||||||
mod examples_common;
|
mod examples_common;
|
||||||
|
|
||||||
fn main_loop(uri: &str) -> Result<(), glib::BoolError> {
|
fn configure_pipeline(pipeline: &ges::Pipeline, output_name: &str) {
|
||||||
|
// Every audiostream piped into the encodebin should be encoded using opus.
|
||||||
|
let audio_profile = gst_pbutils::EncodingAudioProfileBuilder::new()
|
||||||
|
.format(&gst::Caps::new_simple("audio/x-opus", &[]))
|
||||||
|
.build()
|
||||||
|
.expect("Failed to create audio profile");
|
||||||
|
|
||||||
|
// Every videostream piped into the encodebin should be encoded using vp8.
|
||||||
|
let video_profile = gst_pbutils::EncodingVideoProfileBuilder::new()
|
||||||
|
.format(&gst::Caps::new_simple("video/x-vp8", &[]))
|
||||||
|
.build()
|
||||||
|
.expect("Failed to create video profile");
|
||||||
|
|
||||||
|
// All streams are then finally combined into a webm container.
|
||||||
|
let container_profile = gst_pbutils::EncodingContainerProfileBuilder::new()
|
||||||
|
.name("container")
|
||||||
|
.format(&gst::Caps::new_simple("video/webm", &[]))
|
||||||
|
.add_profile(&video_profile)
|
||||||
|
.add_profile(&audio_profile)
|
||||||
|
.build()
|
||||||
|
.expect("Failed to create container profile");
|
||||||
|
|
||||||
|
// Apply the EncodingProfile to the pipeline, and set it to render mode
|
||||||
|
let output_uri = format!("{}.webm", output_name);
|
||||||
|
pipeline
|
||||||
|
.set_render_settings(&output_uri, &container_profile)
|
||||||
|
.expect("Failed to set render settings");
|
||||||
|
pipeline
|
||||||
|
.set_mode(ges::PipelineFlags::RENDER)
|
||||||
|
.expect("Failed to set pipeline to render mode");
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main_loop(uri: &str, output: Option<&String>) -> Result<(), glib::BoolError> {
|
||||||
ges::init()?;
|
ges::init()?;
|
||||||
|
|
||||||
// Begin by creating a timeline with audio and video tracks
|
// Begin by creating a timeline with audio and video tracks
|
||||||
|
@ -55,6 +87,11 @@ fn main_loop(uri: &str) -> Result<(), glib::BoolError> {
|
||||||
let pipeline = ges::Pipeline::new();
|
let pipeline = ges::Pipeline::new();
|
||||||
pipeline.set_timeline(&timeline)?;
|
pipeline.set_timeline(&timeline)?;
|
||||||
|
|
||||||
|
// If requested, configure the pipeline so it renders to a file.
|
||||||
|
if let Some(output_name) = output {
|
||||||
|
configure_pipeline(&pipeline, output_name);
|
||||||
|
}
|
||||||
|
|
||||||
// Load a clip from the given uri and add it to the layer.
|
// Load a clip from the given uri and add it to the layer.
|
||||||
let clip = ges::UriClip::new(uri).expect("Failed to create clip");
|
let clip = ges::UriClip::new(uri).expect("Failed to create clip");
|
||||||
layer.add_clip(&clip)?;
|
layer.add_clip(&clip)?;
|
||||||
|
@ -126,14 +163,15 @@ fn main_loop(uri: &str) -> Result<(), glib::BoolError> {
|
||||||
#[allow(unused_variables)]
|
#[allow(unused_variables)]
|
||||||
fn example_main() {
|
fn example_main() {
|
||||||
let args: Vec<_> = env::args().collect();
|
let args: Vec<_> = env::args().collect();
|
||||||
let uri: &str = if args.len() == 2 {
|
if args.len() < 2 || args.len() > 3 {
|
||||||
args[1].as_ref()
|
println!("Usage: ges input [output]");
|
||||||
} else {
|
|
||||||
println!("Usage: ges launch");
|
|
||||||
std::process::exit(-1)
|
std::process::exit(-1)
|
||||||
};
|
}
|
||||||
|
|
||||||
match main_loop(uri) {
|
let input_uri: &str = args[1].as_ref();
|
||||||
|
let output = args.get(2);
|
||||||
|
|
||||||
|
match main_loop(input_uri, output) {
|
||||||
Ok(r) => r,
|
Ok(r) => r,
|
||||||
Err(e) => eprintln!("Error! {}", e),
|
Err(e) => eprintln!("Error! {}", e),
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue