和计算器中不同的是,画板项目的实现中又更显的复杂一点.尽管有些复杂,但是只要把步骤写下来,复杂的也就是清晰的了.纵观画板的界面,主要由三个部分组成: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 GUI编程的基础知识,包括Swing组件的使用、绘图功能的实现、事件处理以及布局管理。开发者通过这些...
Java Swing组件写的游戏客户端Java Swing组件写的游戏客户端 Java Swing组件写的游戏客户端Java Swing组件写的游戏客户端 Java Swing组件写的游戏客户端Java Swing组件写的游戏客户端 Java Swing组件写的游戏客户端...
Swing组件是Java GUI(图形用户界面)编程中的核心元素,它是...通过阅读和运行这些代码,你将能够更加深入地了解如何在实际项目中运用Swing组件。记得动手实践,理论与实践相结合,才能更好地掌握Swing组件的应用。
Java Swing 组件大全 Java Swing 是 Java 语言中一个功能强大且广泛使用的图形用户界面(GUI)组件库。它提供了大量的组件和工具,用于构建复杂的桌面应用程序。本文档将对 Java Swing 中的组件进行详细的介绍和...
在Java Swing组件全演示中,我们将深入探讨Swing的核心概念、组件和设计原则。 首先,Swing是基于AWT(Abstract Window Toolkit)的,但提供了更丰富的功能和更好的外观。Swing组件通常被称为轻量级组件,因为它们...
普通swing组件用法
Swing 组件概述 Swing 是 Java 编程语言中的一组图形用户界面(GUI)组件,它们提供了丰富的用户界面元素,帮助开发者快速构建桌面应用程序。Swing 组件可以分为五大类:顶层容器、中间容器、特殊容器、基本组件和...
【Swing组件详解】 Swing是Java编程语言中用于创建图形用户界面(GUI)的一个库,它是Java Foundation Classes (JFC)的一部分。在早期的Java版本(如JDK 1.0和1.1)中,Abstract Window Toolkit (AWT)是主要的GUI...
综上所述,"swing组件介绍(一)"可能会涵盖Swing的基本概念、核心组件、布局管理、事件处理以及一些实用工具类,帮助初学者理解Swing在开发Java桌面应用中的重要性和用法。对于深入学习Swing,开发者还需要了解高级...
在本实验报告中,主题是“Java实验报告之图形用户界面程序设计与AWT/Swing组件”,主要目标是让学生熟悉Java GUI设计原理、程序结构,掌握AWT和Swing组件的功能,以及学会应用这些组件来设计应用程序,特别是实现一...
Swing扩展组件是Java Swing库中的一个重要组成部分,它提供了丰富的用户界面元素,使得开发者能够创建出功能强大且具有吸引力的图形用户界面(GUI)。Swing是Java AWT(抽象窗口工具包)的一个替代品,提供了更多的...
"基于Java swing组件实现简易计算器" 本文主要介绍了基于Java swing组件实现简易计算器的知识点,以下是相关知识点的总结: 1. JFrame组件:JFrame是Java swing组件中的一种顶层容器,用于创建一个窗口框架。通过...
Swing提供了一系列组件,使得开发者可以构建功能丰富的、具有吸引力的桌面应用程序。以下是一些Swing组件的详细说明: 1. JPanel: 是最基本的面板组件,用于承载其他组件。你可以将它看作是容器,可以添加、排列和...
常用Swing组件GUI设计,
Java-GUI编程之Swing组件 Java-GUI编程之Swing组件是Java编程语言中用于构建图形用户界面的一个核心组件。Swing是Java Foundation Classes(JFC)的一个组成部分,提供了丰富的图形用户界面组件,帮助开发者快速...
JIDE Common Layer是一套很不错的Swing组件类库,它JIDE软件公司其他产品的基础,于2007年4月开源,在其开源之前是JIDE商业软件中的一部分。它包含将近10万行代码,超过30个的Swing组件和工具。 压缩包中含有对应的...
在这个"Swing组件demo"中,我们可以深入学习Swing组件的使用方法和特性。 Swing组件包括但不限于: 1. **JFrame**: JFrame是窗口的基础类,它为其他组件提供了一个容器。在Swing应用中,通常会创建一个JFrame实例...
8. ** Swing组件的常用方法**:如`setPreferredSize()`用于设置组件的大小,`setOpaque(true|false)`用于设置组件是否透明,`setVisible(true|false)`控制组件的可见性,以及`repaint()`用于重绘组件。 9. **主程序...
本教程将深入探讨Swing组件的实例应用,帮助开发者更好地理解和掌握Swing在实际编程中的运用。 一、Swing组件基础 Swing组件主要由JComponent类及其子类构成,包括按钮(JButton)、文本框(JTextField)、标签...