X-Git-Url: http://git.nikiroo.be/?p=nikiroo-utils.git;a=blobdiff_plain;f=src%2Fbe%2Fnikiroo%2Ffanfix%2Fsupported%2FCbz.java;h=f67f28ae6f936af9235305b8c568e4ad8ed7310f;hp=02c667c1032be681186b4e786907243c046eafd9;hb=2a25f7814eec9854022f1c9dee188bfbdb955591;hpb=62c63b0724f4bc45999cb2e7186b4b3ada479a0a diff --git a/src/be/nikiroo/fanfix/supported/Cbz.java b/src/be/nikiroo/fanfix/supported/Cbz.java index 02c667c..f67f28a 100644 --- a/src/be/nikiroo/fanfix/supported/Cbz.java +++ b/src/be/nikiroo/fanfix/supported/Cbz.java @@ -1,22 +1,22 @@ 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.HashMap; import java.util.List; +import java.util.Map; 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.ImageUtils; import be.nikiroo.utils.Progress; /** @@ -68,9 +68,7 @@ class Cbz extends Epub { Progress pgMeta = new Progress(); pg.addProgress(pgMeta, 10); Story story = processMeta(url, false, true, pgMeta); - if (!pgMeta.isDone()) { - pgMeta.setProgress(pgMeta.getMax()); // 10% - } + pgMeta.done(); // 10% story.setChapters(new ArrayList()); Chapter chap = new Chapter(1, null); @@ -78,7 +76,7 @@ class Cbz extends Epub { ZipInputStream zipIn = new ZipInputStream(getInput()); - List images = new ArrayList(); + Map images = new HashMap(); for (ZipEntry entry = zipIn.getNextEntry(); entry != null; entry = zipIn .getNextEntry()) { if (!entry.isDirectory() @@ -94,39 +92,36 @@ class Cbz extends Epub { if (imageEntry) { String uuid = meta.getUuid() + "_" + entry.getName(); try { - File tmp = Instance.getCache().addToCache(zipIn, uuid); - images.add(tmp.toURI().toURL().toString()); + images.put(uuid, ImageUtils.fromStream(zipIn)); } catch (Exception e) { Instance.getTraceHandler().error(e); } + + if (pg.getProgress() < 85) { + pg.add(1); + } } } } - pg.setProgress(80); + pg.setProgress(85); // ZIP order is not correct for us - Collections.sort(images); + List imagesList = new ArrayList(images.keySet()); + Collections.sort(imagesList); + pg.setProgress(90); - for (String uuid : images) { + for (String uuid : imagesList) { try { - chap.getParagraphs().add(new Paragraph(new URL(uuid))); + chap.getParagraphs().add(new Paragraph(images.get(uuid))); } catch (Exception e) { Instance.getTraceHandler().error(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(); - } + meta.setCover(images.get(imagesList.get(0))); } pg.setProgress(100);