Java-JFrame-swing嵌套浏览器步骤

Java-JFrame-swing嵌套浏览器步骤

一、使用swing嵌套浏览器要实现的功能

  通过javaswing实现在一个窗体中嵌套一个浏览器,可以在这个浏览器中将另一个项目的内容显示出来,只需要回去另一个项目首页的url即可,这样另一个项目就可以在swing嵌套的浏览器中进行正常的显示了;

二、下面的浏览器工具类中的方法在使用的时候,只需要从另一个项目的服务端获取另一个项目的首页stirng类型的url地址和浏览器左上角要显示的string类型的标题两个参数即可,参数只有url和title两个;

(1)主要步骤:

1、通过以下java代码实现创建浏览器;

2、创建JFrame窗体,对窗体进行基本的设置;

3、设置浏览器显示的定位尺寸,并将浏览器添加到JFrame窗体中去:

  非常注意:将浏览器添加到窗体的java代码一定在将浏览器顶部工具栏背景图片添加到窗体的java代码之后,否则浏览器内容显示不出来

4、设置浏览器顶部工具栏的左侧图标;

5、设置浏览器顶部工具栏的左侧标题文字;

6、设置浏览器顶部工具栏右侧最小化、最大化、关闭等图片以及鼠标的各种事件;

7、为窗体添加一个事件:当窗体的尺寸发生变化时,就会执行方法体中的Java代码;因为窗体的大小是可以变化的;

8、非常重要的是:浏览器工具类中一定要下面的一行代码注释掉,否则其他窗体调用此窗体时,不会弹出此窗体;

// 必须将下行代码注释掉,否则不能够跳转到此窗体
// NativeInterface.runEventPump();

(2)浏览器的工具类全部代码如下:

package com;

import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.FlowLayout;
import java.awt.Font;
import java.awt.Image;
import java.awt.Rectangle;
import java.awt.event.ComponentAdapter;
import java.awt.event.ComponentEvent;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;

import javax.swing.ImageIcon;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JLayeredPane;
import javax.swing.JPanel;
import javax.swing.JRootPane;
import javax.swing.SwingUtilities;

import com.listener.XZWebBrowserListener;
import com.util.ScreenSize;

import chrriis.common.UIUtils;
import chrriis.dj.nativeswing.swtimpl.NativeInterface;
import chrriis.dj.nativeswing.swtimpl.components.JWebBrowser;

/**
 * CS包浏览器,首先访问的是项目首页
 * 
 * @author admin
 *
 */
public class EagleBrowser1 extends JPanel {

	private static final long serialVersionUID = 1L;

	private JPanel webBrowserPanel;

	private JWebBrowser webBrowser;

	private JFrame frame;

	private Double browserWidth;// 窗体宽度
	private Double browserHeight;//窗体高度

	public EagleBrowser1() {

	}

	// 构造方法,传递url和title可创建CS包容浏览器窗体
	public EagleBrowser1(String url, String title) {
		/**
		 * 创建浏览器
		 */
		webBrowserPanel = new JPanel(new BorderLayout());
		webBrowser = new JWebBrowser();
		webBrowser.navigate(url);
		webBrowser.setButtonBarVisible(false);
		webBrowser.setMenuBarVisible(false);
		webBrowser.setBarsVisible(false);
		webBrowser.setStatusBarVisible(false);
		webBrowserPanel.add(webBrowser, BorderLayout.CENTER);
		XZWebBrowserListener listener =  new XZWebBrowserListener();
	    webBrowser.addWebBrowserListener(listener );
		//add(webBrowserPanel, BorderLayout.CENTER);
		// webBrowser.executeJavascript("javascrpit:window.location.href='http://www.baidu.com'");
		// webBrowser.executeJavascript("alert('haha')"); //执行Js代码

		UIUtils.setPreferredLookAndFeel();
		NativeInterface.open();
		SwingUtilities.invokeLater(new Runnable() {
			public void run() {
				//JFrame.setDefaultLookAndFeelDecorated(true);
				frame = new JFrame();
				// 去掉窗口的装饰
				frame.setUndecorated(true);
				// 采用指定的窗口装饰风格
				frame.getRootPane().setWindowDecorationStyle(JRootPane.NONE);
				frame.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
				frame.setLocationByPlatform(true);
				frame.setLayout(null);
				// 注意可见性、窗体大小、窗体居中定位,这三个最好按照此顺序书写
				// 设置窗体可见
				frame.setVisible(true);
				frame.setResizable(true);
				// 设置窗体的宽度、高度
				frame.setSize(1600, 900);
				// 设置窗体居中显示
				frame.setLocationRelativeTo(frame.getOwner());
				/**
				 * 获取窗体的总宽
				 */
				browserWidth = frame.getSize().getWidth();
				browserHeight = frame.getSize().getHeight();
				/**
				 * 插入浏览器头部窄条的背景图片
				 */
				// 创建具有分层的JLayeredPane
				JLayeredPane layeredPane = new JLayeredPane();
				layeredPane.setBounds(0, 0, browserWidth.intValue(), 40);
				// 添加分层的JLayeredPane
				frame.getContentPane().add(layeredPane,BorderLayout.CENTER);
				// 创建图片对象
				ImageIcon img = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_head.jpg"));
				// 设置图片在窗体中显示的宽度、高度
				img.setImage(img.getImage().getScaledInstance(browserWidth.intValue(), 40, Image.SCALE_DEFAULT));

				JPanel panel = new JPanel();
				panel.setBounds(0, 0, browserWidth.intValue(), 40);
				layeredPane.add(panel, JLayeredPane.DEFAULT_LAYER);//添加到最底层

				JLabel lblNewLabel = new JLabel("");
				panel.add(lblNewLabel);
				lblNewLabel.setIcon(img);
				/**
				 * 将网页添加到窗体frame中来
				 */
				//设置浏览器距离头部的距离高度
				webBrowserPanel.setBounds(0, 29, browserWidth.intValue(), browserHeight.intValue()-29);
				// 添加网页的JPanel,注意:定要将此行代码放置在添加JLayeredPane以下
				frame.getContentPane().add(webBrowserPanel, BorderLayout.CENTER);
				/**
				 * 插入浏览器头部左边的图片
				 */
				// 创建图片对象
				ImageIcon headLeftImg = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_head_left.jpg"));
				// 设置图片在窗体中显示的宽度、高度
				headLeftImg.setImage(headLeftImg.getImage().getScaledInstance(24, 40, Image.SCALE_DEFAULT));

				JPanel headLeftPanel = new JPanel();
				headLeftPanel.setBounds(0, -5, 24, 40);
				layeredPane.add(headLeftPanel, JLayeredPane.MODAL_LAYER);//添加到比背景图片高一层的层次中

				JLabel headLeftLabel = new JLabel("");
				headLeftPanel.add(headLeftLabel);
				headLeftLabel.setIcon(headLeftImg);
				/**
				 * 插入浏览器窗体左边的标题
				 */
				JPanel titlePanel = new JPanel();
				titlePanel.setBounds(32, 6, browserWidth.intValue()-150, 20);
				layeredPane.add(titlePanel, JLayeredPane.MODAL_LAYER);
				//设置JPanel中文字对齐方式为左对齐
				titlePanel.setLayout(new FlowLayout(FlowLayout.LEFT));
				//设置JPanel为透明的,这样可以让JPanel后面的背景颜色显示出来
				titlePanel.setBackground(null);
				titlePanel.setOpaque(false);
				
				JLabel titleLbel = new JLabel();
				titleLbel.setText(title);
				titleLbel.setSize(100, 20);
				titleLbel.setHorizontalAlignment(JLabel.LEFT);
				titleLbel.setFont(new Font("微软雅黑", 0, 12));
				titleLbel.setForeground(Color.white);
				titlePanel.add(titleLbel);
				/**
				 * 插入右边关闭背景图片及功能
				 */
				// 创建图片对象
				ImageIcon headCloseImg = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_close_01.jpg"));
				// 设置图片在窗体中显示的宽度、高度
				headCloseImg.setImage(headCloseImg.getImage().getScaledInstance(40, 40, Image.SCALE_DEFAULT));

				JPanel headClosePanel = new JPanel();
				headClosePanel.setBounds(browserWidth.intValue() - 40, -5, 40, 40);
				layeredPane.add(headClosePanel, JLayeredPane.MODAL_LAYER);

				JLabel headCloseLabel = new JLabel("");
				headClosePanel.add(headCloseLabel);
				headCloseLabel.setIcon(headCloseImg);
				headCloseLabel.addMouseListener(new MouseAdapter() {
					// 鼠标点击关闭图片,实现关闭窗体的功能
					@Override
					public void mouseClicked(MouseEvent e) {
						 frame.dispose();//此种方式的关闭只是关闭了窗体,后台程序还是没有真正关闭
						 System.exit(0);//此种方式是真正的关闭
					}

					// 鼠标进入,换关闭的背景图片
					@Override
					public void mouseEntered(MouseEvent e) {
						// 创建图片对象
						ImageIcon closeImg1 = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_close_02.jpg"));
						// 设置图片在窗体中显示的宽度、高度
						closeImg1.setImage(closeImg1.getImage().getScaledInstance(40, 40, Image.SCALE_DEFAULT));
						headCloseLabel.setIcon(closeImg1);
					}

					// 鼠标离开,换关闭的背景图片
					@Override
					public void mouseExited(MouseEvent e) {
						// 创建图片对象
						ImageIcon headCloseImg = new ImageIcon(
								EagleBrowser1.class.getResource("/images/browser_close_01.jpg"));
						// 设置图片在窗体中显示的宽度、高度
						headCloseImg.setImage(headCloseImg.getImage().getScaledInstance(40, 40, Image.SCALE_DEFAULT));
						headCloseLabel.setIcon(headCloseImg);
					}
				});
				/**
				 * 插入右边最大化背景图片及功能
				 */
				// 创建图片对象
				ImageIcon headMaxImg = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_middle_01.jpg"));
				// 设置图片在窗体中显示的宽度、高度
				headMaxImg.setImage(headMaxImg.getImage().getScaledInstance(40, 40, Image.SCALE_DEFAULT));

				JPanel headMaxPanel = new JPanel();
				headMaxPanel.setBounds(browserWidth.intValue() - 40 - 40, -5, 40, 40);
				layeredPane.add(headMaxPanel, JLayeredPane.MODAL_LAYER);

				JLabel headMaxLabel = new JLabel("");
				headMaxPanel.add(headMaxLabel);
				headMaxLabel.setIcon(headMaxImg);
				headMaxLabel.addMouseListener(new MouseAdapter() {
					// 鼠标点击关闭图片,实现关闭窗体的功能
					@Override
					public void mouseClicked(MouseEvent e) {
						// 判断窗体当前宽度,如果与计算机分辨率同样宽,那么窗体宽度变为默认值,如果小于计算机分辨率宽度,那么窗体变为最大化显示
						if (frame.getSize().getWidth() < ScreenSize.getScreenWidth()) {
							//加入此行代码,可以让窗体最大化不会遮挡住桌面上底部的工具栏;
							frame.setMaximizedBounds(new Rectangle(0, 1, ScreenSize.getScreenWidth().intValue(), ScreenSize.getScreenHeight().intValue()));
							frame.setExtendedState(JFrame.MAXIMIZED_BOTH);// 窗体最大化
							// 创建图片对象
							ImageIcon maxImg1 = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_max_01.jpg"));
							// 设置图片在窗体中显示的宽度、高度
							maxImg1.setImage(maxImg1.getImage().getScaledInstance(40, 40, Image.SCALE_DEFAULT));
							headMaxLabel.setIcon(maxImg1);
						} else {
							frame.setSize(1600, 900);
							frame.setLocationRelativeTo(frame.getOwner());
							// 创建图片对象
							ImageIcon maxImg1 = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_middle_01.jpg"));
							// 设置图片在窗体中显示的宽度、高度
							maxImg1.setImage(maxImg1.getImage().getScaledInstance(40, 40, Image.SCALE_DEFAULT));
							headMaxLabel.setIcon(maxImg1);
						}

					}

					// 鼠标进入,换关闭的背景图片
					@Override
					public void mouseEntered(MouseEvent e) {
						// 判断窗体当前宽度与计算机分辨率宽度大小
						if (frame.getSize().getWidth() < ScreenSize.getScreenWidth()) {
							//窗体宽度小于计算机分辨率宽度,图片应显示中间那种
							// 创建图片对象
							ImageIcon maxImg1 = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_middle_02.jpg"));
							// 设置图片在窗体中显示的宽度、高度
							maxImg1.setImage(maxImg1.getImage().getScaledInstance(40, 40, Image.SCALE_DEFAULT));
							headMaxLabel.setIcon(maxImg1);
						}else{
							// 创建图片对象
							ImageIcon maxImg1 = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_max_02.jpg"));
							// 设置图片在窗体中显示的宽度、高度
							maxImg1.setImage(maxImg1.getImage().getScaledInstance(40, 40, Image.SCALE_DEFAULT));
							headMaxLabel.setIcon(maxImg1);
						}
					}

					// 鼠标离开,换关闭的背景图片
					@Override
					public void mouseExited(MouseEvent e) {
						// 判断窗体当前宽度与计算机分辨率宽度大小
						if (frame.getSize().getWidth() < ScreenSize.getScreenWidth()) {
							//窗体宽度小于计算机分辨率宽度,图片应显示中间那种
							// 创建图片对象
							ImageIcon maxImg1 = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_middle_01.jpg"));
							// 设置图片在窗体中显示的宽度、高度
							maxImg1.setImage(maxImg1.getImage().getScaledInstance(40, 40, Image.SCALE_DEFAULT));
							headMaxLabel.setIcon(maxImg1);
						}else{
							// 创建图片对象
							ImageIcon maxImg1 = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_max_01.jpg"));
							// 设置图片在窗体中显示的宽度、高度
							maxImg1.setImage(maxImg1.getImage().getScaledInstance(40, 40, Image.SCALE_DEFAULT));
							headMaxLabel.setIcon(maxImg1);
						}
					}
				});
				/**
				 * 插入右边最小化背景图片及功能
				 */
				// 创建图片对象
				ImageIcon headMinImg = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_min_01.jpg"));
				// 设置图片在窗体中显示的宽度、高度
				headMinImg.setImage(headMinImg.getImage().getScaledInstance(40, 40, Image.SCALE_DEFAULT));

				JPanel headMinPanel = new JPanel();
				headMinPanel.setBounds(browserWidth.intValue() - 40 - 40 - 40, -5, 40, 40);
				layeredPane.add(headMinPanel, JLayeredPane.MODAL_LAYER);

				JLabel headMinLabel = new JLabel("");
				headMinPanel.add(headMinLabel);
				headMinLabel.setIcon(headMinImg);
				headMinLabel.addMouseListener(new MouseAdapter() {
					// 鼠标点击关闭图片,实现关闭窗体的功能
					@Override
					public void mouseClicked(MouseEvent e) {
						frame.setExtendedState(JFrame.ICONIFIED);// 最小化窗体
					}

					// 鼠标进入,换关闭的背景图片
					@Override
					public void mouseEntered(MouseEvent e) {
						// 创建图片对象
						ImageIcon mainImg1 = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_min_02.jpg"));
						// 设置图片在窗体中显示的宽度、高度
						mainImg1.setImage(mainImg1.getImage().getScaledInstance(40, 40, Image.SCALE_DEFAULT));
						headMinLabel.setIcon(mainImg1);
					}

					// 鼠标离开,换关闭的背景图片
					@Override
					public void mouseExited(MouseEvent e) {
						// 创建图片对象
						ImageIcon headMinImg = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_min_01.jpg"));
						// 设置图片在窗体中显示的宽度、高度
						headMinImg.setImage(headMinImg.getImage().getScaledInstance(40, 40, Image.SCALE_DEFAULT));
						headMinLabel.setIcon(headMinImg);
					}
				});
				/**
				 * 设置检测窗体大小发生变化的事件
				 */
				frame.addComponentListener(new ComponentAdapter() {
					@Override
					public void componentResized(ComponentEvent e) {
						/**
						 * 获取尺寸变化后的窗体的宽度、高度
						 */
						browserWidth = frame.getSize().getWidth();
						browserHeight = frame.getSize().getHeight();
						/**
						 * 浏览器顶部窄背景图片宽度改变
						 */
						layeredPane.setBounds(0, -5, browserWidth.intValue(), 34);
						titlePanel.setBounds(32, 6, browserWidth.intValue()-150, 20);
						// 创建图片对象
						ImageIcon img1 = new ImageIcon(EagleBrowser1.class.getResource("/images/browser_head.jpg"));
						// 设置图片在窗体中显示的宽度、高度
						img1.setImage(
								img1.getImage().getScaledInstance(browserWidth.intValue(), 40, Image.SCALE_DEFAULT));
						panel.setBounds(0, -5, browserWidth.intValue(), 40);
						panel.add(lblNewLabel);
						lblNewLabel.setIcon(img1);
						/**
						 * 浏览器顶部窄条右侧最小化、最大化、关闭按钮图片根据宽度进行定位
						 */
						headClosePanel.setBounds(browserWidth.intValue() - 40, -5, 40, 40);// 浏览器顶部关闭图片定位
						headMaxPanel.setBounds(browserWidth.intValue() - 40 - 40, -5, 40, 40);// 浏览器顶部最大化图片定位
						headMinPanel.setBounds(browserWidth.intValue() - 40 - 40 - 40, -5, 40, 40);// 浏览器顶部最小化图片定位
						/**
						 * 浏览器宽度、高度进行改变
						 */
						//设置浏览器距离头部的距离高度
						webBrowserPanel.setBounds(0, 29, browserWidth.intValue(), browserHeight.intValue()-29);					
					}
				});

			}
		});
		// 必须将下行代码注释掉,否则不能够跳转到此窗体
		// NativeInterface.runEventPump();
	}

	public static void main(String[] args) {
		String url = "http://www.hao123.com";
		String title = "测试CS包浏览器";
		EagleBrowser1 eagleBrowser = new EagleBrowser1(url, title);
	}

}

  上述代码中用到了获取当前计算机尺寸的工具类代码如下:

package com.util;

import java.awt.Dimension;
import java.awt.Toolkit;
/**
 * 获取当前计算机分辨率的工具类
 * @author admin
 *
 */
public class ScreenSize {
	
	//获取当前计算机分辨率的宽度
	public static Double getScreenWidth(){
		Dimension screenSize = Toolkit.getDefaultToolkit().getScreenSize();
		return screenSize.getWidth();
	}
	
	//获取当前计算机分辨率的高度
	public static Double getScreenHeight(){
		Dimension screenSize = Toolkit.getDefaultToolkit().getScreenSize();
		return screenSize.getHeight();
	}
	
}

 

  

 

 

 

 

posted @ 2017-10-20 17:24  lsyBlog  阅读(9795)  评论(1编辑  收藏  举报