mirror of
https://github.com/alfg/mp4-rust.git
synced 2024-12-22 12:06:33 +00:00
bugfix: fix update_sync_samples in Mp4TrackWriter where sync is not properly set in stss box #38 (#39)
This commit is contained in:
parent
b63522186e
commit
9c43838793
1 changed files with 9 additions and 6 deletions
15
src/track.rs
15
src/track.rs
|
@ -663,16 +663,19 @@ impl Mp4TrackWriter {
|
||||||
|
|
||||||
fn update_sync_samples(&mut self, is_sync: bool) {
|
fn update_sync_samples(&mut self, is_sync: bool) {
|
||||||
if let Some(ref mut stss) = self.trak.mdia.minf.stbl.stss {
|
if let Some(ref mut stss) = self.trak.mdia.minf.stbl.stss {
|
||||||
stss.entries.push(self.sample_id);
|
if !is_sync {
|
||||||
} else {
|
|
||||||
if is_sync {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut stss = StssBox::default();
|
stss.entries.push(self.sample_id);
|
||||||
for i in 1..=self.trak.mdia.minf.stbl.stsz.sample_count {
|
} else {
|
||||||
stss.entries.push(i);
|
if !is_sync {
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Create the stts box if not found and push the entry.
|
||||||
|
let mut stss = StssBox::default();
|
||||||
|
stss.entries.push(self.sample_id);
|
||||||
self.trak.mdia.minf.stbl.stss = Some(stss);
|
self.trak.mdia.minf.stbl.stss = Some(stss);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue