2020-09-15 02:48:00 +00:00
|
|
|
//! `mp4` is a Rust library to read and write ISO-MP4 files.
|
|
|
|
//!
|
|
|
|
//! This package contains MPEG-4 specifications defined in parts:
|
|
|
|
//! * ISO/IEC 14496-12 - ISO Base Media File Format (QuickTime, MPEG-4, etc)
|
|
|
|
//! * ISO/IEC 14496-14 - MP4 file format
|
|
|
|
//! * ISO/IEC 14496-17 - Streaming text format
|
|
|
|
//!
|
|
|
|
//! See: [mp4box] for supported MP4 atoms.
|
|
|
|
//!
|
|
|
|
//! ### Example
|
|
|
|
//!
|
|
|
|
//! ```
|
|
|
|
//! use std::fs::File;
|
|
|
|
//! use std::io::{BufReader};
|
|
|
|
//! use mp4::{Result};
|
|
|
|
//!
|
|
|
|
//! fn main() -> Result<()> {
|
|
|
|
//! let f = File::open("tests/samples/minimal.mp4").unwrap();
|
|
|
|
//! let size = f.metadata()?.len();
|
|
|
|
//! let reader = BufReader::new(f);
|
|
|
|
//!
|
|
|
|
//! let mp4 = mp4::Mp4Reader::read_header(reader, size)?;
|
|
|
|
//!
|
|
|
|
//! // Print boxes.
|
|
|
|
//! println!("major brand: {}", mp4.ftyp.major_brand);
|
|
|
|
//! println!("timescale: {}", mp4.moov.mvhd.timescale);
|
|
|
|
//!
|
|
|
|
//! // Use available methods.
|
|
|
|
//! println!("size: {}", mp4.size());
|
|
|
|
//!
|
|
|
|
//! let mut compatible_brands = String::new();
|
|
|
|
//! for brand in mp4.compatible_brands().iter() {
|
|
|
|
//! compatible_brands.push_str(&brand.to_string());
|
|
|
|
//! compatible_brands.push_str(",");
|
|
|
|
//! }
|
|
|
|
//! println!("compatible brands: {}", compatible_brands);
|
|
|
|
//! println!("duration: {:?}", mp4.duration());
|
|
|
|
//!
|
|
|
|
//! // Track info.
|
2021-07-30 02:57:15 +00:00
|
|
|
//! for track in mp4.tracks().values() {
|
2020-09-15 02:48:00 +00:00
|
|
|
//! println!(
|
|
|
|
//! "track: #{}({}) {} : {}",
|
|
|
|
//! track.track_id(),
|
|
|
|
//! track.language(),
|
|
|
|
//! track.track_type()?,
|
|
|
|
//! track.box_type()?,
|
|
|
|
//! );
|
|
|
|
//! }
|
|
|
|
//! Ok(())
|
|
|
|
//! }
|
|
|
|
//! ```
|
|
|
|
//!
|
|
|
|
//! See [examples] for more examples.
|
|
|
|
//!
|
|
|
|
//! # Installation
|
|
|
|
//!
|
|
|
|
//! Add the following to your `Cargo.toml` file:
|
|
|
|
//!
|
|
|
|
//! ```toml
|
|
|
|
//! [dependencies]
|
|
|
|
//! mp4 = "0.7.0"
|
|
|
|
//! ```
|
|
|
|
//!
|
|
|
|
//! [mp4box]: https://github.com/alfg/mp4-rust/blob/master/src/mp4box/mod.rs
|
2020-11-23 21:55:31 +00:00
|
|
|
//! [examples]: https://github.com/alfg/mp4-rust/blob/master/src/examples
|
2020-09-15 02:48:00 +00:00
|
|
|
#![doc(html_root_url = "https://docs.rs/mp4/*")]
|
|
|
|
|
|
|
|
|
2020-08-25 05:38:05 +00:00
|
|
|
use std::io::{BufReader};
|
|
|
|
use std::fs::File;
|
|
|
|
|
2020-07-28 16:36:17 +00:00
|
|
|
mod error;
|
|
|
|
pub use error::Error;
|
2020-01-12 03:34:29 +00:00
|
|
|
|
2020-07-28 16:36:17 +00:00
|
|
|
pub type Result<T> = std::result::Result<T, Error>;
|
|
|
|
|
2020-08-04 23:56:59 +00:00
|
|
|
mod types;
|
|
|
|
pub use types::*;
|
2020-01-10 06:26:08 +00:00
|
|
|
|
2020-08-04 23:56:59 +00:00
|
|
|
mod mp4box;
|
2022-03-26 03:13:02 +00:00
|
|
|
pub use mp4box::*;
|
2020-07-31 17:12:26 +00:00
|
|
|
|
2020-08-04 23:56:59 +00:00
|
|
|
mod track;
|
|
|
|
pub use track::{Mp4Track, TrackConfig};
|
2020-01-28 05:32:53 +00:00
|
|
|
|
2020-08-04 23:56:59 +00:00
|
|
|
mod reader;
|
|
|
|
pub use reader::Mp4Reader;
|
2020-07-31 17:12:26 +00:00
|
|
|
|
2020-08-04 23:56:59 +00:00
|
|
|
mod writer;
|
|
|
|
pub use writer::{Mp4Config, Mp4Writer};
|
2020-08-25 05:38:05 +00:00
|
|
|
|
|
|
|
pub fn read_mp4(f: File) -> Result<Mp4Reader<BufReader<File>>> {
|
|
|
|
let size = f.metadata()?.len();
|
|
|
|
let reader = BufReader::new(f);
|
|
|
|
let mp4 = reader::Mp4Reader::read_header(reader, size)?;
|
|
|
|
Ok(mp4)
|
|
|
|
}
|