日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java 图片处理——如何生成高清晰度而占有磁盘小的缩略图

發布時間:2025/4/9 java 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java 图片处理——如何生成高清晰度而占有磁盘小的缩略图 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

現在的web項目,圖片越來越多,圖片大小也越來越大,隨便就能達到1M,2M,甚至更大。用戶上傳的圖片,一般是無法直接使用的。一般要生成兩三 種對應的縮略圖,分別適配不同的終端,不同的場景。比如PC,手機,平板等等不同的終端;在比如圖片列表和圖片詳情,肯定一個要使用縮略圖,一個要使用高 清圖。

一般圖片優化的第一步,就是在適當的地方使用縮略圖,盡量不要在web端使用CSS縮放高清原始圖片。下面分析了Java中如何生成不同的縮略圖的技術。

常見的圖片格式有: ".*\\.(?i)(jpg|jpeg|gif|bmp|png)"

這其中有分為了兩種,png 和 gif 是一種,其它格式是一種,因為 png 和 gif 存在透明度的問題,如果按照jpg一樣處理,就會導致生成黑色背景的圖片。

1. 指定高度等比例 縮放圖片:

/*** 按指定高度 等比例縮放圖片* * @param imageFile* @param newPath * @param newWidth 新圖的寬度 * @throws IOException */ public static void zoomImageScale(File imageFile, String newPath, int newWidth) throws IOException { if(!imageFile.canRead()) return; BufferedImage bufferedImage = ImageIO.read(imageFile); if (null == bufferedImage) return; int originalWidth = bufferedImage.getWidth(); int originalHeight = bufferedImage.getHeight(); double scale = (double)originalWidth / (double)newWidth; // 縮放的比例 int newHeight = (int)(originalHeight / scale); zoomImageUtils(imageFile, newPath, bufferedImage, newWidth, newHeight); } private static void zoomImageUtils(File imageFile, String newPath, BufferedImage bufferedImage, int width, int height) throws IOException{ String suffix = StringUtils.substringAfterLast(imageFile.getName(), "."); // 處理 png 背景變黑的問題 if(suffix != null && (suffix.trim().toLowerCase().endsWith("png") || suffix.trim().toLowerCase().endsWith("gif"))){ BufferedImage to= new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); Graphics2D g2d = to.createGraphics(); to = g2d.getDeviceConfiguration().createCompatibleImage(width, height, Transparency.TRANSLUCENT); g2d.dispose(); g2d = to.createGraphics(); Image from = bufferedImage.getScaledInstance(width, height, Image.SCALE_AREA_AVERAGING); g2d.drawImage(from, 0, 0, null); g2d.dispose(); ImageIO.write(to, suffix, new File(newPath)); }else{ // 高質量壓縮,其實對清晰度而言沒有太多的幫助 // BufferedImage tag = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); // tag.getGraphics().drawImage(bufferedImage, 0, 0, width, height, null); // // FileOutputStream out = new FileOutputStream(newPath); // 將圖片寫入 newPath // JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out); // JPEGEncodeParam jep = JPEGCodec.getDefaultJPEGEncodeParam(tag); // jep.setQuality(1f, true); //壓縮質量, 1 是最高值 // encoder.encode(tag, jep); // out.close(); BufferedImage newImage = new BufferedImage(width, height, bufferedImage.getType()); Graphics g = newImage.getGraphics(); g.drawImage(bufferedImage, 0, 0, width, height, null); g.dispose(); ImageIO.write(newImage, suffix, new File(newPath)); } }

上面中 zoomImageScale可以指定生成圖片的高度,然后寬度按照原始圖的 高寬比 計算出新圖片的寬度;同理也可以 指定生成圖片的寬度,來等比例生成新圖片。zoomImageUtils 方法中涉及到了三種圖片處理方法:

1)圖片的按照指定高度,寬度 進行普通的重繪

BufferedImage newImage = new BufferedImage(width, height, bufferedImage.getType());Graphics g = newImage.getGraphics();g.drawImage(bufferedImage, 0, 0, width, height, null);g.dispose();ImageIO.write(newImage, suffix, new File(newPath));

2)利用JPEGImageEncoder生成所謂的“高質量”的圖片

// 高質量壓縮,其實對清晰度而言沒有太多的幫助 // BufferedImage tag = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); // tag.getGraphics().drawImage(bufferedImage, 0, 0, width, height, null); // // FileOutputStream out = new FileOutputStream(newPath); // 將圖片寫入 newPath // JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out); // JPEGEncodeParam jep = JPEGCodec.getDefaultJPEGEncodeParam(tag); // jep.setQuality(1f, true); //壓縮質量, 1 是最高值 // encoder.encode(tag, jep); // out.close();

這種方法,其實僅僅是生成的圖片所占硬盤更大而已,但是實際上,對圖片的清晰度而已,沒有實際的作用。

3)png 和 gif 圖片不能采用上面說到的 圖片處理方法,因為會導致生成的圖片背景變成黑色,要另外處理(指定透明處理):

BufferedImage to = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); Graphics2D g2d = to.createGraphics(); to = g2d.getDeviceConfiguration().createCompatibleImage(width,height, Transparency.TRANSLUCENT); g2d.dispose(); g2d = to.createGraphics(); Image from = bufferedImage.getScaledInstance(width, height, Image.SCALE_AREA_AVERAGING); g2d.drawImage(from, 0, 0, null); g2d.dispose(); ImageIO.write(to, suffix, new File(newPath));

4)線性處理,本方法也不能處理 png 圖片:

/*** 等比例改變圖片尺寸* @param nw 新圖片的寬度* @param oldImage 原圖片 * @throws IOException */ public static void constrainProportios(int nw, String oldImage) throws IOException { AffineTransform transform = new AffineTransform(); BufferedImage bis = ImageIO.read(new File(oldImage)); int w = bis.getWidth(); int h = bis.getHeight(); int nh = (nw * h) / w; double sx = (double) nw / w; double sy = (double) nh / h; transform.setToScale(sx, sy); AffineTransformOp ato = new AffineTransformOp(transform, null); BufferedImage bid = new BufferedImage(nw, nh, BufferedImage.TYPE_3BYTE_BGR); ato.filter(bis, bid); String newPath = StringUtils.substringBeforeLast(oldImage,".")+"_3."+StringUtils.substringAfterLast(oldImage,"."); ImageIO.write(bid, "jpeg", new File(newPath)); // ImageIO.write(bid, "jpeg", response.getOutputStream()); }

上面有4中圖片的生成方法,除了png需要另外處理之外,其它幾種圖片的處理方法,用實際生成的圖片的清晰度比較而言,實際上是差別不大,基本沒有明顯的差別。實際的測試發現,如果要生成的圖片和原始圖片,在清晰度上要達到用肉眼不能明顯區分它們的效果的話,關鍵的不是使用哪種圖片生成方法,關鍵的是不要讓生成的圖片的 width 和 height 太小!這個才是關鍵,實際測試發現,生成的圖片的 width 和 height 最好不要小于500,一定不要小于 400

2. 按照指定的高度和寬度生成圖片:

/*** 按尺寸縮放圖片* * @param imageFile* @param newPath * @param times * @throws IOException */ public static void zoomImage(File imageFile, String newPath, int width, int height) throws IOException { if (imageFile != null && !imageFile.canRead()) return; BufferedImage bufferedImage = ImageIO.read(imageFile); if (null == bufferedImage) return; zoomImageUtils(imageFile, newPath, bufferedImage, width, height); }

這里沒有按照原始圖片的 高寬比 來生成圖片,而是按照指定的 高度和寬度來生成圖片。一般而言,最好不要選擇這種處理方法,因為圖片會被壓縮或者拉伸,圖片會變得比較難看。

3. 實際效果比較:

1)原始圖片:600 x 800, 220k

2) 按照指定高度等比例生成的圖片,指定高度為448, 33.7k

3) 寬度和高度小于400的普通重繪的圖片,224 x 300, 12.9k

4) 寬度和高度小于400的 JPEGImageEncoder生成所謂的“高質量”的圖片,224 x 300, 63.4k

5)上面四種圖片在網頁中,按照同樣的指定的圖片CSS下面的表現:

img {height: auto;max-height: 300px;max-width: 224px;width: auto; }

可以比較明顯的看出,第一張和第二張圖片的清晰度是極其接近的,你甚至無法說出那張圖片更加清晰;而第三張和第四種圖片,從額前的頭發而言,就明顯的比第一張和第二張要差一些。

實際的圖片分別為:

第一張:按照指定高度等比例生成的圖片,指定高度為 448, 33.7k

第二張:原始圖片:600 x 800, 220k

第三張:寬度和高度小于400的普通重繪的圖片,224 x 300, 12.9k

第四張:寬度和高度小于400的 JPEGImageEncoder生成所謂的“高質量”的圖片,224 x 300, 63.4k

結論

生成的圖片的清晰度,主要取決于生成的圖片的高度和寬度的大小,而不是取決于圖片生成的算法;

如果要想達到肉眼無法分別的效果,生成圖片的高寬最好不要小于500,一定不要小于400;

-----

第四張圖片達到了63.4K,但是清晰度明顯差于第一張大小只有33.7K的圖片。圖片的寬度和高度的大小才是清晰度的決定因數。

第三張圖片只有 12.9K,而清晰度和第四張63.4K的圖片清晰度幾乎一樣,因為它們的尺寸是一樣的,都是224 x 300,盡管生成圖片的算法不一樣。

轉載于:https://www.cnblogs.com/likeju/p/4834741.html

總結

以上是生活随笔為你收集整理的Java 图片处理——如何生成高清晰度而占有磁盘小的缩略图的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 美国伊人网| 欧美成人a交片免费看 | 久久久久一区二区三区 | 国产精品第三页 | 亚洲影音先锋 | 老司机av福利 | 日韩av综合在线 | 五月婷婷激情在线 | 超碰在线人人草 | 亚洲国产爱 | 伊人伊人 | 国产精品zjzjzj在线观看 | 日韩欧美aaa | 自拍偷拍亚洲一区 | 一本色道综合久久欧美日韩精品 | 国产一级在线免费观看 | 国产人成精品 | chinese国产精品 | 在线综合网| 日韩美女视频一区二区 | 国产永久在线 | 免费观看一区 | 亚洲精品无amm毛片 国内一区二区三区 | 超碰人人超碰 | 色呦呦精品 | 成人无码精品1区2区3区免费看 | 欧美日韩一区二区三 | 超碰97色| jizz成熟丰满日本少妇 | 黄色福利视频网站 | 国产视频xxxx | 俺啪也 | 性色欲网站人妻丰满中文久久不卡 | 国产极品视频 | 欧美 日韩 成人 | 久草五月天 | 俄罗斯美女一级爱片 | 别揉我奶头啊嗯一区二区 | 91精品国产综合久久福利 | 国产激情视频在线观看 | 亚洲高清一区二区三区 | 亚洲网在线观看 | 国产成人无码精品久久久久 | 怎么可能高潮了就结束漫画 | 亚洲一区二区电影 | 爱草视频 | 在线免费看污片 | 中文字幕在线免费观看 | 精品人妻人伦一区二区有限公司 | 一级作爱视频 | 久久久99国产精品免费 | 农村末发育av片一区二区 | 亚州一二区 | 人人射人人插 | 国产激情精品 | 日韩有码中文字幕在线观看 | 朝鲜一级黄色片 | 亚洲在线成人 | 美女扒开腿让男人捅 | 日韩黄色视屏 | 亚洲人成无码网站久久99热国产 | 精品少妇一区二区 | 欧美日韩亚洲成人 | 欧美精品性视频 | 日韩性视频 | 无码人妻一区二区三区线 | 午夜插插插 | 日韩乱淫 | 好姑娘在线观看高清完整版电影 | 免费看黄色片的网站 | 久久久久亚洲无码 | 欧美做爰猛烈床戏大尺度 | 中文字幕在线播放av | 欧美不在线| 国产香蕉尹人视频在线 | 国产va在线 | 手机在线成人av | 老司机久久精品视频 | 国产一精品一aⅴ一免费 | 亚洲天堂国产精品 | 国产二区在线播放 | 小视频国产 | 国产欧美一级片 | 国产美女无遮挡免费视频 | 可以免费看的黄色 | 噜噜色综合 | 亚洲 欧美 变态 另类 综合 | 亚洲日本激情 | 伊人影院在线视频 | 青青操视频在线观看 | 日韩三级小视频 | 亚洲a∨无码无在线观看 | 国模精品一区二区三区 | 日本一级吃奶淫片免费 | 美女自拍偷拍 | 极品国产一区 | 在线免费观看一区二区 | 一级片在线免费观看 | 亚洲欧美日本一区二区三区 |