Java Code Examples for org.mp4parser.IsoFile#getBoxes()
The following examples show how to use
org.mp4parser.IsoFile#getBoxes() .
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example 1
Source File: MetaDataInsert.java From mp4parser with Apache License 2.0 | 6 votes |
private boolean needsOffsetCorrection(IsoFile isoFile) { if (Path.getPath(isoFile, "moov[0]/mvex[0]") != null) { // Fragmented files don't need a correction return false; } else { // no correction needed if mdat is before moov as insert into moov want change the offsets of mdat for (Box box : isoFile.getBoxes()) { if ("moov".equals(box.getType())) { return true; } if ("mdat".equals(box.getType())) { return false; } } throw new RuntimeException("I need moov or mdat. Otherwise all this doesn't make sense"); } }
Example 2
Source File: Avc1ToAvc3Example.java From mp4parser with Apache License 2.0 | 6 votes |
public static void main(String[] args) throws IOException { String f = Avc1ToAvc3Example.class.getProtectionDomain().getCodeSource().getLocation().getFile() + "/1365070268951.mp4"; Movie m = MovieCreator.build(new FileInputStream(f).getChannel(), new FileRandomAccessSourceImpl(new RandomAccessFile(f, "r")), "inmem"); Movie m2 = new Movie(); for (Track track : m.getTracks()) { if (track.getSampleEntries().get(0).getType().equals("avc1")) { m2.addTrack(new Avc1ToAvc3TrackImpl(track)); } else { m2.addTrack(track); } } new FragmentedMp4Builder().build(m2).writeContainer(new FileOutputStream("output.mp4").getChannel()); IsoFile i = new IsoFile("output.mp4"); for (Box box : i.getBoxes()) { System.err.println(box + "@-nooffsets"); } }
Example 3
Source File: VideoAudioChecker.java From mp4parser with Apache License 2.0 | 6 votes |
public static TYPE getType(IsoFile isoFile) { List<HandlerBox> handlerBoxes = isoFile.getBoxes(HandlerBox.class, true); for (HandlerBox handlerBox : handlerBoxes) { if ("vide".equals(handlerBox.getHandlerType())) { return TYPE.VIDEO; } else if ("soun".equals(handlerBox.getHandlerType())) { return TYPE.AUDIO; } else { System.err.println("unknown"); } } return TYPE.AUDIO; }
Example 4
Source File: MetaDataTool.java From mp4parser with Apache License 2.0 | 6 votes |
public static boolean needsOffsetCorrection(IsoFile isoFile) { if (Path.getPaths(isoFile, "mdat").size() > 1) { throw new RuntimeException("There might be the weird case that a file has two mdats. One before" + " moov and one after moov. That would need special handling therefore I just throw an " + "exception here. "); } if (Path.getPaths(isoFile, "moof").size() > 0) { throw new RuntimeException("Fragmented MP4 files need correction, too. (But I would need to look where)"); } for (Box box : isoFile.getBoxes()) { if ("mdat".equals(box.getType())) { return false; } if ("moov".equals(box.getType())) { return true; } } throw new RuntimeException("Hmmm - shouldn't happen"); }
Example 5
Source File: MetaDataInsert.java From mp4parser with Apache License 2.0 | 4 votes |
public void writeRandomMetadata(String videoFilePath, String title) throws IOException { File videoFile = new File(videoFilePath); if (!videoFile.exists()) { throw new FileNotFoundException("File " + videoFilePath + " not exists"); } if (!videoFile.canWrite()) { throw new IllegalStateException("No write permissions to file " + videoFilePath); } IsoFile isoFile = new IsoFile(videoFilePath); MovieBox moov = isoFile.getBoxes(MovieBox.class).get(0); FreeBox freeBox = findFreeBox(moov); boolean correctOffset = needsOffsetCorrection(isoFile); long sizeBefore = moov.getSize(); long offset = 0; for (Box box : isoFile.getBoxes()) { if ("moov".equals(box.getType())) { break; } offset += box.getSize(); } // Create structure or just navigate to Apple List Box. UserDataBox userDataBox; if ((userDataBox = Path.getPath(moov, "udta")) == null) { userDataBox = new UserDataBox(); moov.addBox(userDataBox); } MetaBox metaBox; if ((metaBox = Path.getPath(userDataBox, "meta")) == null) { metaBox = new MetaBox(); HandlerBox hdlr = new HandlerBox(); hdlr.setHandlerType("mdir"); metaBox.addBox(hdlr); userDataBox.addBox(metaBox); } AppleItemListBox ilst; if ((ilst = Path.getPath(metaBox, "ilst")) == null) { ilst = new AppleItemListBox(); metaBox.addBox(ilst); } if (freeBox == null) { freeBox = new FreeBox(128 * 1024); metaBox.addBox(freeBox); } // Got Apple List Box AppleNameBox nam; if ((nam = Path.getPath(ilst, "©nam")) == null) { nam = new AppleNameBox(); } nam.setDataCountry(0); nam.setDataLanguage(0); nam.setValue(title); ilst.addBox(nam); long sizeAfter = moov.getSize(); long diff = sizeAfter - sizeBefore; // This is the difference of before/after // can we compensate by resizing a Free Box we have found? if (freeBox.getData().limit() > diff) { // either shrink or grow! freeBox.setData(ByteBuffer.allocate((int) (freeBox.getData().limit() - diff))); sizeAfter = moov.getSize(); diff = sizeAfter - sizeBefore; } if (correctOffset && diff != 0) { correctChunkOffsets(moov, diff); } BetterByteArrayOutputStream baos = new BetterByteArrayOutputStream(); moov.getBox(Channels.newChannel(baos)); isoFile.close(); FileChannel fc; if (diff != 0) { // this is not good: We have to insert bytes in the middle of the file // and this costs time as it requires re-writing most of the file's data fc = splitFileAndInsert(videoFile, offset, sizeAfter - sizeBefore); } else { // simple overwrite of something with the file fc = new RandomAccessFile(videoFile, "rw").getChannel(); } fc.position(offset); fc.write(ByteBuffer.wrap(baos.getBuffer(), 0, baos.size())); fc.close(); }