Search in sources :

Example 1 with MPlayerTitle

use of org.fagu.fmv.soft.mplayer.MPlayerTitle in project fmv by f-agu.

the class Ripper method rip.

/**
 * @throws IOException
 */
public void rip() throws IOException {
    AppVersion.logMyVersion(logger::log);
    logger.log("===========================================================");
    String msg = "Analyzing DVD on " + dvdDrive + "...";
    logger.log(msg);
    String name = null;
    try (TextProgressBar bar = TextProgressBar.newBar().appendText(msg + "   ").append(new SpinnerPart()).buildAndSchedule()) {
        name = dvdName.nameOf(dvdDrive, logger);
    }
    displayAndLog("Name: " + name);
    msg = "Scanning titles...";
    logger.log(msg);
    MPlayerTitles mPlayerTitles = null;
    try (TextProgressBar bar = TextProgressBar.newBar().appendText(msg + "   ").append(new SpinnerPart()).buildAndSchedule()) {
        mPlayerTitles = titlesExtractor.extract(dvdDrive, logger);
    }
    Collection<MPlayerTitle> titles = selectTitlesPolicy.select(mPlayerTitles.getTitles());
    displayAndLog("Found " + titles.size() + " titles:");
    titles.forEach(t -> displayAndLog("   " + t.getNum() + "/" + t.getLength()));
    displayAndLog("Write to " + tmpDirectory);
    AtomicInteger currentTitle = new AtomicInteger();
    AtomicInteger currentEncoding = new AtomicInteger();
    final int prefixWidth = 30;
    int nbProgresses = titles.size() * 2;
    List<AtomicInteger> progressList = new ArrayList<>(nbProgresses);
    titles.forEach(t -> {
        // dump
        progressList.add(new AtomicInteger());
        // encode
        progressList.add(new AtomicInteger());
    });
    final String finalName = name;
    TextProgressBarBuilder builder = TextProgressBar.newBar().fixWidth(32).withText(StringUtils.abbreviate(finalName, prefixWidth) + " ");
    if (titles.size() == 1) {
        builder.fixWidth(20).with(s -> currentTitle.get() == 1 ? "reading DVD..." : currentEncoding.get() == 1 ? "encoding..." : "");
    } else {
        builder.fixWidth(19).with(s -> currentTitle.get() > 0 ? "reading DVD: " + currentTitle.get() + "/" + titles.size() : "");
        builder.fixWidth(15).with(s -> currentEncoding.get() > 0 ? "encoding: " + currentEncoding.get() + "/" + titles.size() : "");
    }
    textProgressBar = builder.append(ProgressPart.width(31).build()).fixWidth(6).leftPad().with(new PercentPart()).buildAndSchedule(() -> progressList.stream().mapToInt(AtomicInteger::get).sum() / nbProgresses);
    if (!tmpDirectory.exists() && !tmpDirectory.mkdirs()) {
        throw new IOException("Unable to make directory: " + tmpDirectory);
    }
    CountDownLatch encodingLatch = new CountDownLatch(titles.size());
    Iterator<AtomicInteger> progressIterator = progressList.iterator();
    for (MPlayerTitle title : titles) {
        AtomicInteger dumpProgress = progressIterator.next();
        AtomicInteger encodeProgress = progressIterator.next();
        currentTitle.incrementAndGet();
        String baseName = name + "-" + title.getNum();
        File vobFile = File.createTempFile(baseName + '-', ".vob", tmpDirectory);
        logger.log("Dumping title " + currentTitle + "/" + titles.size() + ": " + vobFile.getAbsolutePath());
        MPlayerDump mPlayerDump = mPlayerDumperBuilder.prepare(dvdDrive, logger).progress(dumpProgress::set).dump(title.getNum(), vobFile);
        File mp4File = new File(tmpDirectory, baseName + ".mp4");
        logger.log("Encoding title " + currentTitle + "/" + titles.size() + ": " + mp4File.getAbsolutePath());
        encode(vobFile, mp4File, mPlayerDump, encodeProgress, currentEncoding, encodingLatch);
    }
    currentTitle.set(-1);
    try {
        encodingLatch.await();
    } catch (InterruptedException e) {
        throw new IOException(e);
    }
    logger.log("End");
}
Also used : SpinnerPart(org.fagu.fmv.textprogressbar.part.SpinnerPart) MPlayerDump(org.fagu.fmv.soft.mplayer.MPlayerDump) MPlayerTitle(org.fagu.fmv.soft.mplayer.MPlayerTitle) ArrayList(java.util.ArrayList) PercentPart(org.fagu.fmv.textprogressbar.part.PercentPart) IOException(java.io.IOException) CountDownLatch(java.util.concurrent.CountDownLatch) TextProgressBarBuilder(org.fagu.fmv.textprogressbar.TextProgressBar.TextProgressBarBuilder) MPlayerTitles(org.fagu.fmv.soft.mplayer.MPlayerTitles) AtomicInteger(java.util.concurrent.atomic.AtomicInteger) TextProgressBar(org.fagu.fmv.textprogressbar.TextProgressBar) File(java.io.File)

Example 2 with MPlayerTitle

use of org.fagu.fmv.soft.mplayer.MPlayerTitle in project fmv by f-agu.

the class RipperTestCase method mPlayerTitles_1.

/**
 * @return
 */
private MPlayerTitles mPlayerTitles_1() {
    Map<String, String> properties = Collections.emptyMap();
    NavigableMap<Integer, MPlayerTitle> mPlayerTitleMap = new TreeMap<>();
    NavigableSet<Duration> chapters = new TreeSet<>();
    chapters.add(Duration.valueOf(10 * 60));
    chapters.add(Duration.valueOf(20 * 60));
    chapters.add(Duration.valueOf(30 * 60));
    MPlayerTitle mPlayerTitle = new MPlayerTitle(1, Duration.valueOf(84 * 60), chapters);
    mPlayerTitleMap.put(4, mPlayerTitle);
    return new MPlayerTitles(properties, mPlayerTitleMap);
}
Also used : TreeSet(java.util.TreeSet) MPlayerTitle(org.fagu.fmv.soft.mplayer.MPlayerTitle) Duration(org.fagu.fmv.utils.time.Duration) TreeMap(java.util.TreeMap) MPlayerTitles(org.fagu.fmv.soft.mplayer.MPlayerTitles)

Aggregations

MPlayerTitle (org.fagu.fmv.soft.mplayer.MPlayerTitle)2 MPlayerTitles (org.fagu.fmv.soft.mplayer.MPlayerTitles)2 File (java.io.File)1 IOException (java.io.IOException)1 ArrayList (java.util.ArrayList)1 TreeMap (java.util.TreeMap)1 TreeSet (java.util.TreeSet)1 CountDownLatch (java.util.concurrent.CountDownLatch)1 AtomicInteger (java.util.concurrent.atomic.AtomicInteger)1 MPlayerDump (org.fagu.fmv.soft.mplayer.MPlayerDump)1 TextProgressBar (org.fagu.fmv.textprogressbar.TextProgressBar)1 TextProgressBarBuilder (org.fagu.fmv.textprogressbar.TextProgressBar.TextProgressBarBuilder)1 PercentPart (org.fagu.fmv.textprogressbar.part.PercentPart)1 SpinnerPart (org.fagu.fmv.textprogressbar.part.SpinnerPart)1 Duration (org.fagu.fmv.utils.time.Duration)1