Java生成jpg格式圖片:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
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縮略圖
我們在網站上想上傳資料與大家分享時,都會碰到一個這樣的問題,隨著高分辨率DC的普及,上傳的圖片容量會很大,比如300萬象素DC出來的文件基本不下600K.為了管理方便,大家可能不愿意每次都用ACDsee修改它,而直接上傳到服務器。但是這種做法在客戶端看來就沒有那么輕松了,對于撥號上網的用戶簡直是一場惡夢,雖然你可以在圖片區域設置wide和high!問題的解決之道來了!我們可以在類中處理一張大圖,并縮小它。前提是需要JDK1.4,這樣才能進行處理。按以下方法做:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
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); //構造Image對象 int wideth=src.getWidth( null ); //得到源圖寬 int height=src.getHeight( null ); //得到源圖長 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(); } } |
過程很簡單,從本地磁盤讀取文件Order005-0001.jpg(2032*1524),變成Image對象src,接著構造目標文件tag,設置tag的長寬為源圖的一半,對tag進行編碼,輸出到文件流out,最后關閉文件流。
還有一些問題需要說明:第一,目前只能支持JPG(JPEG)、GIF、PNG三種格式。第二,對于源圖的容量有限制,最好不要超過1M,否則會拋內存不足的錯誤,不過我試驗過1.8M的源圖,可以成功,但是也很容易拋內存不足。引用一位前輩的話:圖象運算本身是密集型運算,需要大量的內存存放象素值。我用VC試了一下,4M的圖象也有問題,而且越是壓縮比大的圖片在內存中還原成BITMAP時需要的內存越大。解決的方法,可以重寫編碼類,先開一定的內存,然后一段一段編碼寫到臨時文件中,輸出的時候再一段一段讀出來。或利用nio的內存映象來操作。JavaMail由于采用了Builder模式,先生成一個郵件的每一個部分,然后合并成一個完整的郵件對象,這樣每個構件都要先生成到內存中,你如果發送一個上百兆的附件,那么在構造Part時肯定內存溢出,所以我就改寫了BodyPart的構造,讓他和一個臨時文件關聯,然后用臨時文件保存Part而不是構造在內存中,這樣任義大小的附件(硬盤能放得下為限)都可以發送了。
最后,如果大家對圖像處理有更高的要求,不妨關注一下開源項目。比如JMagick,可以使用JMagick來實現圖片的復制、信息獲取、斜角、特效、組合、改變大小、加邊框、旋轉、切片、改變格式、去色等等功能。
PS:一些老的Java代碼在JDK下編譯會報錯,比如這個:程序包com.sun.image.codec.jpeg不存在。
1
|
JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out); |
JPEGImageEncoder類是SUN公司私有類
一般出現在這樣的代碼段中:
1
2
3
|
FileOutputStream out = new FileOutputStream(dstName); JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out); encoder.encode(dstImage); |
改寫成:
1
2
3
4
5
|
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 */ ); |
都使用統一的ImageIO進行圖像格式文件的讀寫,沒有必要使用過時的實現類JPEGImageEncoder類。