`

swing组件运用之个性画板

 
阅读更多
和计算器中不同的是,画板项目的实现中又更显的复杂一点.尽管有些复杂,但是只要把步骤写下来,复杂的也就是清晰的了.纵观画板的界面,主要由三个部分组成:1,左边添加功能的面板;2,下面添加颜色选择的面板;3,中间画布的面板.
   有了这个大概的方向,思路就会清晰很多了.但是每个部分又可以分为几个步骤.第一部分,1)先创建窗体;2)创建面板,设置相关的属性;3)创建功能选择按钮,给按钮设置命令;4)将面板加到窗体上.第二部分和第三部分都有相应相同的情况.
   下为原代码:
画板类
package lesson0129lianxi;

import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Dimension;
import java.awt.FlowLayout;
import java.awt.Graphics;
import java.util.Random;

import javax.swing.ButtonGroup;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JRadioButton;
import javax.swing.border.BevelBorder;



public class DrawBoard extends JFrame{
	/**
	 * 主函数,程序的入口
	 * @param args
	 */
	public static void main(String[] args){
		DrawBoard db = new DrawBoard();
		db.showUI();
	}
	Color color=Color.black;
	public void showUI(){
		/**
		 * 设置窗体的属性
		 */
		this.setTitle("山寨画板Z.30");
		this.setSize(850,630);
		this.setDefaultCloseOperation(3);
		this.setLayout(new BorderLayout());
		
		/**
		 * 创建画板左边的面板
		 */
		JPanel jp = new JPanel();
		Dimension dime1 =new Dimension(70,800);
		jp.setPreferredSize(dime1);
		jp.setBackground(Color.LIGHT_GRAY);
		jp.setLayout(new FlowLayout(FlowLayout.LEFT,0,0));
		//设置边框效果
		jp.setBorder(new BevelBorder(0,Color.BLUE,new Color(205,205,205)));
		this.add(jp,BorderLayout.WEST);
		
		/**
		 * 创建工具选择按钮
		 */
		ButtonGroup bg = new ButtonGroup();
		for(int i=0;i<16;i++){
			//将i=6的图标所对应的铅笔功能设为默认功能
			if(i==6){
				JRadioButton jbx = new JRadioButton("",true);
				jbx.setActionCommand(6+"形状");
			  	bg.add(jbx);
			    ImageIcon image1 = new ImageIcon("image/draw"+6+".jpg");
				ImageIcon image2 = new ImageIcon("image/draw"+6+"-1.jpg");
				ImageIcon image3 = new ImageIcon("image/draw"+6+"-2.jpg");
				ImageIcon image4 = new ImageIcon("image/draw"+6+"-3.jpg");
				jbx.setIcon(image1);
				jbx.setRolloverIcon(image2);
				jbx.setPressedIcon(image3);
				jbx.setSelectedIcon(image4);
				jp.add(jbx);
				this.add(jp,BorderLayout.WEST);
				continue;		
			}
			JRadioButton jb = new JRadioButton();
			
			jb.setActionCommand(i+"形状");
			bg.add(jb);
			ImageIcon image1 = new ImageIcon("image/draw"+i+".jpg");
			ImageIcon image2 = new ImageIcon("image/draw"+i+"-1.jpg");
			ImageIcon image3 = new ImageIcon("image/draw"+i+"-2.jpg");
			ImageIcon image4 = new ImageIcon("image/draw"+i+"-3.jpg");
			jb.setIcon(image1);
			jb.setRolloverIcon(image2);
			jb.setPressedIcon(image3);
			jb.setSelectedIcon(image4);
			jp.add(jb);
			this.add(jp,BorderLayout.WEST);
		}
		
		/**
		 * 创建选择颜色的面板
		 */
		JPanel jp_down= new JPanel();
		jp_down.setPreferredSize(new Dimension(800,50));
		jp_down.setBackground(Color.green);
		jp_down.setLayout(new FlowLayout(FlowLayout.LEFT,5,5));
		this.add(jp_down,BorderLayout.SOUTH);
		
		/**
		 * 创建颜色面板中的左右面板
		 */
		JPanel jp_left = new JPanel();
		JPanel jp_right = new JPanel();
		jp_left.setPreferredSize(new Dimension(40,40));
		jp_right.setPreferredSize(new Dimension(540,40));
		jp_left.setLayout(new FlowLayout(FlowLayout.LEFT,0,0));
		jp_right.setLayout(new FlowLayout(FlowLayout.LEFT,0,0));

		jp_down.add(jp_left);
		jp_down.add(jp_right);
		
		/**
		 * 创建两个按钮,加到颜色面板中的做面板
		 */
		JButton jb_front = new JButton();
		JButton jb_end = new JButton();
		jb_front.setPreferredSize(new Dimension(20,20));
		jb_end.setPreferredSize(new Dimension(20,20));
		jb_front.setBackground(Color.WHITE);
		jb_end.setBackground(Color.white);
		/**
		 *将两个按钮放到左边的面板上,并形成重叠的效果,1.先将要添加的面板布局去掉,设为空布局 2.通过绝对布局来设置位置     
		 */
		jp_left.setLayout(null);
		jb_front.setBounds(7,7,20,20);
		jb_end.setBounds(17,17,20,20);
		jp_left.add(jb_front);
		jp_left.add(jb_end);
		
		/**
		 * 创建颜色按钮,并加到下方右面板
		 */
		//往右边面板添加一定数量的颜色选择按钮
		//创建随机对象
		ColorListener co = new ColorListener(this);
		Random ra = new Random();
		for(int x=0;x<60;x++){
		JButton jbu = new JButton();
		jbu.setPreferredSize(new Dimension(20,20));
		jbu.setBackground(new Color(ra.nextInt(200102022)));
		jbu.addActionListener(co);
		jp_right.add(jbu);
			
		}
		
		/**
		 * 添加中间的画板,并创建画布到画板上
		 */
		JPanel jp_center = new JPanel();
		jp_center.setPreferredSize(new Dimension(600,600));
		jp.setBackground(Color.orange);
		jp_center.setLayout(new FlowLayout(0));
		this.add(jp_center);
		/**
		 * 创建画布的画板,并将画布加上去
		 */
		JPanel jp_draw = new JPanel();
		jp_draw.setBackground(Color.white);
		jp_draw.setPreferredSize(new Dimension(450,450));
		jp_center.add(jp_draw);
		/**
		 * 添加两个标签
		 */
		JLabel jl_name = new JLabel("       	Auther:Zhuzhenke");
		JLabel jl_date = new JLabel("Date:2013.01.30");
		jl_name.setBackground(Color.BLACK);
		jl_date.setBackground(Color.BLACK);
		jp_down.add(jl_name);
		jp_down.add(jl_date);
		
        this.setVisible(true);
		
		Graphics g = jp_draw.getGraphics();
	
	
		/**
		 * 创建画板监听器,
		 */
		DrawListener db =new DrawListener(bg,g,this);
		jp_center.addMouseListener(db);//这是个添加监听器的方法,根据后面DrawListener调用的方法来添加,
		jp_center.addMouseMotionListener(db);//也就是把DrawListener添加到中间的画板
		
		
}
	
}


画板监听器类
package lesson0129lianxi;

import java.awt.Graphics;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import javax.swing.ButtonGroup;

public class DrawListener extends MouseAdapter{
	/**
	 * 声明变量
	 */
	public int x1,y1,x2,y2,x3,y3,x4,y4;
	public ButtonGroup bg;
	public Graphics g;
	public DrawBoard db;
	public String command;
	/**
	 * 构造法
	 * @param bg
	 * @param g
	 */
	public DrawListener(ButtonGroup bg,Graphics g,DrawBoard db){
		this.bg = bg;
		this.g = g;
		this.db = db;
	}
	/**
	 * 重写MouseAdapter中的方法
	 */
	public int count=1;
	public void mousePressed(MouseEvent e){
		x1 = e.getX();
		y1 = e.getY();
		command = bg.getSelection().getActionCommand();
		g.setColor(db.color);
		if(command.equals("13形状")){
		if(count==1){
			x3=x1;
			y3=y1;
			count++;
		}else{
			x1=x2;
			y1=y2;
		}
		}
	}
	public void mouseDragged(MouseEvent e){
		if("6形状".equals(command)){
			x2 = e.getX();
			y2 = e.getY();
			g.drawLine(x1, y1, x2, y2);
			x1 =x2;
			y1 = y2;
		}
		
	} 
	public void mouseReleased(MouseEvent e){
		x2 = e.getX();
		y2 = e.getY();
	/**
	 * 判断命令,执行相应的方法
	 */
		//定义command为从按钮组中得到的选择命令,从而得到按钮所得到的命令
		String command = bg.getSelection().getActionCommand();
		if("10形状".equals(command)){
			g.drawLine(x1,y1,x2,y2);
		}else if("12形状".equals(command)){
			g.drawRect(Math.min(x1,x2), Math.min(y1, y2), Math.abs(x1-x2), Math.abs(y1-y2));
		}else if("14形状".equals(command)){g.drawOval(Math.min(x2, x1), Math.min(y1,y2), Math.abs(x1-x2),Math.abs(y1-y2));
		}else if("15形状".equals(command)){
			g.drawArc(Math.min(x2, x1), Math.min(y1,y2), Math.abs(x1-x2),Math.abs(y1-y2),200,200);		
	    }else if("13形状".equals(command)){
	    	g.drawLine(x1, y1, x2, y2);
	    }
}		
	public void mouseClicked(MouseEvent e){
			int w = e.getClickCount();//鼠标点击的次数
			String command = bg.getSelection().getActionCommand();
			if(w==2&&"13形状".equals(command)){
				g.drawLine(x3, y3, x2, y2);
				count = 1;
			}
			 
	}
	
}	

颜色按钮监听器类
package lesson0129lianxi;

import java.awt.Color;
import java.awt.Dimension;
import java.awt.Graphics;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.Random;

import javax.swing.JButton;
import javax.swing.JPanel;

public class ColorListener implements ActionListener{
	public DrawBoard db;
	public ColorListener(DrawBoard db){
		this.db = db;
	}
	public void actionPerformed(ActionEvent e){
		//e得到的事件源是按钮,用按钮代替事件源,将事件源强制转型为按钮
		JButton jb = (JButton)e.getSource();
		db.color= jb.getBackground();
	}
}




但是还有相当部分的功能还没能实现,这也算是个给我在家慢慢探讨的机会,毕竟要经过思考才能更实际的把自己的想法通过代码开表现出来.所以说软件开发是个创新的事物,是很有意义的事情.
   但是遇到挫折是非常常见的事,如果说敲代码没有遇到什么困难,那么也不会有太多的意义,自己也不会有太多的提高,所以,无论是困难还是局部顺利的,都是很好的事情.
   总之,来到蓝杰学习编程,自己收获很多.感谢左哥一遍又一遍耐心的为我解答和讲解.
   相信大学的生活会变得更加有意义.为自己加油,为自己喝彩!

  • 大小: 32.2 KB
分享到:
评论

相关推荐

    java swing简单画板

    在这个画板应用中,可能使用了某种布局管理器来放置画板组件。 综上所述,"java swing简单画板"项目涵盖了Java GUI编程的基础知识,包括Swing组件的使用、绘图功能的实现、事件处理以及布局管理。开发者通过这些...

    Java Swing组件写的游戏客户端.zip

    Java Swing组件写的游戏客户端Java Swing组件写的游戏客户端 Java Swing组件写的游戏客户端Java Swing组件写的游戏客户端 Java Swing组件写的游戏客户端Java Swing组件写的游戏客户端 Java Swing组件写的游戏客户端...

    Swing组件应用实例

    Swing组件是Java GUI(图形用户界面)编程中的核心元素,它是...通过阅读和运行这些代码,你将能够更加深入地了解如何在实际项目中运用Swing组件。记得动手实践,理论与实践相结合,才能更好地掌握Swing组件的应用。

    javaswing组件大全.pdf

    Java Swing 组件大全 Java Swing 是 Java 语言中一个功能强大且广泛使用的图形用户界面(GUI)组件库。它提供了大量的组件和工具,用于构建复杂的桌面应用程序。本文档将对 Java Swing 中的组件进行详细的介绍和...

    Java Swing 组件全演示

    在Java Swing组件全演示中,我们将深入探讨Swing的核心概念、组件和设计原则。 首先,Swing是基于AWT(Abstract Window Toolkit)的,但提供了更丰富的功能和更好的外观。Swing组件通常被称为轻量级组件,因为它们...

    普通swing组件用法

    普通swing组件用法

    常用Swing组件一览表

    Swing 组件概述 Swing 是 Java 编程语言中的一组图形用户界面(GUI)组件,它们提供了丰富的用户界面元素,帮助开发者快速构建桌面应用程序。Swing 组件可以分为五大类:顶层容器、中间容器、特殊容器、基本组件和...

    swing组件的详细介绍

    【Swing组件详解】 Swing是Java编程语言中用于创建图形用户界面(GUI)的一个库,它是Java Foundation Classes (JFC)的一部分。在早期的Java版本(如JDK 1.0和1.1)中,Abstract Window Toolkit (AWT)是主要的GUI...

    swing组件介绍(一)

    综上所述,"swing组件介绍(一)"可能会涵盖Swing的基本概念、核心组件、布局管理、事件处理以及一些实用工具类,帮助初学者理解Swing在开发Java桌面应用中的重要性和用法。对于深入学习Swing,开发者还需要了解高级...

    java实验报告之图形用户界面程序设计与 AWT/Swing组件

    在本实验报告中,主题是“Java实验报告之图形用户界面程序设计与AWT/Swing组件”,主要目标是让学生熟悉Java GUI设计原理、程序结构,掌握AWT和Swing组件的功能,以及学会应用这些组件来设计应用程序,特别是实现一...

    Swing 扩展组件 Swing 扩展组件

    Swing扩展组件是Java Swing库中的一个重要组成部分,它提供了丰富的用户界面元素,使得开发者能够创建出功能强大且具有吸引力的图形用户界面(GUI)。Swing是Java AWT(抽象窗口工具包)的一个替代品,提供了更多的...

    Swing组件下载(常用组件)

    Swing提供了一系列组件,使得开发者可以构建功能丰富的、具有吸引力的桌面应用程序。以下是一些Swing组件的详细说明: 1. JPanel: 是最基本的面板组件,用于承载其他组件。你可以将它看作是容器,可以添加、排列和...

    基于Java swing组件实现简易计算器

    "基于Java swing组件实现简易计算器" 本文主要介绍了基于Java swing组件实现简易计算器的知识点,以下是相关知识点的总结: 1. JFrame组件:JFrame是Java swing组件中的一种顶层容器,用于创建一个窗口框架。通过...

    Swing组件类库 JIDE Common Layer

    JIDE Common Layer是一套很不错的Swing组件类库,它JIDE软件公司其他产品的基础,于2007年4月开源,在其开源之前是JIDE商业软件中的一部分。它包含将近10万行代码,超过30个的Swing组件和工具。 压缩包中含有对应的...

    常用Swing组件GUI设计

    常用Swing组件GUI设计,

    Java-GUI编程之Swing组件.doc

    Java-GUI编程之Swing组件 Java-GUI编程之Swing组件是Java编程语言中用于构建图形用户界面的一个核心组件。Swing是Java Foundation Classes(JFC)的一个组成部分,提供了丰富的图形用户界面组件,帮助开发者快速...

    swing 组件 demo

    在这个"Swing组件demo"中,我们可以深入学习Swing组件的使用方法和特性。 Swing组件包括但不限于: 1. **JFrame**: JFrame是窗口的基础类,它为其他组件提供了一个容器。在Swing应用中,通常会创建一个JFrame实例...

    Java的Swing组件实现的计算器,Java入门学习案例,源码.rar

    8. ** Swing组件的常用方法**:如`setPreferredSize()`用于设置组件的大小,`setOpaque(true|false)`用于设置组件是否透明,`setVisible(true|false)`控制组件的可见性,以及`repaint()`用于重绘组件。 9. **主程序...

    swing各个组件实例演示

    本教程将深入探讨Swing组件的实例应用,帮助开发者更好地理解和掌握Swing在实际编程中的运用。 一、Swing组件基础 Swing组件主要由JComponent类及其子类构成,包括按钮(JButton)、文本框(JTextField)、标签...

Global site tag (gtag.js) - Google Analytics