X-Git-Url: http://git.nikiroo.be/?a=blobdiff_plain;f=src%2Fbe%2Fnikiroo%2Ffanfix%2Fsupported%2FCbz.java;h=b041b6d468a30a81683465bef8968dd35c9c56e0;hb=83f66cbbd12246a5e2f1aeee1afe36503b901814;hp=012c0474a95df1a05cae162a9518e322f9099a80;hpb=08fe2e33007063e30fe22dc1d290f8afaa18eb1d;p=fanfix.git diff --git a/src/be/nikiroo/fanfix/supported/Cbz.java b/src/be/nikiroo/fanfix/supported/Cbz.java index 012c047..b041b6d 100644 --- a/src/be/nikiroo/fanfix/supported/Cbz.java +++ b/src/be/nikiroo/fanfix/supported/Cbz.java @@ -1,17 +1,23 @@ package be.nikiroo.fanfix.supported; +import java.awt.image.BufferedImage; import java.io.File; import java.io.IOException; import java.io.InputStream; import java.net.URL; import java.util.ArrayList; +import java.util.Collections; +import java.util.List; import java.util.zip.ZipEntry; import java.util.zip.ZipInputStream; +import javax.imageio.ImageIO; + import be.nikiroo.fanfix.Instance; import be.nikiroo.fanfix.data.Chapter; import be.nikiroo.fanfix.data.Paragraph; import be.nikiroo.fanfix.data.Story; +import be.nikiroo.utils.Progress; /** * Support class for CBZ files (works better with CBZ created with this program, @@ -39,12 +45,6 @@ class Cbz extends Epub { protected boolean requireInfo() { return false; } - - @Override - public boolean isImageDocument(URL source, InputStream in) - throws IOException { - return true; - } @Override protected boolean getCover() { @@ -52,14 +52,33 @@ class Cbz extends Epub { } @Override - public Story process(URL url) throws IOException { - Story story = processMeta(url, false, true); + protected void preprocess(URL source, InputStream in) throws IOException { + super.preprocess(source, in); + meta.setImageDocument(true); + } + + @Override + public Story process(URL url, Progress pg) throws IOException { + if (pg == null) { + pg = new Progress(); + } else { + pg.setMinMax(0, 100); + } + + Progress pgMeta = new Progress(); + pg.addProgress(pgMeta, 10); + Story story = processMeta(url, false, true, pgMeta); + if (!pgMeta.isDone()) { + pgMeta.setProgress(pgMeta.getMax()); // 10% + } + story.setChapters(new ArrayList()); Chapter chap = new Chapter(1, null); story.getChapters().add(chap); ZipInputStream zipIn = new ZipInputStream(getInput()); + List images = new ArrayList(); for (ZipEntry entry = zipIn.getNextEntry(); entry != null; entry = zipIn .getNextEntry()) { if (!entry.isDirectory() @@ -73,14 +92,10 @@ class Cbz extends Epub { } if (imageEntry) { + String uuid = meta.getUuid() + "_" + entry.getName(); try { - // we assume that we can get the UUID without a stream - String uuid = getUuid(url, null) + "_" - + entry.getName(); - - Instance.getCache().addToCache(zipIn, uuid); - chap.getParagraphs().add( - new Paragraph(new File(uuid).toURI().toURL())); + File tmp = Instance.getCache().addToCache(zipIn, uuid); + images.add(tmp.toURI().toURL().toString()); } catch (Exception e) { Instance.syserr(e); } @@ -88,6 +103,33 @@ class Cbz extends Epub { } } + pg.setProgress(80); + + // ZIP order is not correct for us + Collections.sort(images); + pg.setProgress(90); + + for (String uuid : images) { + try { + chap.getParagraphs().add(new Paragraph(new URL(uuid))); + } catch (Exception e) { + Instance.syserr(e); + } + } + + if (meta.getCover() == null && !images.isEmpty()) { + InputStream in = Instance.getCache().open(new URL(images.get(0)), + this, true); + try { + BufferedImage fcover = ImageIO.read(in); + meta.setCover(fcover); + meta.setFakeCover(true); + } finally { + in.close(); + } + } + + pg.setProgress(100); return story; } }