Hướng dẫn tạo GUI trong Java bằng AWT phần 4 docx

5 470 3
Hướng dẫn tạo GUI trong Java bằng AWT phần 4 docx

Đang tải... (xem toàn văn)

Thông tin tài liệu

16 Java hỗ trợ lớp Choice cho phép chúng ta tạo các danh sách chứa nhiều item. Khi danh sách vừa được tạo ra, nó sẽ rỗng. Choice colors=new Choice(); Mỗi thời điểm chỉ thêm được một item bằng cách sử dụng phương thức addItem như được chỉ ra bên dưới: colors.addItem(“Red”); colors.addItem(“Green”); Chương trình 5.8 minh họa cách tạo một danh sách chọn lựa: Chương trình 5.8 import java.awt.*; class Choicetest extends Frame { Label l1=new Label(“What is your favorite color”); Choice colors=new Choice(); public Choicetest(String title) { super(title); setLayout(new FlowLayout()); add(l1); colors.addItem(“White”); colors.addItem(“Red”); colors.addItem(“Orange”); colors.addItem(“Green”); colors.addItem(“Yellow”); colors.addItem(“Blue”); colors.addItem(“Black”); add(colors); } public static void main(String args[]) { Choicetest t=new Choicetest(“Choice list”); t.setSize(300,200); t.show(); } 17 } Kết xuất được chỉ ra ở hình bên dưới: Hình 5.10 Danh sách chọn lựa 5.4 Trình quản lý cách trình bày (Layout manager) Layout manager điều khiển cách trình bày vật lý của các phần tử GUI như là button, textbox, option button v.v… Một layout manager tự động bố trí các thành phần này trong container. Các kiểu trình bày khác nhau:  Flow layout  Border layout  Card layout  Grid layout  GridBag Layout Tất cả các thành phần mà chúng ta vừa tạo sử dụng layout manager mặc đònh. Cho ví dụ, ‘FlowLayout’ là cách trình bày mặc đònh của một applet. Layout manager này sẽ tự động xắp xếp các thành phần. Tất cả các thành phần được đặt trong một container, và được xắp xếp đến layout manager tương ứng. Layout manager được thiết lập bằng phương thức được gọi là ‘setLayout()’. Bây giờ chúng ta sẽ tìm hiểu chi tiết các cách trình bày và cách bố trí các thành phần của ta vào những vò trí mong muốn. 5.4.1 FlowLayout manager 18 ‘FlowLayout’ là layout manager mặc đònh cho các applet và các panel. Các thành phần được xắp xếp từ góc trái trên đến góc phải dưới của màn hình. Khi một số thành phần được tạo, chúng được xắp xếp theo hàng, từ trái sang phải. Các constructor của FlowLayout: FlowLayout mylayout = new FlowLayout() // constructor //constructor with alignment specified FlowLayout exLayout=new FlowLayout(FlowLayout.RIGHT); setLayout(exLayout); //setting the layout to Flowlayout Các điều khiển có thể được canh về bên trái, bên phải hay ở giữa. Để canh các điều khiển về bên phải, bạn sử dụng cú pháp sau: setLayout(new FlowLayout(FlowLayout.RIGHT)); Chương trình 5.9 minh họa về FlowLayout manager. Ở đây, contructor không cần được gọi một cách tường minh, bởi vì cấu tử này được gọi mặc đònh cho một applet. Chương trình 5.9 import java.awt.*; class Fltest extends Frame { Button b1=new Button(“Center Aligned Button 1”); Button b2=new Button(“Center Aligned Button 2”); Button b3=new Button(“Center Aligned Button 3”); public Fltest(String title) { super(title); setLayout(new FlowLayout(FlowLayout.CENTER)); add(b1); add(b2); add(b3); } public static void main(String args[]) { 19 Fltest t=new Fltest(“Flow Layout”); t.setSize(300,200); t.show(); } } Kết xuất của chương trình chỉ ra ở hình 5.11. Hình 5.11 Flowlayout 5.4.2 BorderLayout Manager ‘BorderLayout’ là layout manager mặc đònh cho ‘Window’, ‘Frame’ và ‘Dialog’. Layout này xắp xếp tối đa 5 thành phần trong một container. Những thành phần này có thể được đặt ở các hướng ‘North’, ‘South’, ‘East’, ‘West’ và ‘Center’ của container.  NORTH – Đặt ở đỉnh của container.  EAST – Đặt phía bên phải của container.  SOUTH – Đặt ở phía dưới của container.  WEST – Đặt phía bên trái của container.  CENTER – Đặt ở giữa của container. Để thêm một thành phần vào vùng ‘North’, bạn sử dụng cú pháp sau: Button b1=new Button(“North Button”); // khai báo thành phần setLayout(new BorderLayout()); // thiết lập layout add(b1,BorderLayout.NORTH); // thêm thành phần vào layout Các thành phần vẫn giữ nguyên vò trí tương đối của chúng kể cả khi container bò thay đổi kích thước. Các thành phần được đặt trong vùng ‘North’, ‘South’ được dàn nằm ngang 20 trong khi đó các thành phần đặt trong vùng ‘East’ và ‘West’ lại được dàn thẳng đứng. Các thành phần được đặt trong vùng ‘center’ sẽ được dàn đều vào những khu vực nằm giữa của container. add(b2,BorderLayout.CENTER); // thêm thành phần vào vùng ‘center’ Khi tất cả các thành phần được đặt vào các vùng tương ứng, lúc đó Frame sẽ giống như sau: Hình 5.12 BorderLayout BorderLayout có thể chứa nhiều hơn 5 thành phần. Để thực hiện điều này, chúng ta có thể sử dụng các panel của các layout khác nhau để chứa các thành phần, và sau đó đặt các panel này vào trong border layout. 5.4.3 CardLayout Manager CardLayout có thể lưu trữ một ngăn xếp (stack) các layout. Mỗi layout giống như một bảng (card). Bảng thường là đối tượng Panel. Một thành phần độc lập như button sẽ điều khiển cách trình bày các bảng ở lớp trên cùng. Đầu tiên, chúng ta bố trí tập hợp các thành phần được yêu cầu trên các panel tương ứng. Mỗi panel sẽ được bố trí vào các layout khác nhau. Cho ví dụ: panelTwo.setLayout(new GridLayout(2,1)); Panel chính sẽ chứa những panel này. Chúng ta thiết lập layout của panel chính là Cardlayout như sau: CardLayout card=new CardLayout(); . ‘North’, ‘South’ được dàn nằm ngang 20 trong khi đó các thành phần đặt trong vùng ‘East’ và ‘West’ lại được dàn thẳng đứng. Các thành phần được đặt trong vùng ‘center’ sẽ được dàn đều vào những. sẽ tự động xắp xếp các thành phần. Tất cả các thành phần được đặt trong một container, và được xắp xếp đến layout manager tương ứng. Layout manager được thiết lập bằng phương thức được gọi là. Flowlayout 5 .4. 2 BorderLayout Manager ‘BorderLayout’ là layout manager mặc đònh cho ‘Window’, ‘Frame’ và ‘Dialog’. Layout này xắp xếp tối đa 5 thành phần trong một container. Những thành phần này

Ngày đăng: 31/07/2014, 01:20

Từ khóa liên quan

Tài liệu cùng người dùng

  • Đang cập nhật ...

Tài liệu liên quan