使用Java生成jpg與壓縮圖片為jpg文件的代碼示例
Java生成jpg格式圖片:
package other.pic; import com.sun.image.codec.jpeg.JPEGCodec; import com.sun.image.codec.jpeg.JPEGImageEncoder; import java.io.BufferedOutputStream; import java.io.FileOutputStream; import java.io.RandomAccessFile; import java.awt.image.BufferedImage; import java.awt.*; import java.util.Random; /** * Created by IntelliJ IDEA. * User: Administrator * Date: 2005-6-10 * Time: 11:19:49 * This class can create jpg picture. * To change this template use File | Settings | File Templates. */ public class ChartGraphics { BufferedImage image; void createImage(String fileLocation) { try { FileOutputStream fos = new FileOutputStream(fileLocation); BufferedOutputStream bos = new BufferedOutputStream(fos); JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(bos); encoder.encode(image); bos.close(); } catch (Exception e) { e.printStackTrace(); } } public void graphicsGeneration(int h1, int h2, int h3, int h4, int h5) { final int X = 10; int imageWidth = 300;//圖片的寬度 int imageHeight = 300;//圖片的高度 int columnWidth = 30;//柱的寬度 int columnHeight = 200;//柱的最大高度 // ChartGraphics chartGraphics = new ChartGraphics(); image = new BufferedImage(imageWidth, imageHeight, BufferedImage.TYPE_INT_RGB); Graphics graphics = image.getGraphics(); graphics.setColor(Color.white); graphics.fillRect(0, 0, imageWidth, imageHeight); graphics.setColor(Color.red); graphics.drawRect(X + 1 * columnWidth, columnHeight - h1, columnWidth, h1); graphics.drawRect(X + 2 * columnWidth, columnHeight - h2, columnWidth, h2); graphics.drawRect(X + 3 * columnWidth, columnHeight - h3, columnWidth, h3); graphics.drawRect(X + 4 * columnWidth, columnHeight - h4, columnWidth, h4); graphics.drawRect(X + 5 * columnWidth, columnHeight - h5, columnWidth, h5); createImage("D://Temp//chart.jpg"); } public static void main(String[] args) { int[] height = {40,50,16,22,85}; ChartGraphics cg=new ChartGraphics(); try { for (int i = 0; i < 5; i++) { cg.graphicsGeneration(height[0],height[1],height[2],height[3],height[4]); } } catch (Exception e) { e.printStackTrace(); } } }
以下是生成的圖片
Java壓縮圖片為jpg縮略圖
我們?cè)诰W(wǎng)站上想上傳資料與大家分享時(shí),都會(huì)碰到一個(gè)這樣的問(wèn)題,隨著高分辨率DC的普及,上傳的圖片容量會(huì)很大,比如300萬(wàn)象素DC出來(lái)的文件基本不下600K.為了管理方便,大家可能不愿意每次都用ACDsee修改它,而直接上傳到服務(wù)器。但是這種做法在客戶端看來(lái)就沒(méi)有那么輕松了,對(duì)于撥號(hào)上網(wǎng)的用戶簡(jiǎn)直是一場(chǎng)惡夢(mèng),雖然你可以在圖片區(qū)域設(shè)置wide和high!問(wèn)題的解決之道來(lái)了!我們可以在類中處理一張大圖,并縮小它。前提是需要JDK1.4,這樣才能進(jìn)行處理。按以下方法做:
import java.io.File; import java.io.FileOutputStream; import java.awt.Graphics; import java.awt.Image; import java.awt.image.BufferedImage; import com.sun.image.codec.jpeg.JPEGCodec; import com.sun.image.codec.jpeg.JPEGImageEncoder; public class JpgTest { public void JpgTset() throws Exception{ File _file = new File("/Order005-0001.jpg"); //讀入文件 Image src = javax.imageio.ImageIO.read(_file); //構(gòu)造Image對(duì)象 int wideth=src.getWidth(null); //得到源圖寬 int height=src.getHeight(null); //得到源圖長(zhǎng) BufferedImage tag = new BufferedImage(wideth/2,height/2,BufferedImage.TYPE_INT_RGB); tag.getGraphics()。drawImage(src,0,0,wideth/2,height/2,null); //繪制縮小后的圖 FileOutputStream out=new FileOutputStream("newfile.jpg"); //輸出到文件流 JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out); encoder.encode(tag); //近JPEG編碼 System.out.print(width+"*"+height); out.close(); } }
過(guò)程很簡(jiǎn)單,從本地磁盤讀取文件Order005-0001.jpg(2032*1524),變成Image對(duì)象src,接著構(gòu)造目標(biāo)文件tag,設(shè)置tag的長(zhǎng)寬為源圖的一半,對(duì)tag進(jìn)行編碼,輸出到文件流out,最后關(guān)閉文件流。
還有一些問(wèn)題需要說(shuō)明:第一,目前只能支持JPG(JPEG)、GIF、PNG三種格式。第二,對(duì)于源圖的容量有限制,最好不要超過(guò)1M,否則會(huì)拋內(nèi)存不足的錯(cuò)誤,不過(guò)我試驗(yàn)過(guò)1.8M的源圖,可以成功,但是也很容易拋內(nèi)存不足。引用一位前輩的話:圖象運(yùn)算本身是密集型運(yùn)算,需要大量的內(nèi)存存放象素值。我用VC試了一下,4M的圖象也有問(wèn)題,而且越是壓縮比大的圖片在內(nèi)存中還原成BITMAP時(shí)需要的內(nèi)存越大。解決的方法,可以重寫編碼類,先開一定的內(nèi)存,然后一段一段編碼寫到臨時(shí)文件中,輸出的時(shí)候再一段一段讀出來(lái)?;蚶胣io的內(nèi)存映象來(lái)操作。JavaMail由于采用了Builder模式,先生成一個(gè)郵件的每一個(gè)部分,然后合并成一個(gè)完整的郵件對(duì)象,這樣每個(gè)構(gòu)件都要先生成到內(nèi)存中,你如果發(fā)送一個(gè)上百兆的附件,那么在構(gòu)造Part時(shí)肯定內(nèi)存溢出,所以我就改寫了BodyPart的構(gòu)造,讓他和一個(gè)臨時(shí)文件關(guān)聯(lián),然后用臨時(shí)文件保存Part而不是構(gòu)造在內(nèi)存中,這樣任義大小的附件(硬盤能放得下為限)都可以發(fā)送了。
最后,如果大家對(duì)圖像處理有更高的要求,不妨關(guān)注一下開源項(xiàng)目。比如JMagick,可以使用JMagick來(lái)實(shí)現(xiàn)圖片的復(fù)制、信息獲取、斜角、特效、組合、改變大小、加邊框、旋轉(zhuǎn)、切片、改變格式、去色等等功能。
PS:一些老的Java代碼在JDK下編譯會(huì)報(bào)錯(cuò),比如這個(gè):程序包c(diǎn)om.sun.image.codec.jpeg不存在。
JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out);
JPEGImageEncoder類是SUN公司私有類
一般出現(xiàn)在這樣的代碼段中:
FileOutputStream out = new FileOutputStream(dstName); JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out); encoder.encode(dstImage);
改寫成:
String formatName = dstName.substring(dstName.lastIndexOf(".") + 1); //FileOutputStream out = new FileOutputStream(dstName); //JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out); //encoder.encode(dstImage); ImageIO.write(dstImage, /*"GIF"*/ formatName /* format desired */ , new File(dstName) /* target */ );
都使用統(tǒng)一的ImageIO進(jìn)行圖像格式文件的讀寫,沒(méi)有必要使用過(guò)時(shí)的實(shí)現(xiàn)類JPEGImageEncoder類。
相關(guān)文章
Spring中@EnableScheduling實(shí)現(xiàn)定時(shí)任務(wù)代碼實(shí)例
這篇文章主要介紹了Spring中@EnableScheduling實(shí)現(xiàn)定時(shí)任務(wù)代碼實(shí)例,@EnableScheduling 注解開啟定時(shí)任務(wù)功能,可以將多個(gè)方法寫在一個(gè)類,也可以分多個(gè)類寫,當(dāng)然也可以將方法直接寫在上面ScheddulConfig類中,需要的朋友可以參考下2024-01-01mybatis sum(參數(shù)) 列名作為參數(shù)的問(wèn)題
這篇文章主要介紹了mybatis sum(參數(shù)) 列名作為參數(shù)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01Spring Cloud 配置中心內(nèi)容加密的配置方法
這篇文章主要介紹了Spring Cloud 配置中心內(nèi)容加密的配置方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-06-06解決mybatis無(wú)法給帶有下劃線屬性賦值問(wèn)題
這篇文章主要介紹了解決mybatis無(wú)法給帶有下劃線屬性賦值問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01SpringBoot整合EasyExcel實(shí)現(xiàn)導(dǎo)入導(dǎo)出數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了如何使用Vue、SpringBoot和EasyExcel實(shí)現(xiàn)導(dǎo)入導(dǎo)出數(shù)據(jù)功能,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-05-05