X-Git-Url: http://www2.svjatoslav.eu/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Feu%2Fsvjatoslav%2Fmeviz%2Fhtmlindexer%2Fmetadata%2FfileTypes%2FPicture.java;h=1f5b2722a8d9c0d5f9f6a8da1df93d81dfcde38c;hb=9a96d6cd7fa903f3da1ff8e25d87316db3526678;hp=7a1ba39df99dd5b0d2447566ab1480988d300988;hpb=52c7290c1d1a4f73df6f212fec87f8ae4d3a7248;p=meviz.git diff --git a/src/main/java/eu/svjatoslav/meviz/htmlindexer/metadata/fileTypes/Picture.java b/src/main/java/eu/svjatoslav/meviz/htmlindexer/metadata/fileTypes/Picture.java index 7a1ba39..1f5b272 100755 --- a/src/main/java/eu/svjatoslav/meviz/htmlindexer/metadata/fileTypes/Picture.java +++ b/src/main/java/eu/svjatoslav/meviz/htmlindexer/metadata/fileTypes/Picture.java @@ -5,7 +5,7 @@ * This program is free software; you can redistribute it and/or * modify it under the terms of version 3 of the GNU Lesser General Public License * or later as published by the Free Software Foundation. -*/ + */ package eu.svjatoslav.meviz.htmlindexer.metadata.fileTypes; @@ -127,29 +127,29 @@ public class Picture extends AbstractFile { private static void makeJpegThumbnail(File inputFile, File outputFile, java.awt.Dimension preferredTargetDimensions) throws IOException, ImageFormatError { - final BufferedImage inputImage = getBufferedImage(inputFile); + final BufferedImage inputImage = getBufferedImage(inputFile); - final java.awt.Dimension sourceImageDimension = new java.awt.Dimension( - inputImage.getWidth(), inputImage.getHeight()); + final java.awt.Dimension sourceImageDimension = new java.awt.Dimension( + inputImage.getWidth(), inputImage.getHeight()); - final java.awt.Dimension targetDimensions = getTargetThumbnailDimension( - sourceImageDimension, preferredTargetDimensions); + final java.awt.Dimension targetDimensions = getTargetThumbnailDimension( + sourceImageDimension, preferredTargetDimensions); - final OutputStream out = new FileOutputStream(outputFile); + final OutputStream out = new FileOutputStream(outputFile); - final Image scaledImage = scaleImage(inputImage, - targetDimensions.width, targetDimensions.height); + final Image scaledImage = scaleImage(inputImage, + targetDimensions.width, targetDimensions.height); - final BufferedImage bufferedImage = new BufferedImage( - scaledImage.getWidth(null), scaledImage.getHeight(null), - TYPE_INT_RGB); + final BufferedImage bufferedImage = new BufferedImage( + scaledImage.getWidth(null), scaledImage.getHeight(null), + TYPE_INT_RGB); - final Graphics2D g = bufferedImage.createGraphics(); - g.drawImage(scaledImage, 0, 0, null); - g.dispose(); + final Graphics2D g = bufferedImage.createGraphics(); + g.drawImage(scaledImage, 0, 0, null); + g.dispose(); - ImageIO.write(bufferedImage, "jpg", out); - out.close(); + ImageIO.write(bufferedImage, "webp", out); + out.close(); } private static void makeGifThumbnail( @@ -166,8 +166,6 @@ public class Picture extends AbstractFile { System.out.println("Desired target image dimensions:" + targetDimensions); - FileInputStream fiStream = new FileInputStream( inputFile ); - ImageReader reader = ImageIO.getImageReadersByFormatName("gif").next(); ImageInputStream stream = ImageIO.createImageInputStream(inputFile); reader.setInput(stream); @@ -175,23 +173,23 @@ public class Picture extends AbstractFile { Utils.ImageFrame[] frames = Utils.readGIF(reader); for (Utils.ImageFrame frame : frames) { Image scaleImage = scaleImage(frame.image, targetDimensions.width, targetDimensions.height); - BufferedImage bimage = new BufferedImage( + BufferedImage bImage = new BufferedImage( targetDimensions.width, targetDimensions.height, BufferedImage.TYPE_INT_ARGB); - Graphics2D bGr = bimage.createGraphics(); + Graphics2D bGr = bImage.createGraphics(); bGr.drawImage(scaleImage, 0, 0, null); bGr.dispose(); - frame.image = bimage; + frame.image = bImage; } - ImageOutputStream output = new FileImageOutputStream(outputFile ); + ImageOutputStream output = new FileImageOutputStream(outputFile); GifSequenceWriter writer = - new GifSequenceWriter( output, frames[0].image.getType(), frames[0].getDelay(), true ); + new GifSequenceWriter(output, frames[0].image.getType(), frames[0].getDelay(), true); - writer.writeToSequence( frames[0].image ); - for ( int i = 1; i < frames.length; i++ ) { + writer.writeToSequence(frames[0].image); + for (int i = 1; i < frames.length; i++) { BufferedImage nextImage = frames[i].image; - writer.writeToSequence( nextImage ); + writer.writeToSequence(nextImage); } writer.close(); @@ -224,7 +222,6 @@ public class Picture extends AbstractFile { + getFileLength() + " " + Constants.THUMBNAIL_VERSION; - // System.out.println("Computing hash from: " + forMagicHash); return Utils.getStringCrcAsHex(forMagicHash); } @@ -237,8 +234,10 @@ public class Picture extends AbstractFile { * relative to designated thumbnails directory within parent directory. */ public String getRelativeThumbnailFileName(final Dimension targetDimension) { + String thumbnailExtension = "gif".equalsIgnoreCase(getFileExtension()) ? "gif" : "webp"; + return FilePathParser.getFileNameWithoutExtension(fileName) + " (" - + computeThumbnailHash(targetDimension) + ")." + getFileExtension(); + + computeThumbnailHash(targetDimension) + ")." + thumbnailExtension; } @Override