- 資訊首頁(yè) > 開(kāi)發(fā)技術(shù) > 編程語(yǔ)言 >
- Java圖形界面GUI布局方式(小結)
采用流式布局會(huì )將元素按從左到右的順序排列,如果一個(gè)元素在一行中放不下,那這個(gè)元素會(huì )另起一行依然按照從左到右的順序排列
示例:
代碼
public class Test { public static void main(String[] args) { // 創(chuàng )建窗口 JFrame jFrame = new JFrame(); // 設置窗口名稱(chēng) jFrame.setTitle("hello"); // 創(chuàng )建流式布局管理器 對齊方式為左對齊 LayoutManager layout = new FlowLayout(FlowLayout.LEFT); // 關(guān)閉窗口結束程序 jFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); // 創(chuàng )建內容面板 Container contentpage = jFrame.getContentPane(); // 設置內容面板布局方式為流布局 contentpage.setLayout(layout); // 創(chuàng )建按鈕 JButton button1 = new JButton("1"); JButton button2 = new JButton("2"); JButton button3 = new JButton("3"); JButton button4 = new JButton("4"); JButton button5 = new JButton("5"); // 設置按鈕大小 button1.setPreferredSize(new Dimension(100,100)); button2.setPreferredSize(new Dimension(100,100)); button3.setPreferredSize(new Dimension(100,100)); button4.setPreferredSize(new Dimension(100,100)); button5.setPreferredSize(new Dimension(100,100)); // 設置按鈕背景顏色 button1.setBackground(Color.red); button2.setBackground(Color.blue); button3.setBackground(Color.pink); button4.setBackground(Color.orange); button5.setBackground(Color.yellow); // 將按鈕添加到內容面板中 contentpage.add(button1); contentpage.add(button2); contentpage.add(button3); contentpage.add(button4); contentpage.add(button5); // 設置窗口大小 jFrame.setSize(500, 300); // 設置窗口可見(jiàn) jFrame.setVisible(true); } }
采用邊界布局會(huì )將元素分別劃分到東,西,中,南,北五個(gè)方位,分別使用EAST,WEST,CENTER,SOUTH,NORTH標識,每個(gè)方位只能放一個(gè)元素
示例
代碼
public class Test { public static void main(String[] args) { // 創(chuàng )建窗口 JFrame jFrame = new JFrame(); // 設置窗口名稱(chēng) jFrame.setTitle("hello"); // 創(chuàng )建邊界布局管理器 BorderLayout layout = new BorderLayout(); // 關(guān)閉窗口結束程序 jFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); // 創(chuàng )建內容面板 Container contentpage = jFrame.getContentPane(); // 設置內容面板布局方式為流布局 contentpage.setLayout(layout); // 創(chuàng )建按鈕 JButton button1 = new JButton("1"); JButton button2 = new JButton("2"); JButton button3 = new JButton("3"); JButton button4 = new JButton("4"); JButton button5 = new JButton("5"); // 設置按鈕背景顏色 button1.setBackground(Color.red); button2.setBackground(Color.blue); button3.setBackground(Color.pink); button4.setBackground(Color.orange); button5.setBackground(Color.yellow); // 將按鈕添加到內容面板中 // 將按鈕放置到北部 contentpage.add(button1,BorderLayout.NORTH); // 將按鈕放置到南部 contentpage.add(button2,BorderLayout.SOUTH); // 將按鈕放置到西部 contentpage.add(button3,BorderLayout.WEST); // 將按鈕放置到東部 contentpage.add(button4,BorderLayout.EAST); // 將按鈕放置到中心 contentpage.add(button5,BorderLayout.CENTER); // 設置窗口大小 jFrame.setSize(500, 300); // 設置窗口可見(jiàn) jFrame.setVisible(true); } }
顧名思義,若一個(gè)容器使用卡片布局,其里面的所有組件就像是一副牌一樣重疊在一起,容器只能顯示一個(gè)組件,默認顯示第一個(gè)組件,可以通過(guò)CardLayout中的show方法改變顯示的組件
示例
顯示第一個(gè)按鈕
顯示第二個(gè)按鈕
代碼
public class Test { public static void main(String[] args) { // 創(chuàng )建窗口 JFrame jFrame = new JFrame(); // 設置窗口名稱(chēng) jFrame.setTitle("hello"); // 創(chuàng )建卡片布局管理器 CardLayout layout = new CardLayout(); // 關(guān)閉窗口結束程序 jFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); // 創(chuàng )建面板 JPanel jPanel = new JPanel(); // 設置面板布局方式為卡片布局 jPanel.setLayout(layout); // 添加 按鈕 設置背景顏色 JButton jButton1 = new JButton(); jButton1.setBackground(Color.pink); JButton jButton2 = new JButton(); jButton2.setBackground(Color.yellow); // 將按鈕添加到面板中并對按鈕進(jìn)行命名 jPanel.add(jButton1,"bt1"); jPanel.add(jButton2,"bt2"); // 指定在面板上顯示的按鈕 layout.show(jPanel, "bt2"); // 將面板添加到窗口中 jFrame.add(jPanel); // 設置窗口大小 jFrame.setSize(500,300); // 設置窗口可見(jiàn) jFrame.setVisible(true); } }
所謂自定義布局就是不使用任何布局管理器,而是我們自己通過(guò)指定組件的X坐標,Y坐標,寬度,高度來(lái)指定組件的位置
這里的坐標和我們平時(shí)的坐標有些區別,如下:
組件是以左上角頂點(diǎn)為原點(diǎn)來(lái)定位坐標,使用自定義布局,要將容器使用的布局管理器設置為null
那有的小伙伴會(huì )問(wèn)了,既然布局管理器設置為null,那可不可以直接不設置啊,當然不行,如果不設置的話(huà),組件會(huì )不顯示
示例
代碼
public class Test { public static void main(String[] args) { // 創(chuàng )建窗口 JFrame jFrame = new JFrame(); // 設置窗口名稱(chēng) jFrame.setTitle("hello"); // 關(guān)閉窗口同時(shí)結束程序 jFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); // 創(chuàng )建面板 JPanel jPanel = new JPanel(); // 使用自定義布局,將容器使用的布局管理器設置為null jPanel.setLayout(null); // 添加 按鈕 設置背景顏色 JButton jButton1 = new JButton(); jButton1.setBackground(Color.pink); JButton jButton2 = new JButton(); jButton2.setBackground(Color.yellow); // 設置按鈕的坐標為(100,100) ,寬度為100,高度為100 jButton1.setBounds(new Rectangle(100,100,100,100)); // 設置按鈕的坐標為(220,70) ,寬度為100,高度為100 jButton2.setBounds(new Rectangle(220,70,100,100)); // 將按鈕添加到面板中 jPanel.add(jButton1); jPanel.add(jButton2); // 將面板添加到窗口中 jFrame.add(jPanel); // 設置窗口大小 jFrame.setSize(500,300); // 設置窗口可見(jiàn) jFrame.setVisible(true); } }
到此這篇關(guān)于Java圖形界面GUI布局方式(小結)的文章就介紹到這了,更多相關(guān)Java GUI布局內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站