What Will I Learn?
<ul>
<li>The user will learn how to create a Basic Web Browser.
<li>The user will learn about JEditorPane
<li>The user will learn about Hyperlink Listeners.
<h4>Requirements
<ul>
<li>A computer System is required for this tutorial.
<li>Java Software Development Kit(JDK) must be installed on your computer.
<li>An Integrated Development Environment(IDE) such as Eclipse or NetBeans is required to be installed on your computer.
<p dir="auto">Get JDK <a href="http://www.oracle.com/technetwork/java/javase/downloads/jdk9-downloads-3848520.html" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">here
<p dir="auto">Get Eclipse <a href="http://www.eclipse.org/downloads/eclipse-packages/" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">here
<p dir="auto">Get NetBeans <a href="https://netbeans.org/downloads/index.html" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">here
<h4>Difficulty
<p dir="auto">Intermediate.
<h4>Tutorial Contents
<p dir="auto">Today, we will look at how to create a very basic Web Browser that loads basic elements in a website, and also use the medium to talk about JEditorPane and Hyperlink Listeners.
<h3>JEditorPane
<p dir="auto">A JEditorPane is a text component that can handle different text with style.<br />
By default, it can handle plain text, HTML, and Rich Text Format (RTF).<br />
A JEditorPane is primarily used to display an HTML document with only basic HTML elements.
<h1>Hyperlink Listener
<p dir="auto">A Hyperlink Listener is a Listener Interface that listens for events to occur on links.
<p dir="auto">It has a single method <code>hyperlinkUpdate which must be implemented when used.<br />
The syntax for the implementation of the method is
<pre><code>public void hyperlinkUpdate(HyperlinkEvent event)
<p dir="auto">In this tutorial, we will create two classes:
<ul>
<li><p dir="auto">webBrowser Class: We will create a JTextField and JEditorPane objects to serve as an address field and a window.<br />
The user will type a URL in the address field and hit the enter button and the program will direct the user to the website, displaying the contents in the window.
<li><p dir="auto">webMain Class: Contains main method for run instructions.<br />
This tutorial is done in assumption that the user follows through previous tutorials and is familiar with the coding terms used therein, also, have basic Java programming knowledge.
<p dir="auto"><img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520521897/qhjgwjt9gxmpe61d3dp3.png" alt="1.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520521897/qhjgwjt9gxmpe61d3dp3.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520521897/qhjgwjt9gxmpe61d3dp3.png 2x" />
<p dir="auto"><img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520521904/cqyilmjftbpqmb94xtog.png" alt="2.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520521904/cqyilmjftbpqmb94xtog.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520521904/cqyilmjftbpqmb94xtog.png 2x" />
<h1>CODE BLOCK
<h6>webBrowser Class
<pre><code>import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
import javax.swing.event.*;
<pre><code>public class webBrowser extends JFrame {
<pre><code> private JEditorPane window;
<pre><code> public webBrowser() {
super("Simple Web Browser Demo");
<pre><code> addressField = new JTextField("Enter a URL!");
addressField.addActionListener(
new ActionListener() {
public void actionPerformed(ActionEvent event) {
loadSite(event.getActionCommand());
}
}
);
<pre><code> add(addressField, BorderLayout.NORTH);
<pre><code> window = new JEditorPane();
window.setEditable(false);
window.addHyperlinkListener(
new HyperlinkListener() {
public void hyperlinkUpdate(HyperlinkEvent event) {
if (event.getEventType() == HyperlinkEvent.EventType.ACTIVATED) {
loadSite(event.getURL().toString());
}
}
}
);
<pre><code> add(new JScrollPane(window), BorderLayout.CENTER);
}
<pre><code> private void loadSite(String text) {
try {
window.setPage(text);
addressField.setText(text);
}
catch (Exception e) {
JOptionPane.showMessageDialog(null, "Invalid URL!");
}
}
}
<h6>webMain Class
<pre><code>import javax.swing.JFrame;
<pre><code>public class webMain {
<pre><code> public static void main (String args []) {
<pre><code> webBrowser browser = new webBrowser();
browser.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
browser.setSize(500, 300);
browser.setVisible(true);
}
}
<h3>Output
<p dir="auto"><img src="https://images.hive.blog/0x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520536006/ngrdydll8dryqf6u98av.gif" alt="ezgif.com-optimize.gif" />
<h1>webBrowser Class
<pre><code>addressField = new JTextField("Enter a URL!");
addressField.addActionListener(
new ActionListener() {
public void actionPerformed(ActionEvent event) {
loadSite(event.getActionCommand());
}
}
);
add(addressField, BorderLayout.NORTH);
<p dir="auto">The above code creates a JTextField object which will serve as the address field where user will enter a URL address. It has a default message saying “Enter a URL!”
<p dir="auto">An ActionListener interface is associated with the object to detect an event when the user hits the “Enter” button. The <code>actionPerformed method is implemented.
<p dir="auto">The <code>loadSite() is a method that will be created later in the program. It will contain instructions which will display the contents of a website to the screen when a URL is passed to it.
<p dir="auto">The object is then added to the screen.
<pre><code>window = new JEditorPane();
window.setEditable(false);
window.addHyperlinkListener(
new HyperlinkListener() {
public void hyperlinkUpdate(HyperlinkEvent event) {
if (event.getEventType() == HyperlinkEvent.EventType.ACTIVATED) {
loadSite(event.getURL().toString());
}
}
}
);
add(new JScrollPane(window), BorderLayout.CENTER);
<p dir="auto">This code creates a JEditorPane object called “window”. Because this window will display contents of a web page, the <code>.setEditable(false) method is used to make the contents un-editable.
<p dir="auto">A Hyperlink Listener is associated with the window. This is because contents of the window may contain links and the user might click these links.<br />
The Hyperlink Listener method <code>hyperlinkUpdate is implemented.
<p dir="auto">The above “if” statement is interpreted as - if an event type is same as a hyperlink event; simply meaning “if a link is clicked”, the loadSite method is called which displays the web page of the clicked link.
<p dir="auto">The object is added to a JScrollPane component and added to the centre of the screen.<br />
The <code>loadSite method is now created.
<pre><code>private void loadSite(String text) {
try {
window.setPage(text);
addressField.setText(text);
}
catch (Exception e) {
JOptionPane.showMessageDialog(null, "Invalid URL!");
}
}
}
<p dir="auto">This method contains instructions which allows the contents of a web page to be displayed on the screen. The method takes a String argument which is the URL.
<p dir="auto">A try-catch statement is used to handle exceptions for events when a user enters a wrong URL address.
<p dir="auto">The inbuilt method <code>.setPage() automatically reads the HTML file of the entered URL address and displays the contents of the web page on the screen. This is the most important piece of code in this program, without it, the web pagw till not be displayed.
<p dir="auto">The text on the address field is also set to the URL of the web page.
<p dir="auto">Exception handling catch statement displays a message to the screen of the user enters an invalid URL.
<h1>webMain class
<pre><code>import javax.swing.JFrame;
public class webMain {
public static void main (String args []) {
webBrowser browser = new webBrowser();
browser.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
browser.setSize(500, 300);
browser.setVisible(true);
}
}
<p dir="auto">Main class containing main method with instructions on how the program runs.
<p dir="auto">An object of the Slider class is created. The slider class holds instructions for running the program.
<p dir="auto">The program Exit Mode is set. This will close the program when user clicks the “X” button on the frame.
<p dir="auto">Size of the window is set using inbuilt methods <code>.setSize
<p dir="auto">Visibility setting is set, making the frame visible, the code <code>.setVisible(true) is used.
<p dir="auto"><img src="https://images.hive.blog/0x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520536006/ngrdydll8dryqf6u98av.gif" alt="ezgif.com-optimize.gif" />
<p dir="auto"><img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520532866/h2b78x7h7ubbl9y1atqm.png" alt="4.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520532866/h2b78x7h7ubbl9y1atqm.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520532866/h2b78x7h7ubbl9y1atqm.png 2x" />
<p dir="auto"><img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520532786/ospz4jjk3lxku2ma956v.png" alt="3.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520532786/ospz4jjk3lxku2ma956v.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520532786/ospz4jjk3lxku2ma956v.png 2x" />
<p dir="auto"><span><a href="http://google.com" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">http://google.com
<p dir="auto"><img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520533735/micyc7umphjqfpzpgp2r.png" alt="5.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520533735/micyc7umphjqfpzpgp2r.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520533735/micyc7umphjqfpzpgp2r.png 2x" />
<p dir="auto"><span><a href="http://yahoomail.com" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">http://yahoomail.com
<p dir="auto">When the program is run, the user may enter any URL and the program will redirect to the website.
<h3>Note
<p dir="auto"><span>This is a basic web browser and so may not be compatible with recent sophisticated webpages, but provides basic knowledge for building web browser. The user must enter complete URL, For Example: “<a href="http://google.com" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">http://google.com”
<p dir="auto"><img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520536304/exl8d09qdse92i1p2n0h.png" alt="6.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520536304/exl8d09qdse92i1p2n0h.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520536304/exl8d09qdse92i1p2n0h.png 2x" />
<p dir="auto"><img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520536317/kpnggsyapyljpwqbaoov.png" alt="7.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520536317/kpnggsyapyljpwqbaoov.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520536317/kpnggsyapyljpwqbaoov.png 2x" />
<p dir="auto"><img src="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520536354/ywvhmhvjas8m0c2imusv.png" alt="8.png" srcset="https://images.hive.blog/768x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520536354/ywvhmhvjas8m0c2imusv.png 1x, https://images.hive.blog/1536x0/https://res.cloudinary.com/hpiynhbhq/image/upload/v1520536354/ywvhmhvjas8m0c2imusv.png 2x" />
<p dir="auto">Source Codes from GitHub Account.
<p dir="auto">You can get the codes at my <a href="https://github.com/will-ugo/webBrowser/tree/master/src" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">GitHub Account if you want to try it on your own.
<h6>REFERENCES
<ul>
<li><a href="http://www.java2s.com/Tutorials/Java/Java_Swing/0860__Java_Swing_JEditorPane.htm" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">Java2s
<h4>Curriculum
<p dir="auto">Similar posts already posted on Utopian are:
<ul>
<li><p dir="auto"><a href="https://utopian.io/utopian-io/@will-ugo/java-gui-confirm-dialogs-using-eclipse-ide" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">Java GUI: Confirm Dialogs Using Eclipse IDE<br />
<li><p dir="auto"><a href="https://utopian.io/utopian-io/@will-ugo/java-gui-jspinner-and-functions-using-eclipse-ide" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">Java GUI: JSpinner and functions Using Eclipse IDE<br />
<li><p dir="auto"><a href="https://utopian.io/utopian-io/@will-ugo/java-gui-jtabbedpane-and-functions-using-eclipse-ide" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">Java GUI: JTabbedPane and Functions Using Eclipse IDE<br />
<ul>
<li><a href="https://utopian-io/utopian-io/@will-ugo/java-graphical-user-interface-gui-jmenubar-jmenu-and-jmenuitem-functions-and-operations-using-eclipse-ide" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">Java Graphical User Interface(GUI): JMenuBar, JMenu and JMenuItem functions and operations using Eclipse IDE<br />
<p dir="auto"><br /><hr /><em>Posted on <a href="https://utopian.io/utopian-io/@will-ugo/creating-a-basic-web-browser-using-eclipse-ide" target="_blank" rel="noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">Utopian.io - Rewarding Open Source Contributors<hr /><p>
Thank you for the contribution. It has been approved.
You can contact us on Discord.
[utopian-moderator]
Hey @will-ugo I am @utopian-io. I have just upvoted you!
Achievements
Community-Driven Witness!
I am the first and only Steem Community-Driven Witness. Participate on Discord. Lets GROW TOGETHER!
Up-vote this comment to grow my power and help Open Source contributions like this one. Want to chat? Join me on Discord https://discord.gg/Pc8HG9x
That's great
Nice... Learning quite a lot from you Sir. Kudos!!
Thank you for visiting. I see you do programming contributions also, Nice One!
Yes, but I'm still a rookie compared to you. I think it should not be out of place for me to come to you for private tutorials.
Honestly, am not a pro myself, I started learning how to code recently. But with time, patience and dedication; we will all get to where we want to be in the world of programming.
Good tutorial