天天看點

圖形界面筆記

GUI 圖形使用者界面

GUI

   Graphical User Interface(圖形使用者接口)

   用圖形的方式,來顯示計算機操作的界面

CLI

   Command line User Interface(指令行使用者接口)

Java為GUI提供的對象都存在java.Awt和javax.Swing包中

java.Awt:Abstract Window Toolkit(抽象視窗工具包),

   需要調用本地系統方法實作功能。和系統的依賴性相對較強。

java.Swing:在Awt的基礎上,建立的一套圖形界面系統,

   其中提供了更多的元件,而且完全由java實作,增強了

   移植性。和系統的依賴性相對較弱。

Eclipse是純java編寫的,用的是Swt界面。

Component 建構{Container容器(Window視窗(Frame架構,Dialog對

話框(FileDialog)),Panel面闆),(Button,Label,

CheckBox,TextComponent文本元件(TextArea文本域 

多行文本,TextField文本框 單行))}

    Container:是一個特殊的元件,該元件可以通過add方法添加其他元件進來

布局管理器

   容器中的元件的排放方式即布局。

   常見的布局管理器:

     FlowLayout(流式布局管理器)

       從左到右的順序排列,預設元件都是居中的

       Panel預設的布局管理器

     BorderLayout(邊界布局管理器)

       東 南 西 北 中

       Frame預設的布局管理器

       若未指定方向,會以窗體最大面積填充窗體,添加新組建會覆寫

     GridLayout(網絡布局管理器)

       規則的矩陣

     CardLayout(卡片布局管理器)

       頁籤

     GridBagLayout(網格包布局管理器)

       非規則的矩陣

使用者對元件的操作就是一個事件。産生事件的元件就是事件源。

接受并處理事件,與使用者進行互動的行為就是事件處理器。

這些處理方式都封裝在監聽器中。

事件監聽機制的特點:

1.事件源   :就是awt包或者swing包中的那些圖形界面元件

2.事件     :每一個事件源都有自己特有的對應事件和共性事件

3.監聽器   :将可以觸發某一事件的動作(不止一個動作)都已經封裝到了監聽器中

4.事件處理

以上三者,在java中都已經定義好了。

直接擷取其對象用即可。

我們隻需對産生的動作進行處理即可。

import java.awt.*;
import java.awt.event.*;

/*
建立圖形化界面:
1.建立frame窗體
2.對窗體進行基本設定
	如大小、位置、布局
3.定義元件
4.将元件通過窗體的add方法添加到窗體中
5.通過setVisible(true)讓窗體顯示
*/

class  AwtDemo
{
	public static void main(String[] args) 
	{
		Frame f = new Frame("my awt");
		 //建立一個标題為my awt的窗體.構造一個最初不可見的Frame新執行個體.
		 //預設的是邊界式布局管理器
		f.setSize(500,100);//(寬,高)
		f.setLocation(300,100);//設定本地位置,(寬,高)

		f.setLayout(new FlowLayout());//設定布局管理器

		Button b = new Button("我是一個按鈕");
		 //建立一個按鈕,但此時按鈕跟窗體沒有聯系。
		 //需要使用容器的add方法加入按鈕
		 //因是邊界布局管理器且沒指定方向,會全窗體填充
		f.add(b);

		f.addWindowListener(new MyWin());
		/*或者寫成匿名内部類
		f.addWindowListener(new WindowAdapter()
		{
			public void windowClosing(Winevent e)
			{
				System.out.println("window closing");
				System.exit(0);
			}
		}
		);
		*/
		
		f.setVisible(true);
		 //setVisible(boolean b);根據參數b的值顯示或隐藏此元件


		System.out.println("Hello World!");
	}
}

/*
 class MyWin implements WindowListener
 {
	//覆寫7個方法,但隻用到關閉的動作。
	//其他動作都沒用到,但卻必須要複寫。
 }
*/

//因WindowListener的子類WindowAdapter已經實作了WindowListener接口,
//并覆寫了其中所有的方法。那麼隻要繼承自WindowAdapter覆寫需要的方法即可。
class MyWin extends WindowAdapter
{
	public void windowClosing(WindowEvent e)
		//WindowEvent 接收窗體事件
	{
		System.out.println("window closing---"+e.toString());
			//e.toString();  将事件列印出來

		System.exit(0);//退出java虛拟機
	}

	public void windowActivated(WindowEvent e)
	{
		System.out.println("window Activated--"+e.toString());//窗體置于最前端
	}

	public void windowOpened(WindowEvent e)
	{
		System.out.println("window Opened--"+e.toString()); //視窗首次變為可見時調用
	}
}





事件中的匿名内部類的方法名開頭必須小寫


import java.awt.*;
import java.awt.event.*;

class FrameDemo 
{
	//定義該圖形中所需的元件的引用
	private Frame f;
	private Button but;

	FrameDemo()
	{
		init();//一初始化就有圖形界面并具備一些基本事件
	}

	public void init()  //對圖形界面進行初始化
	{
		f = new Frame("My Frame");

		//對frame進行基本設定
		//f.setSize(int w,int h);//awt——>Component
		//f.setLocation(int x,int y);//移動到指定位置 awt——>Component
		f.setBounds(300,100,600,400);//(x,y,w,h)移動并調整大小
		f.setLayout(new FlowLayout());//設定布局管理器

		but = new Button("Exit");

		//将組建添加到frame中
		f.add(but);

		//加載一下窗體上的事件
		MyEvent();

		//顯示窗體
		f.setVisible(true);
	}

	private void MyEvent()
	{
		f.addWindowListener(new WindowAdapter()
		{
			public void windowClosing(WindowEvent e) //方法名開頭必須小寫
			{
				System.exit(0);
			}
		}
		);

		//讓按鈕具備退出程式的功能
		/*
		按鈕就是事件源。那麼應該選擇哪個監聽器呢?
		通過關閉窗體示例了解到,想要知道哪個元件具備什麼樣的特有監聽器,
		需要檢視該元件對象的功能。
		通過查閱button的描述,發現按鈕支援一個特有監聽——addActionListener.
		*/
		but.addActionListener(new ActionListener()
		{
			public void actionPerformed(ActionEvent e)
			{
				//System.out.println("按鈕幹的,退出");
				System.exit(0);
			}
		}
		);
	}

	public static void main(String[] args) 
	{
		new FrameDemo();
	}
}







import java.awt.*;
import java.awt.event.*;

class MouseAndKeyEvent 
{
	private Frame f;
	private Button but;
	private Button butE;
	private TextField tf;

	MouseAndKeyEvent()
	{
		init();
	}

	public void init()
	{
		f = new Frame("My Frame");

		f.setBounds(300,300,500,500);

		f.setLayout(new FlowLayout());

		tf = new TextField(10); //隻能指定列數

		but = new Button("Button");
		butE = new Button("Esc");

		f.add(tf);//添加文本框

		f.add(but);
		f.add(butE);

		MyEvent();

		f.setVisible(true);
	}

	private void MyEvent()
	{
		f.addWindowListener(new WindowAdapter()
		{
			public void windowClosing(WindowEvent e)
			{
				System.exit(0);
			}
		}
		);

		//要求:文本框中隻能輸入數字,其他的不能輸入到文本框中
		tf.addKeyListener(new KeyAdapter()
		{
			public void keyPressed(KeyEvent e)
			{
				int code = e.getKeyCode();
				if(!(code>=KeyEvent.VK_0&&code<=KeyEvent.VK_9))
					//此處的0~9是主鍵盤中的不是小鍵盤中的
					{
						System.out.println(KeyEvent.getKeyText(code)+"..無效");
						e.consume();//不按照預設方式(其他字元輸入到文本框中)進行。
							
					}
			}
		}
		);


		//給But添加一個鍵盤監聽
		but.addKeyListener(new KeyAdapter()
		{
			public void keyPressed(KeyEvent e)
			{
				System.out.println(e.getKeyChar()+"...."+e.getKeyCode()+
					"..."+KeyEvent.getKeyText(e.getKeyCode()));
					//列印鍵與其對應的碼

				if(e.isControlDown()&&e.getKeyCode()==KeyEvent.VK_ENTER)//Esc對應的碼是27
					System.exit(0);
			}
		}
		);

		but.addActionListener(new ActionListener() //按鈕的活動監聽
		{
			public void actionPerformed(ActionEvent e)
			{
				System.out.println("action ok");
			}
		}
		);

		/*
		按鈕點選與按鈕活動監聽相比,按鈕點選先執行。

		按鈕隻要被活動按鈕監聽就會執行,滑鼠和鍵盤(空格)均能使按鈕活動。
		*/

		but.addMouseListener(new MouseAdapter()
		{
			private int count = 1;
			private int clickCount = 1;
			public void mouseEntered(MouseEvent e)
			{
				System.out.println("滑鼠進入按鈕區域"+(count++)+"次");
			}

			public void mouseClicked(MouseEvent e)
			{
				//System.out.println("點選動作"+clickCount++);

				if(e.getClickCount()==2)
					System.out.println("輕按兩下動作"+clickCount++);
			}
		}
		);

		butE.addMouseListener(new MouseAdapter()
		{
			public void mouseClicked(MouseEvent e)
			{
				System.exit(0);
			}
		}
		);
	}


	public static void main(String[] args) 
	{
		new MouseAndKeyEvent();
	}
}







import java.awt.*;
import java.awt.event.*;
import java.io.*;

class MyWindowDemo
{
	private Frame f;
	private TextField tf;
	private Button but;
	private TextArea ta;

	private Dialog d;
	private Label lab;
	private Button okBut;

	MyWindowDemo()
	{
		init();
	}

	public void init()
	{
		f = new Frame("My Window");
		f.setBounds(300,300,500,500);
		f.setLayout(new FlowLayout());

		tf = new TextField(30);

		but = new Button("轉到");

		ta = new TextArea(15,40);//(行,列)


		d = new Dialog(f,"提示資訊",true);
			//d是一個窗體,不要加到f中。因若加入,f打開d也會打開。
			//模式為true,此對話框不操作,其所屬窗體操作不了。
			//模式若為假,對話框不操作所屬窗體也能操作。
		d.setBounds(400,200,240,70);
		d.setLayout(new FlowLayout());
		lab = new Label();
		okBut = new Button("确定");

		d.add(lab);
		d.add(okBut);


		f.add(tf);
		f.add(but);
		f.add(ta);

		MyEvent();
		f.setVisible(true);
	}

	private void MyEvent()
	{
		/*
		d.addWindowListener(new WindowAdapter()
		{
			public void dialogClosing(WindowEvent e)
			{
				d.setVisible(false);//隻關閉對話框
			}
		}
		);*/

		okBut.addActionListener(new ActionListener()
		{
			public void actionPerformed(ActionEvent e)
			{
				d.setVisible(false);//隻關閉對話框
			}
		}
		);

		tf.addKeyListener(new KeyAdapter() //文本框是事件源
		{
			public void keyPressed(KeyEvent e)
			{
				if(e.getKeyCode()==KeyEvent.VK_ENTER)
				{
					showDir();
				}
			}
		}
		);


		but.addActionListener(new ActionListener()
		{
			public void actionPerformed(ActionEvent e)
			{
				/*
				String text = tf.getText();//傳回此文本元件表示的文本
				//System.out.println("Text:"+text);
				ta.setText(text);

				tf.setText("");//将文本框中資料轉到文本域後文本框中資料清空*/
				String dirPath = tf.getText();

				File dir = new File(dirPath);//需封裝成檔案以便後續判斷

				if(dir.exists()&&dir.isDirectory()) //必須存在且為目錄
				{
					ta.setText("");//若不清空,多次輸入路徑後顯示的檔案都會在。
					String[] names = dir.list();
						//list();傳回一個字元串數組,這些字元串指定此抽象路
						//徑名表示的目錄中的檔案和目錄
					for(String name:names)
					{
						/*
						ta.setText(name+"\r\n");
							//文本域中隻會出現一個檔案,因為會被覆寫。*/
						ta.append(name+"\r\n");//追加文本
							//将給定文本追加到文本區的目前文本。
					}
				}
				else
				{
					String info = "輸入有誤:"+dirPath+"!請重新輸入。";
					lab.setText(info);
					d.setVisible(true);	
				}

				//tf.setText(""); 清空文本框

			}
		}
		);

		f.addWindowListener(new WindowAdapter()
		{
			public void windowClosing(WindowEvent e)
			{
				System.exit(0);
			}
		}
		);
	}


	private void showDir() //将轉到動作封裝
		{
			String dirPath = tf.getText();

			File dir = new File(dirPath);

			if(dir.exists()&&dir.isDirectory())
			{
				ta.setText("");

				String[] names = dir.list();

				for(String name:names)
				{
					ta.append(name+"\r\n");
				}
			}
			else
			{
				String info = "輸入有誤:"+dirPath+"!請重新輸入。";
				lab.setText(info);
				d.setVisible(true);	
			}
		}


	public static void main(String[] args) 
	{
		new MyWindowDemo();
	}
}







import java.awt.*;
import java.awt.event.*;

class MyMenuDemo 
{
	private Frame f;
	private MenuBar mb;
	private Menu m,subMenu;
	private MenuItem closeItem,subItem;

	MyMenuDemo()
	{
		init();
	}

	public void init()
	{
		f = new Frame("My WindomMenu");
		f.setBounds(200,200,300,300);
		f.setLayout(new FlowLayout());

		mb = new MenuBar();

		m = new Menu("檔案");

		subMenu = new Menu("子菜單");//菜單有右箭頭,條目沒有

		subItem = new MenuItem("子條目");
		closeItem = new MenuItem("退出");

		subMenu.add(subItem);

		m.add(subMenu);
		m.add(closeItem);
		mb.add(m);

		f.setMenuBar(mb);

		MyEvent();

		f.setVisible(true);
	}

	private void MyEvent()
	{
		f.addWindowListener(new WindowAdapter()
		{
			public void windowClosing(WindowEvent e)
			{
				System.exit(0);
			}
		}
		);

		closeItem.addActionListener(new ActionListener()
		{
			public void actionPerformed(ActionEvent e)
			{
				System.exit(0);
			}
		}
		);
	}

	public static void main(String[] args) 
	{
		new MyMenuDemo();
	}
}
           
package MyMenu;

import java.awt.*;
import java.awt.event.*;
import java.io.*;


public class MyMenuTest 
{
<span style="white-space:pre">	</span>private Frame f;
<span style="white-space:pre">	</span>private MenuBar mb;
<span style="white-space:pre">	</span>private TextArea ta;
<span style="white-space:pre">	</span>private Menu fileMenu;
<span style="white-space:pre">	</span>private MenuItem openI,saveI,closeI;


<span style="white-space:pre">	</span>private FileDialog openDia,saveDia;


<span style="white-space:pre">	</span>private File file;


<span style="white-space:pre">	</span>MyMenuTest()
<span style="white-space:pre">	</span>{
<span style="white-space:pre">		</span>init();
<span style="white-space:pre">	</span>}


<span style="white-space:pre">	</span>public void init()
<span style="white-space:pre">	</span>{
<span style="white-space:pre">		</span>f = new Frame("My WindowMenu");
<span style="white-space:pre">		</span>f.setBounds(200,200,300,300);
<span style="white-space:pre">		</span>//f.setLayout(new FlowLayout());


<span style="white-space:pre">		</span>mb = new MenuBar();


<span style="white-space:pre">		</span>ta = new TextArea();


<span style="white-space:pre">		</span>fileMenu = new Menu("檔案");


<span style="white-space:pre">		</span>openI = new MenuItem("打開");
<span style="white-space:pre">		</span>saveI = new MenuItem("儲存");
<span style="white-space:pre">		</span>closeI = new MenuItem("退出");


<span style="white-space:pre">		</span>mb.add(fileMenu);
<span style="white-space:pre">		</span>fileMenu.add(openI);
<span style="white-space:pre">		</span>fileMenu.add(saveI);
<span style="white-space:pre">		</span>fileMenu.add(closeI);


<span style="white-space:pre">		</span>f.setMenuBar(mb);


<span style="white-space:pre">		</span>openDia = new FileDialog(f,"打開",FileDialog.LOAD);//模式預設為LOAD
<span style="white-space:pre">		</span>
<span style="white-space:pre">		</span>saveDia = new FileDialog(f,"儲存",FileDialog.SAVE);


<span style="white-space:pre">		</span>f.add(ta);


<span style="white-space:pre">		</span>MyEvent();


<span style="white-space:pre">		</span>f.setVisible(true);
<span style="white-space:pre">	</span>}


<span style="white-space:pre">	</span>private void MyEvent()
<span style="white-space:pre">	</span>{
<span style="white-space:pre">		</span>saveI.addActionListener(new ActionListener()
<span style="white-space:pre">		</span>{
<span style="white-space:pre">			</span>public void actionPerformed(ActionEvent e)
<span style="white-space:pre">			</span>{
<span style="white-space:pre">				</span>if(file==null)
<span style="white-space:pre">				</span>{
<span style="white-space:pre">					</span>saveDia.setVisible(true);


<span style="white-space:pre">					</span>String dirPath = saveDia.getDirectory();
<span style="white-space:pre">					</span>String fileName = saveDia.getFile();
<span style="white-space:pre">					</span>if(dirPath==null||fileName==null)
<span style="white-space:pre">						</span>return ;
<span style="white-space:pre">					</span>file = new File(dirPath,fileName);
<span style="white-space:pre">				</span>}
<span style="white-space:pre">				</span>
<span style="white-space:pre">				</span>try
<span style="white-space:pre">				</span>{
<span style="white-space:pre">					</span>BufferedWriter bufw = new BufferedWriter(new FileWriter(file));


<span style="white-space:pre">					</span>String text = ta.getText();


<span style="white-space:pre">					</span>bufw.write(text);
<span style="white-space:pre">					</span>bufw.close();
<span style="white-space:pre">				</span>}
<span style="white-space:pre">				</span>catch (IOException ie)
<span style="white-space:pre">				</span>{
<span style="white-space:pre">					</span>throw new RuntimeException();
<span style="white-space:pre">				</span>}
<span style="white-space:pre">			</span>}
<span style="white-space:pre">		</span>}
<span style="white-space:pre">		</span>);
<span style="white-space:pre">		</span>
<span style="white-space:pre">		</span>openI.addActionListener(new ActionListener()
<span style="white-space:pre">		</span>{
<span style="white-space:pre">			</span>public void actionPerformed(ActionEvent e)
<span style="white-space:pre">			</span>{
<span style="white-space:pre">				</span>openDia.setVisible(true);
<span style="white-space:pre">				</span>String dirPath = openDia.getDirectory();
<span style="white-space:pre">				</span>String fileName = openDia.getFile();
<span style="white-space:pre">				</span>//System.out.println(dirPath+"..."+fileName);//會在控台中列印
<span style="white-space:pre">				</span>//ta.setText(dirPath+"\\"+fileName);


<span style="white-space:pre">				</span>if(dirPath==null||fileName==null)
<span style="white-space:pre">					</span>return ;
<span style="white-space:pre">				</span>ta.setText("");
<span style="white-space:pre">				</span>file = new File(dirPath,fileName);


<span style="white-space:pre">				</span>try
<span style="white-space:pre">				</span>{
<span style="white-space:pre">					</span>BufferedReader bufr = new BufferedReader(new FileReader(file));


<span style="white-space:pre">					</span>String line = null;


<span style="white-space:pre">					</span>while((line=bufr.readLine())!=null)
<span style="white-space:pre">					</span>{
<span style="white-space:pre">						</span>ta.append(line+"\r\n");
<span style="white-space:pre">					</span>}
<span style="white-space:pre">				</span>}
<span style="white-space:pre">				</span>catch (IOException i)
<span style="white-space:pre">				</span>{
<span style="white-space:pre">					</span>throw new RuntimeException("讀取失敗!");
<span style="white-space:pre">				</span>}
<span style="white-space:pre">			</span>}
<span style="white-space:pre">		</span>}
<span style="white-space:pre">		</span>);


<span style="white-space:pre">		</span>f.addWindowListener(new WindowAdapter()
<span style="white-space:pre">		</span>{
<span style="white-space:pre">			</span>public void windowClosing(WindowEvent e)
<span style="white-space:pre">			</span>{
<span style="white-space:pre">				</span>System.exit(0);
<span style="white-space:pre">			</span>}
<span style="white-space:pre">		</span>}
<span style="white-space:pre">		</span>);


<span style="white-space:pre">		</span>closeI.addActionListener(new ActionListener()
<span style="white-space:pre">		</span>{
<span style="white-space:pre">			</span>public void actionPerformed(ActionEvent e)
<span style="white-space:pre">			</span>{
<span style="white-space:pre">				</span>System.exit(0);
<span style="white-space:pre">			</span>}
<span style="white-space:pre">		</span>}
<span style="white-space:pre">		</span>);
<span style="white-space:pre">	</span>}


<span style="white-space:pre">	</span>public static void main(String[] args) 
<span style="white-space:pre">	</span>{
<span style="white-space:pre">		</span>new MyMenuTest();
<span style="white-space:pre">	</span>}
}