`
kuailehuahua
  • 浏览: 7017 次
  • 性别: Icon_minigender_2
最近访客 更多访客>>
社区版块
存档分类

画板基本功能的实现(直线、矩形、椭圆的绘制;存储)

 
阅读更多

原始的画板:

(1)DrawUI类:

public class DrawUI extends javax.swing.JFrame{

	public static void main(String args[]){
		
		DrawUI ui = new DrawUI();
		ui.initDrawUI();
		
	}
	
	/**
	 * 初始化窗体的方法
	 */
	public void initDrawUI(){
		
		//指调用房当前initDrawUI()方法的对象
		this.setTitle("我的画板v01");
		this.setSize(600,500);
		
		//设置布局
		java.awt.FlowLayout fl = new java.awt.FlowLayout();
		this.setLayout(fl);
		
		//创建一个按钮组
		javax.swing.ButtonGroup group = new javax.swing.ButtonGroup();
		//单选按钮
		javax.swing.JRadioButton line = new javax.swing.JRadioButton("直线");
		//设置按钮的动作命令
		line.setActionCommand("line");
		//默认选中直线
		line.setSelected(true);
		
		javax.swing.JRadioButton rect = new javax.swing.JRadioButton("矩形");
		rect.setActionCommand("rect");
		
		javax.swing.JRadioButton oval = new javax.swing.JRadioButton("椭圆");
		oval.setActionCommand("oval");
		
		//按钮分组
		group.add(line);
		group.add(rect);
		group.add(oval);
		
		
		
		this.add(line);
		this.add(rect);
		this.add(oval);
		
		this.setDefaultCloseOperation(3);
		this.setVisible(true);
		
		//从窗体上获取画布
		//窗体在屏幕上所占据的区域是允许改变颜色的
		java.awt.Graphics g = this.getGraphics();
		
	
		
		//创建一个鼠标监听器对象
		DrawListener dlis = new DrawListener(g,group);
		//给窗体加鼠标监听器
		this.addMouseListener(dlis);
		
	}
	
	
	
}

 (2)DrawListener类:

import java.awt.event.MouseEvent;

/**
 * 画板的监听器,实现鼠标监听器接口
 * 
 * @author Administrator
 * 
 */
public class DrawListener implements java.awt.event.MouseListener {

	private int x1, y1, x2, y2;
	private java.awt.Graphics g;
	private javax.swing.ButtonGroup group;
	private String type = "line";

	public DrawListener(java.awt.Graphics g, javax.swing.ButtonGroup group) {
		this.g = g;
		this.group = group;
	}

	// 按下
	public void mousePressed(MouseEvent e) {
		// 先判断要绘制的形状
		// 得到选中选项的动作命令
		type = group.getSelection().getActionCommand();
		System.out.println("要绘制的形状:"+type);
		// 得到鼠标按下时候光标的坐标
		x1 = e.getX();
		y1 = e.getY();
	}

	// 释放
	public void mouseReleased(MouseEvent e) {
		// 得到鼠标释放时候光标的坐标
		x2 = e.getX();
		y2 = e.getY();

		if ("line".equals(type)) {
			// 当鼠标释放的时候就画直线
			g.drawLine(x1, y1, x2, y2);
		} else if (type.equals("rect")) {
			g.drawRect(x1, y1, x2 - x1, y2 - y1);
		} else if (type.equals("oval")) {
			g.drawOval(x1, y1, x2 - x1, y2 - y1);
		}
	}

	// 进入
	public void mouseEntered(MouseEvent e) {
		// System.out.println("mouseEntered");
	}

	// 离开
	public void mouseExited(MouseEvent e) {
		// System.out.println("mouseExited");
	}

	// 点击
	public void mouseClicked(MouseEvent e) {
		// System.out.println("mouseClicked");
	}
}

 

总结:

1、运用initDraw()设计窗体,而非把所有设计步骤都放在main()方法中

2、设计窗体的框架步骤:a、大小、标题->布局->添加元素组件->关闭操作、可见性

                                   b、为窗体添加监听器

3、只有组件可见后方可创建Graphics对象

4、单选按钮需添加进按钮组方可起作用

5、运用属性、构造函数将两个相关类连接起来(例如:将属性Graphics g,Buttongroup group传入DrawListener类)

6、Graphics类不能使用构造方法来创建对象

7、每个按钮都有其动作命令(和按钮的文本不一样)

8、只要为组件添加监听器,组件就可以自动监听动作事项

 

扩展后的画板(任意方向画图、存储数据):

(1)接口Shape;实现类Line、Rect、Oval

import java.awt.Color;
import java.awt.Graphics;
public abstract class Shape {
	//坐标、颜色
   protected int x1,x2,y1,y2;
   protected Color color;
   
   //draw()方法
   public abstract void draw(Graphics g);
   
}

 

import java.awt.Graphics;
import java.awt.Color;
public class Line extends Shape{
	//重写构造方法
	public Line(int x1,int y1,int x2,int y2,Color color){
		this.x1=x1;
		this.y1=y1;
		this.x2=x2;
		this.y2=y2;
		this.color=color;
	}
	
	//重写draw()方法
   public void draw(Graphics g){
	   g.setColor(color);
	   g.drawLine(x1,y1,x2,y2);
   }	

}

 

import java.awt.Graphics;
import java.awt.Color;
public class Rect extends Shape{
	public Rect(int x1,int y1,int x2,int y2,Color color){
		this.x1=x1;
		this.y1=y1;
		this.x2=x2;
		this.y2=y2;
		this.color=color;
		
	}
	public void draw(Graphics g){
		g.setColor(color);
		g.drawRect(Math.min(x1,x2),Math.min(y1,y2),Math.abs(x2-x1),Math.abs(y2-y1));
	}

}

 

import java.awt.Color;
import java.awt.Graphics;
public class Oval extends Shape{
	public Oval(int x1,int y1,int x2,int y2,Color color){
		this.x1=x1;
		this.y1=y1;
		this.x2=x2;
		this.y2=y2;
		this.color=color;
	}
	public void draw(Graphics g){
		g.setColor(color);
		g.drawOval(Math.min(x1,x2),Math.min(y1, y2),Math.abs(x2-x1),Math.abs(y2-y1));
	}

}

 

(2)DrawUI、DrawListener类

public class DrawUI extends javax.swing.JFrame{

	public static void main(String args[]){
		
		DrawUI ui = new DrawUI();
		ui.initDrawUI();
		
	}
	
	/**
	 * 初始化窗体的方法
	 */
	public void initDrawUI(){
		
		//指调用房当前initDrawUI()方法的对象
		this.setTitle("我的画板v01");
		this.setSize(600,500);
		
		//设置布局
		java.awt.FlowLayout fl = new java.awt.FlowLayout();
		this.setLayout(fl);
		
		//创建一个按钮组
		javax.swing.ButtonGroup group = new javax.swing.ButtonGroup();
		//单选按钮
		javax.swing.JRadioButton line = new javax.swing.JRadioButton("直线");
		//设置按钮的动作命令
		line.setActionCommand("line");
		//默认选中直线
		line.setSelected(true);
		
		javax.swing.JRadioButton rect = new javax.swing.JRadioButton("矩形");
		rect.setActionCommand("rect");
		
		javax.swing.JRadioButton oval = new javax.swing.JRadioButton("椭圆");
		oval.setActionCommand("oval");
		
		//按钮分组
		group.add(line);
		group.add(rect);
		group.add(oval);
		
		
		
		this.add(line);
		this.add(rect);
		this.add(oval);
		
		this.setDefaultCloseOperation(3);
		this.setVisible(true);
		
		//从窗体上获取画布
		//窗体在屏幕上所占据的区域是允许改变颜色的
		java.awt.Graphics g = this.getGraphics();
		
	
		
		//创建一个鼠标监听器对象
		DrawListener dlis = new DrawListener(g,group);
		//给窗体加鼠标监听器
		this.addMouseListener(dlis);
		
	}
	
	
	
}

 

import java.awt.event.MouseEvent;

/**
 * 画板的监听器,实现鼠标监听器接口
 * 
 * @author Administrator
 * 
 */
public class DrawListener implements java.awt.event.MouseListener {

	private int x1, y1, x2, y2;
	private java.awt.Graphics g;
	private javax.swing.ButtonGroup group;
	private String type = "line";

	public DrawListener(java.awt.Graphics g, javax.swing.ButtonGroup group) {
		this.g = g;
		this.group = group;
	}

	// 按下
	public void mousePressed(MouseEvent e) {
		// 先判断要绘制的形状
		// 得到选中选项的动作命令
		type = group.getSelection().getActionCommand();
		System.out.println("要绘制的形状:"+type);
		// 得到鼠标按下时候光标的坐标
		x1 = e.getX();
		y1 = e.getY();
	}

	// 释放
	public void mouseReleased(MouseEvent e) {
		// 得到鼠标释放时候光标的坐标
		x2 = e.getX();
		y2 = e.getY();

		if ("line".equals(type)) {
			// 当鼠标释放的时候就画直线
			g.drawLine(x1, y1, x2, y2);
		} else if (type.equals("rect")) {
			g.drawRect(x1, y1, x2 - x1, y2 - y1);
		} else if (type.equals("oval")) {
			g.drawOval(x1, y1, x2 - x1, y2 - y1);
		}
	}

	// 进入
	public void mouseEntered(MouseEvent e) {
		// System.out.println("mouseEntered");
	}

	// 离开
	public void mouseExited(MouseEvent e) {
		// System.out.println("mouseExited");
	}

	// 点击
	public void mouseClicked(MouseEvent e) {
		// System.out.println("mouseClicked");
	}
}

 对比总结:

 

1、将Line、Rect、Oval分别创建成类,实现Shape接口,便于统一规范存储 

2、因为存储元素(对象)个数不固定,故选择队列存储方式

3、每个对象所要存储的数据变量以属性表示

4、接口以实现程序的目标为准,将各个实现类的共有属性和方法加以归纳提炼

5、运用接口可以灵活使用累的多态性这一特征

6、运用构造函数将一个类中的属性传入另一个类 

分享到:
评论

相关推荐

    Python绘图画板程序 自由绘制 直线 矩形 椭圆 画笔调整 PyQt6

    这个程序实现了常用的绘图功能,如自由绘制、画直线、矩形和椭圆。此外,还提供了选择画笔颜色、调整画笔宽度、清空画布和导出图像的功能。 安装依赖: pip install pyqt6 运行方法: python main.py

    java 做的画板画矩形,椭圆,直线

    在Java编程语言中,我们可以利用Java AWT(Abstract Window Toolkit)和Swing库来创建一个基本的画板,实现画矩形、椭圆和直线的功能。这些组件为开发者提供了丰富的图形用户界面(GUI)功能,使得创建具有绘图能力...

    小画板mfc直线椭圆等工具自制小画板

    在本文中,我们将深入探讨如何使用Microsoft Foundation Class (MFC) 库来创建一个自定义的小画板应用程序,其中包含绘制直线、椭圆以及其他基本图形的功能。MFC 是微软为 Windows 平台提供的一个 C++ 类库,它简化...

    C#画图板-直线、曲线、矩形

    在这个项目中,我们关注的是实现基础的绘图功能,包括绘制直线、曲线和矩形,并允许用户选择线条的颜色。下面我们将详细探讨这些知识点。 1. **Windows Forms 应用程序基础**: - C#中的Windows Forms是构建桌面...

    js原生方法绘制椭圆,矩形,箭头

    椭圆的绘制相对复杂,因为Canvas API没有直接提供椭圆绘制方法。我们可以使用`arc()`方法画圆,然后通过调整坐标和大小来模拟椭圆。这里有一个通用的方法来绘制椭圆: ```javascript function drawEllipse(ctx, x, ...

    c# GDI+ 实现类似画图板的效果,有画矩形、直线、椭圆,保存,新建,擦除,颜色变换

    利用GDI+,开发者可以构建出类似画图板的应用程序,提供用户绘制各种形状,如矩形、直线和椭圆,并进行保存、新建、擦除以及颜色变换等操作。下面我们将详细探讨如何实现这样的功能。 首先,我们需要创建一个...

    VB简易绘图板,实现鼠标画自由曲线、直线、矩形、椭圆、橡皮擦以及无规则异形颜色填充,还支持撤销与重做功能。

    在VB(Visual Basic)编程环境中,我们可以创建一个简易的绘图板应用,它允许用户使用鼠标绘制各种图形,包括自由曲线、直线、矩形、椭圆,并提供了橡皮擦工具来擦除绘制的内容。此外,这个绘图板还具备撤销与重做的...

    java实现画板的基本功能程序

    - **选择工具**:用户应能选择不同的绘图工具,如直线、曲线、矩形、椭圆等。这可以通过创建各种形状类,并在选中相应的工具按钮时激活相应类的方法来实现。 - **橡皮擦**:橡皮擦功能允许用户擦除画布上的部分或...

    qtdrawe.zipqt画板绘制椭圆

    压缩包文件中的`drawtest`可能是一个可执行程序或源代码文件,用于演示如何在Qt环境中实现画板绘制椭圆的功能。如果你希望进一步学习或验证这些概念,可以尝试运行或编译这个文件。 总之,Qt提供了一个强大的绘图...

    简易画板MyPPT可实现简易图形绘制

    《简易画板MyPPT:实现简易图形绘制的创新工具》 在计算机应用领域,图形绘制工具是不可或缺的一部分,它们帮助用户快速、直观地表达思想和创意。"简易画板MyPPT"就是这样一款专为用户提供简单图形绘制功能的软件。...

    C++绘制图形(包括三角形、椭圆、矩形)

    I.绘画: 1.绘制椭圆; 2.绘制矩形; 3.绘制三角形(手绘); 3.绘制三角形(坐标绘制); II.功能: 1.计算三角形(手绘); 2.清空画板; III.说明: 1.使用说明; 2.更新说明;

    JAVA基本功能画板无Bug

    【JAVA基本功能画板无Bug】是一个JAVA编程项目,旨在实现一个功能丰富的画板应用。这个项目涵盖了多种图形绘制工具,如铅笔、橡皮、喷枪、直线、多边形、矩形、圆角矩形和椭圆,充分展示了JAVA在图形用户界面(GUI)...

    java 实现 画板程序

    在本例中,我们将探讨如何利用Java实现一个简单的画板程序,该程序允许用户绘制直线、长方形、椭圆和曲线。 1. **基础架构** - 主类`painter`通过`JFrame`创建了一个窗口,设置了背景颜色为白色,并添加了一个`...

    MFC画直线圆矩形

    `CView`类提供了基本的绘图功能,而`CDrawView`将扩展这些功能以实现画直线、圆和矩形。 在`CDrawView`中,我们需要重写几个关键函数: 1. `OnDraw(CDC* pDC)`:这是绘制视图的主要函数。在这里,我们将使用`pDC`...

    MFC简易绘画板功能::

    在这个MFC简易绘画板项目中,我们看到它集成了多种基本的图形绘制功能,包括画笔、直线、矩形、圆形和椭圆。下面我们将深入探讨这些功能的实现原理以及MFC在其中的作用。 首先,MFC提供了基于Windows API的封装,...

    基于qt实现的minidraw画板程序

    "基于Qt实现的Minidraw画板程序"就是这样一个例子,它利用Qt的Widget模块,为用户提供了一个简单的画板,能够绘制多种基本图形。 首先,我们来看看这个程序的核心功能。Minidraw画板程序提供了五种基本图形的绘制...

    实现基本功能的初级画板(初来乍到)

    1. **基本图形绘制**:初级画板的核心功能之一是提供基本图形的绘制,例如直线、矩形、圆形、椭圆、多边形等。这些图形的生成可以通过数学公式计算坐标点,然后连接这些点形成图形。例如,直线通过两点确定,矩形和...

    C++程序开发基于Qt实现的简单绘画板程序源码+项目说明.zip

    - 绘制点、直线、椭圆、矩形等基本几何图形; - 存储、读取绘图文件; - 撤回、重做等功能; - 调节线宽、线条颜色; - 显示鼠标坐标位置。 ## 注意事项 程序图标使用绝对路径,图标资源在res文件夹里。 【备注】 1...

    MFC实现画板

    在"画板"这个项目中,我们关注的是图形绘制和交互功能的实现。 首先,我们需要了解MFC中的CView类。它是MFC框架中用于显示和处理窗口视图的基类。在我们的画板应用中,我们将继承自CView,并重写其OnDraw函数,以...

    java画板代码 可以画图形

    这个类提供了一系列的方法,如`drawLine()`, `fillRect()`, `drawOval()`等,用于在屏幕上绘制线条、矩形、椭圆等基本形状。Swing库中的`javax.swing.JComponent`类提供了`paintComponent(Graphics g)`方法,这是...

Global site tag (gtag.js) - Google Analytics