我基於你原來畫圖的方法,添加了事件觸發的命令b[j].setActionCommand("b" + j);否則你不能在事件響應處理的方法中使用e.getActionCommand(),而且字元串的比較用equals方法比較好。現在可以運行了,你可以看一下:
import java.applet.Applet;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
public class drawing extends Applet implements ActionListener {
Button b[] = new Button[5];
String fontname = "仿宋_GB2312";
int style = Font.PLAIN;
int size = 24;
int index = 0;
Font myfont;
public void init() {
setSize(700,700);
myfont = new Font(fontname, style, size);
b[0] = new Button("扇形");
b[1] = new Button("圓形");
b[2] = new Button("三角形");
b[3] = new Button("長方形");
b[4] = new Button("橢圓形");
for (int j = 0; j < b.length; j++) {
b[j].setBounds(10, 10, 50, 20);
b[j].addActionListener(this);
b[j].setActionCommand("b" + j);
add(b[j]);
}
}
public void actionPerformed(ActionEvent e) {
if (e.getActionCommand().equals("b0")) {
index = 0;
repaint();
}
if (e.getActionCommand().equals("b1")) {
index = 1;
repaint();
}
if (e.getActionCommand().equals("b2")) {
index = 2;
repaint();
}
if (e.getActionCommand().equals("b3")) {
index = 3;
repaint();
}
if (e.getActionCommand().equals("b4")) {
index = 4;
repaint();
}
}
public void paint(Graphics g) {
switch (index) {
case 0:
g.fillArc(0, 60, 80, 60, 30, 120);
break;
case 1:
g.drawOval( 300, 50, 60, 60);
break;
case 2:
Polygon filledPolygon = new Polygon();
filledPolygon.addPoint(380, 50);
filledPolygon.addPoint(380, 110);
filledPolygon.addPoint(450, 90);
g.drawPolygon(filledPolygon);
break;
case 3:
g.drawRect( 200, 50, 80, 60);
break;
case 4:
g.drawOval(100, 50, 80, 60);
break;
default:
g.fillArc(0, 60, 80, 60, 30, 120);
break;
}
}
/*
* public void paint(Graphics g) { g.fillArc( 0, 60, 80, 60, 30, 120);
* //繪制扇形 g.drawOval( 100, 50, 80, 60); g.drawRect( 200, 50, 80, 60);
* g.drawOval( 300, 50, 60, 60); Polygon filledPolygon=new Polygon();
* filledPolygon.addPoint(380,50); filledPolygon.addPoint(380,110);
* filledPolygon.addPoint(450,90); g.drawPolygon(filledPolygon); }
*/
}
B. Java知多少Graphics2D類的繪圖方法
Java語言在Graphics類提供繪制各種基本的幾何圖形的基礎上,擴展Graphics類提供一個Graphics2D類,它擁用更強大的二維圖形處理能力,提供、坐標轉換、顏色管理以及文字布局等更精確的控制。
繪圖屬性
Graphics2D定義了幾種方法,用於添加或改變圖形的狀態屬性。可以通過設定和修改狀態屬性,指定畫筆寬度和畫筆的連接方式;設定平移、旋轉、縮放或修剪變換圖形;以及設定填充圖形的顏色和圖案等。圖形狀態屬性用特定的對象存儲。
1. stroke屬性
stroke屬性控制線條的寬度、筆形樣式、線段連接方式或短劃線圖案。該屬性的設置需要先創建BasicStroke對象,再調用setStroke()方法來設置。創建BasicStroke對象的方法有:
BasicStroke(float w):指定線條寬w。
BasicStroke(float w,int cap, int join):
cap是端點樣:CAP_BUTT(無修飾),CAP_ROUND(半圓形末端),CAP_SQUARE(方形末端,默認值)。
Join定義兩線段交匯處的連接方式:JOIN_BEVEL(無修飾),JOIN_MTTER(尖形末端,默認值),JOIN_ROUND(圓形末端)。
2. paint屬性
paint屬性控制填充效果。先調用以下方法確定填充效果,理用setPaint()方法設置。
GradientPaint(float x1,float y1,Color c1,float x2,flaot y2,Color c2):從(x1,y1)到(x2,y2)顏色從c1漸變到c2。其中:參數c1,c2決定這個漸變色是從顏色c1漸變到顏色c2。參數x1,y1,x2,y2決定了漸變的強弱,即要求從點(x1,y1)出發到達點(x2,y2),顏色從c1變成c2。
GradientPaint(float x1,float y1,Color c1,float x2,float y2,Color c2,Boolean cyclic):如果希望漸變到終點又是起點的顏色,應將cyclic設置為true。
3. transform屬性
transform 屬性用來實現常用的圖形平移、縮放和斜切等變換操作。首先創建AffineTransform對象,然後調用setTransform()方法設置transform屬性。最後,用具有指定屬性的Graphics2D對象繪制圖形。創建AffineTransform對象的方法有:
getRotateinstrance(double theta):旋轉theta弧度。
getRotateInstance(double theta,dioble x,double y):繞旋轉中心(x,y)旋轉。
getScaleInstance(double sx,double sy):x和y 方向分別按sx,sy比例變換。
getTranslateInstance(double tx,double ty):平移變換。
getShearInstance(double shx,double shy):斜切變換,shx和shy指定斜拉度。
也可以先創建一個沒有transform屬性的AffineTransform對象,然後用以下方法指定圖形平移、旋轉、縮放變換屬性。
transelate(double dx,double dy):將圖形在x軸方向平移dx像素。
scale(double sx,double sy):圖形在x軸方向縮放sx倍,縱向縮放sy倍。
rotate(double arc,double x, double y):圖形以點(x,y)為軸點,旋轉arc弧度。
例如,創建AffineTransform對象:
AffineTransform trans = new AffineTransform();
為AffineTransform對象指定繞點旋轉變換屬性:
Trans.rotate(50.0*3.1415927/180.0,90,80);
接著為Graphics2D 的對象g2d設置具有上述旋轉變換功能的「畫筆」:
Graphics2D g2d = (Graphics2D)g;g2d.setTranstorm(trans);
最後,以圖形對象為參數調用具有變換功能的Graphics2D 對象的draw()方法。例如,設已有一個二次曲線對象curve,以下代碼實現用上述旋轉功能的g2d對象繪制這條二次曲線:
g2d.draw(curve);
4. clip屬性
clip屬性用於實現剪裁效果。設置剪裁屬性可調用setClip()方法確定剪裁區的Shape。連續多個setClip()得到它們交集的剪裁區。
5. composit屬性
composit屬性設置圖形重疊區域的效果。先用方法AlphaComposite.getInstance(int rule, float alpha)得到AlphaComposite對象,再通過setComposite()方法設置混合效果。Alpha值的范圍為0.0f(完全透明)-0.1f(完全不透明)。
Graphics2D類的繪圖方法
Graphics2D類仍然保留Graphics類的繪圖方法,同時增加了許多新方法。新方法將幾何圖形(線段、圓等)作為一個對象來繪制。在java.awt.geom包中聲明的一系列類,分別用於創建各種身體圖形對象。主要有:
Line2D線段類,RoundRectangle2D圓角矩形類,Ellipse2D橢圓類,Arc2D圓弧類,QuadCurve2D二次曲線類,CubicCurve2D三次曲線類。
要用Graphics2D類的新方法畫一個圖形。先在重畫方法paintComponent()或paint()中,把參數對象g強制轉換成Graphics2D對象;然後,用上述圖形類提供的靜態方法Double()創建該圖形的對象;最後,以圖形對象為參數調用Graphics2D對象的draw()方法繪制這個圖形。例如以下代碼用Graphics2D的新方法繪制線段和圓角矩形:
Graphics2D g2d = (Graphics2D)g;//將對象g類型從Graphics轉換成Graphics2D
Line2D line = new Line2D.Double(30.0,30.0,340.0,30.0);
g2d.draw(line);
RoundRectangle2D rRect = new RoundRectangle2D.Double(13.0,30.0,100.0,70.0,40.0,20.0);
g2d.draw(rRect);
也可以先用java.awt.geom包提供的Shape對象,並用單精度Float坐標或雙精度Double坐標創建Shape對象,然後再用draw()方法繪制。例如,以下代碼先創建圓弧對象,然後繪制圓弧:
Shape arc = new Arc2D.Float(30,30,150,150,40,100,Arc2D.OPEN);
g2d.draw(arc)/繪制前面創建的圖形對象arc
C. java關於graphics2d
Java中的Graphics2D是用於二維圖形繪制的類。它是Java 2D API的核心部分,提供了一個高級的繪圖界面,可以在應用程序窗口中進行圖形渲染和繪圖操作。通過Graphics2D對象,可以實現繪制線條、填充形狀、渲染文本和圖像等功能。它是基於坐標系統的,允許開發人員使用各種繪圖方法和屬性來創建復雜的圖形和圖像。
Graphics2D概述
Java的Graphics2D是一個強大的繪圖工具,它允許開發者在Java應用程序中創建和操作二維圖形。它是Java 2D API的一部分,該API為Java開發人員提供了高級的二維圖形渲染功能。
Graphics2D的主要功能
1. 繪制基本圖形:使用Graphics2D,可以輕松繪制線條、矩形、橢圓、圓弧等。
2. 填充和描邊:可以填充形狀並為其設置邊框。
3. 文本渲染:能夠在指定的位置和樣式渲染文本。
4. 圖像處理:可以在圖形上載入、處理和顯示圖像。
5. 坐標系統操作:Graphics2D基於坐標系統,可以進行坐標變換,如平移、旋轉和縮放。
使用Graphics2D
要使用Graphics2D進行繪圖,通常需要先獲取一個組件的Graphics對象,然後將其轉換為Graphics2D。這通常在組件的paint方法中完成。開發者可以通過設置屬性,如顏色、字體、畫筆樣式等,來自定義繪圖的外觀。此外,還可以利用路徑來創建復雜的圖形形狀。
總結
總的來說,Java中的Graphics2D為開發者提供了一個強大且靈活的二維圖形繪制工具。無論是簡單的形狀繪制還是復雜的圖形渲染,都可以通過Graphics2D來實現。它為Java應用程序提供了豐富的圖形功能,使得開發圖形密集型應用變得簡單和直觀。
D. 感覺用java做出來的圖形界面比較難看啊有什麼好的處理方法嗎請高手指點
try {
UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch ( e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
把上面的代碼放到main的一開始,這樣你的程序裡面的按鈕什麼的就跟操作系統的那些按鈕一致了,比默認的好看