Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,037

HOME > Java Programming > Java GUI สอน Java GUI เขียนโปรแกรม GUI ด้วย Java(Swing/AWT/JFC) > พื้นฐาน Java GUI : Dialog และ Popup สร้าง Input Dialog และ Custom Modal Dialog



Clound SSD Virtual Server

พื้นฐาน Java GUI : Dialog และ Popup สร้าง Input Dialog และ Custom Modal Dialog

พื้นฐาน Java GUI : Dialog และ Popup สร้าง Input Dialog และ Custom Modal Dialog บทความนี้เราจะมาเรียนรู้เกี่ยวกับ Java GUI และการสร้าง Dialog และ Popuo ทั้งที่เป็น Input Dialog เช่น การสร้าง Input Dialog Popup แบบรับค่า Username / Password หรือการสร้าง Modal Dialog แบบ Confirm ที่จะต้องกด Yes/No หรือจะเป็นแบบ Custom Dialog Popup ที่ใช้การเรียก Form จาก Class อื่น แสดงเป็นแบบ Modal Dialog โดยใน Modal อาจจะสร้างเป็น Input ข้อมูล และหลังจากที่ได้ข้อมูลเรียบร้อยแล้วก็ส่งค่ากลับมายัง Form หลัก

Example 1 : ตัวอย่างการสร้าง Dialog Popup แบบ Cofirm ด้วย Yes/No

MyForm.java
package com.java.myapp;

import java.awt.EventQueue;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JOptionPane;

public class MyForm extends JFrame {

	public static void main(String[] args) {
		EventQueue.invokeLater(new Runnable() {
			public void run() {
				MyForm form = new MyForm();
				form.setVisible(true);
			}
		});
	}
	
	public MyForm() {
            
		// Create Form Frame
		super("ThaiCreate.Com Tutorial");
		setSize(450, 300);
		setLocation(500, 280);
		setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
		getContentPane().setLayout(null);
		
		// Create Dialog
		JButton btnButton = new JButton("Submit");
		btnButton.setBounds(171, 95, 89, 23);
		btnButton.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				
				int n = JOptionPane.showConfirmDialog(null,
                        "I really like my book",
                        "Question (application-modal dialog)", 
                        JOptionPane.YES_NO_OPTION,
                        JOptionPane.QUESTION_MESSAGE); 
		        System.out.println(n); // Use n for response

			}
		});
		
		getContentPane().add(btnButton);
			
	}

}

Output

Java GUI : Dialog Input Custom Modal Dialog

คลิกที่ Button เพื่อแสดง Dialog แบบ Yes/No

Java GUI : Dialog Input Custom Modal Dialog

ทางเลือก Optional เป็น Yes/No โดยเมื่อกลับไปสามารถนำค่า n ไปใช้ได้

System.out.println(n);









Example 2 : ตัวอย่างการสร้าง Dialog Popup แบบมี Input ข้อมูลเช่น Name , Username และ Password

MyForm.java
package com.java.myapp;

import java.awt.EventQueue;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

import javax.swing.JButton;
import javax.swing.JComponent;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPasswordField;
import javax.swing.JTextField;

public class MyForm extends JFrame {

	public static void main(String[] args) {
		EventQueue.invokeLater(new Runnable() {
			public void run() {
				MyForm form = new MyForm();
				form.setVisible(true);
			}
		});
	}
	
	
	public MyForm() {
            
		// Create Form Frame
		super("ThaiCreate.Com Tutorial");
		setSize(450, 300);
		setLocation(500, 280);
		setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
		getContentPane().setLayout(null);
		
		// Create Dialog
		JButton btnButton = new JButton("Submit");
		btnButton.setBounds(171, 95, 89, 23);
		btnButton.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				
				JTextField name = new JTextField();
				JTextField username = new JTextField();
				JPasswordField password = new JPasswordField();
				final JComponent[] inputs = new JComponent[] {
						new JLabel("Name"),
						name,
						new JLabel("Username"),
						username,
						new JLabel("Password"),
						password
				};
				JOptionPane.showMessageDialog(null, inputs, "My custom dialog", JOptionPane.PLAIN_MESSAGE);
				System.out.println("You entered " +
						name.getText() + ", " +
						username.getText() + ", " +
						password.getText());
				
			}
		});
		
		getContentPane().add(btnButton);
					
	}

}

Output

Java GUI : Dialog Input Custom Modal Dialog

คลิกที่ Button เพื่อแสดง Dialog ที่มี Input ข้อมูล

Java GUI : Dialog Input Custom Modal Dialog

กรอกข้อมูใน Input Dialog และหลังจากที่กด OK สามารถ get ค่าได้โดยใช้คำสั่ง

				System.out.println("You entered " +
						name.getText() + ", " +
						username.getText() + ", " +
						password.getText());




Example 3 : ตัวอย่างการสร้าง Custom Modal Dialog แบบสร้าง Layout ขึ้นมาใหม่อีก Class

MyForm.java เป็น Form หลักไว้เปิด Dialog และแสดงค่าจาก Dialog
package com.java.myapp;

import java.awt.EventQueue;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;


public class MyForm extends JFrame {

	public static void main(String[] args) {
		EventQueue.invokeLater(new Runnable() {
			public void run() {
				MyForm form = new MyForm();
				form.setVisible(true);
			}
		});
	}
	
	
	public MyForm() {
            
		// Create Form Frame
		super("ThaiCreate.Com Tutorial");
		setSize(450, 300);
		setLocation(500, 280);
		setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
		getContentPane().setLayout(null);
		
		// Label Result
		final JLabel lblResult = new JLabel("Result",JLabel.CENTER);
		lblResult.setBounds(32, 53, 370, 14);
		getContentPane().add(lblResult);
		
		// Create Button Open Dialog
		JButton btnButton = new JButton("Submit");
		btnButton.setBounds(171, 95, 89, 23);
		btnButton.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				
				MyDialogPopup dialog = new MyDialogPopup();
				dialog.setModal(true);
				dialog.setVisible(true);
				
				lblResult.setText(dialog.sName);
				
			}
		});
		getContentPane().add(btnButton);
			
		
	}

}

Java GUI : Dialog Input Custom Modal Dialog

MyDialogPopup.java เป็น Dialog และ Input ข้อมูล
package com.java.myapp;

import javax.swing.JButton;
import javax.swing.JDialog;

import java.awt.event.ActionListener;
import java.awt.event.ActionEvent;
import javax.swing.JTextField;

public class MyDialogPopup extends JDialog {

	public String sName;
	
	public static void main(String[] args) {
		try {
			MyDialogPopup dialog = new MyDialogPopup();
			dialog.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
			dialog.setVisible(true);
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	public MyDialogPopup() {
		setBounds(100, 100, 296, 175);
		setResizable(false);
		setLocationRelativeTo(null);
		getContentPane().setLayout(null);
		
		// Create Input 
		final JTextField name = new JTextField();
		name.setBounds(57, 36, 175, 20);
		getContentPane().add(name);
		
		// Button OK
		JButton btnOK = new JButton("OK");
		btnOK.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				sName = name.getText();
				dispose();
			}
		});
		btnOK.setBounds(70, 93, 78, 23);
		getContentPane().add(btnOK);
		
		// Button Cancel
		JButton btnCancel = new JButton("Cancel");
		btnCancel.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				sName = "";
				dispose();
			}
		});
		btnCancel.setBounds(158, 93, 74, 23);
		getContentPane().add(btnCancel);
		
	}
}

Java GUI : Dialog Input Custom Modal Dialog

Output

Java GUI : Dialog Input Custom Modal Dialog

แสดง Form หลักคลิกที่ Button เพื่อเปิด Dialog Popup

Java GUI : Dialog Input Custom Modal Dialog

แสดง Dialog Popup และ Input ข้อมูล และเมื่อคลิกที่ OK จะมีการส่งข้อมูลไปยัง Form หลัก

Java GUI : Dialog Input Custom Modal Dialog

แสดงข้อมูลที่ถูกส่งมายัง Dialog Popup








   
Share


ช่วยกันสนับสนุนรักษาเว็บไซต์ความรู้แห่งนี้ไว้ด้วยการสนับสนุน Source Code 2.0 ของทีมงานไทยครีเอท


ลองใช้ค้นหาข้อมูล


   


Bookmark.   
       
  By : ThaiCreate.Com Team (บทความเป็นลิขสิทธิ์ของเว็บไทยครีเอทห้ามนำเผยแพร่ ณ เว็บไซต์อื่น ๆ)
  Score Rating :  
  Create/Update Date : 2013-08-23 12:47:12 / 2017-03-27 17:05:59
  Download : No files
 Sponsored Links / Related

 
รู้จักกับ Java กับ JFrame เครื่องมือหลักในการสร้าง GUI Window Form ด้วย JFrame
Rating :

 
การปรับแต่ง JFrame เช่น Title/Resizable/Maximum Window/Change Icon (Java)
Rating :

 
พื้นฐาน Java สร้าง Controls บน GUI และการสร้าง Action Event Handler กับ Controls
Rating :

 
พื้นฐานการสร้าง GUI Window Form ที่ประกอบด้วย 2 Form และการ Open Form (Java)
Rating :

 
พื้นฐาน Form การสร้าง Dialog MessageBox บน Java GUI เพื่อโต้ตอบกับผู้ใช้
Rating :

 
พื้นฐาน Form และ GUI : JTextField , JLabel , JButton เพื่อรับข้อมูลและแสดงข้อมูล
Rating :


ThaiCreate.Com Forum


Comunity Forum Free Web Script
Jobs Freelance Free Uploads
Free Web Hosting Free Tools

สอน PHP ผ่าน Youtube ฟรี
สอน Android การเขียนโปรแกรม Android
สอน Windows Phone การเขียนโปรแกรม Windows Phone 7 และ 8
สอน iOS การเขียนโปรแกรม iPhone, iPad
สอน Java การเขียนโปรแกรม ภาษา Java
สอน Java GUI การเขียนโปรแกรม ภาษา Java GUI
สอน JSP การเขียนโปรแกรม ภาษา Java
สอน jQuery การเขียนโปรแกรม ภาษา jQuery
สอน .Net การเขียนโปรแกรม ภาษา .Net
Free Tutorial
สอน Google Maps Api
สอน Windows Service
สอน Entity Framework
สอน Android
สอน Java เขียน Java
Java GUI Swing
สอน JSP (Web App)
iOS (iPhone,iPad)
Windows Phone
Windows Azure
Windows Store
Laravel Framework
Yii PHP Framework
สอน jQuery
สอน jQuery กับ Ajax
สอน PHP OOP (Vdo)
Ajax Tutorials
SQL Tutorials
สอน SQL (Part 2)
JavaScript Tutorial
Javascript Tips
VBScript Tutorial
VBScript Validation
Microsoft Access
MySQL Tutorials
-- Stored Procedure
MariaDB Database
SQL Server Tutorial
SQL Server 2005
SQL Server 2008
SQL Server 2012
-- Stored Procedure
Oracle Database
-- Stored Procedure
SVN (Subversion)
แนวทางการทำ SEO
ปรับแต่งเว็บให้โหลดเร็ว


Hit Link
   







Load balance : Server 03
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่