/**
* 画图板的升级 ,可以实现图形和颜色的选择,可以以此为模版继续添加图形和颜色
*/
import java.awt.Color;
import java.awt.Graphics;
import javax.swing.*;
public class DrawUI {
public static void main(String args[]) {
DrawUI dr = new DrawUI();
dr.initUI();
}
public void initUI() {
JFrame jf = new JFrame("画图板");
jf.setSize(500,600);
jf.setResizable(false); //窗体大小不能变化
jf.setLocation(300, 20);
jf.setLayout(null);
JLabel jlb = new JLabel("请选择");
jlb.setBounds(10,420,100,30);
jf.add(jlb);
/**
* 画图区域
*/
JPanel jp = new JPanel();
jp.setSize(500,400);
jp.setBackground(Color.DARK_GRAY);
jf.add(jp);
/**
* 图形选择
*/
JRadioButton jrb1 = new JRadioButton("直线");
JRadioButton jrb2 = new JRadioButton("矩形");
JRadioButton jrb3 = new JRadioButton("圆");
JRadioButton jrb4 = new JRadioButton("3D-rect");
JRadioButton jrb5 = new JRadioButton("Full3DRect");
/**
* 设置相应图形的指令
*/
jrb1.setActionCommand("line");
jrb2.setActionCommand("rect");
jrb3.setActionCommand("oval");
jrb4.setActionCommand("3D-rect");
jrb5.setActionCommand("Full3DRect");
jrb1.setBounds(10, 450,70, 50);
jrb2.setBounds(100, 450,70, 50);
jrb3.setBounds(200, 450,70, 50);
jrb4.setBounds(300, 450,70, 50);
jrb5.setBounds(400, 450,90, 50);
ButtonGroup group1 = new ButtonGroup(); //组管理,实现图形单选
group1.add(jrb1);
group1.add(jrb2);
group1.add(jrb3);
group1.add(jrb4);
group1.add(jrb5);
jrb1.setSelected(true); //默认选择为直线
jf.add(jrb1);
jf.add(jrb2);
jf.add(jrb3);
jf.add(jrb4);
jf.add(jrb5);
/**
* 颜色选择
*/
JRadioButton jrba = new JRadioButton("红色");
JRadioButton jrbb = new JRadioButton("蓝色");
JRadioButton jrbc = new JRadioButton("黑色");
JRadioButton jrbd = new JRadioButton("黄色");
JRadioButton jrbe = new JRadioButton("绿色");
/**
* 设置相颜色形的指令
*/
jrba.setActionCommand("red");
jrbb.setActionCommand("blue");
jrbc.setActionCommand("black");
jrbd.setActionCommand("yellow");
jrbe.setActionCommand("green");
jrba.setBounds(10, 500,70, 50);
jrbb.setBounds(100, 500,70, 50);
jrbc.setBounds(200, 500,70, 50);
jrbd.setBounds(300, 500,70, 50);
jrbe.setBounds(400, 500,70,50);
ButtonGroup group2 = new ButtonGroup(); //组管理,实现颜色单选
group2.add(jrba);
group2.add(jrbb);
group2.add(jrbc);
group2.add(jrbd);
group2.add(jrbe);
jrba.setSelected(true); //默认选择为红色
jf.add(jrba);
jf.add(jrbb);
jf.add(jrbc);
jf.add(jrbd);
jf.add(jrbe);
jf.setDefaultCloseOperation(3);
jf.setVisible(true);
/**
* 获取可以画的区域
*/
Graphics g = jp.getGraphics();
DrawUIListener dl = new DrawUIListener(g, group1, group2);
jp.addMouseListener(dl);
}
}
/**
* 画图的监听器,实现鼠标监听器接口
*/
import java.awt.Color;
import java.awt.Graphics;
import java.awt.event.*;
import javax.swing.ButtonGroup;
import javax.swing.ButtonModel;
public class DrawUIListener implements MouseListener {
private Graphics g;
private ButtonGroup group1,group2;
private int x1,x2,y1,y2;
String shapetype, colortype;
public DrawUIListener(Graphics g,ButtonGroup group1,ButtonGroup group2) {
this.g = g;
this.group1 = group1;
this.group2 = group2;
}
public void mousePressed(MouseEvent e) {
x1 = e.getX();
y1 = e.getY();
ButtonModel model1 = group1.getSelection();
ButtonModel model2 = group2.getSelection();
/**
* 获取相应图形和颜色对应的指令
*/
String commond1 = model1.getActionCommand();
String commond2 = model2.getActionCommand();
shapetype = commond1;
colortype = commond2;
/**
* 判断得到的指令,并执行相应的颜色选择
*/
if(colortype.equals("red")) {
g.setColor(Color.RED);
}
else if(colortype.equals("blue")) {
g.setColor(Color.blue);
}
else if(colortype.equals("black")) {
g.setColor(Color.BLACK);
}
else if(colortype.equals("yellow")) {
g.setColor(Color.YELLOW);
}
else if(colortype.equals("green")) {
g.setColor(Color.GREEN);
}
}
public void mouseReleased(MouseEvent e) {
x2 = e.getX();
y2 = e.getY();
/**
* 判断得到的指令,并执行相应的图形选择
*/
if(shapetype.equals("line")) {
drawLine();
}
else if(shapetype.equals("rect")) {
drawRect();
}
else if(shapetype.equals("oval")) {
drawOval();
}
else if(shapetype.equals("3D-rect")) {
draw3DRect();
}
else if(shapetype.equals("Full3DRect")) {
fill3DRect();
}
}
/**
* 画直线的方法
*/
public void drawLine() {
g.drawLine(x1, y1, x2, y2);
}
/**
* 画矩形的方法
* 画矩形四中选择drawRect(x,y,width,height)
* 铭记(x,y)为矩形左上角的坐标,wedth,heigth 为大的减小的
* 1.从左上角到右下角
* 2.从左下角到右上角
* 3.从右下角到左上角
* 4.从右上角到左下角
*/
public void drawRect() {
if(x1<x2&&y1<y2) {
g.drawRect(x1, y1,x2-x1,y2-y1); //从左上角到右下角
}
else if(x1<x2&&y1>y2) {
g.drawRect(x1, y2, x2-x1,y1-y2); //从左下角到右上角
}
else if(x1>x2&&y2>y1) {
g.drawRect(x2, y1, x1-x2,y2-y1); //从右上角到左下角
}
else if(x1>x2&&y1>y2) {
g.drawRect(x2, y2, x1-x2, y1-y2); //从右下角到左上角
}
}
/**
* 画圆或者椭圆的方法
*/
public void drawOval() {
if(x1<x2&&y1<y2) {
g.drawOval(x1, y1,x2-x1,y2-y1); //从左上角到右下角
}
else if(x1<x2&&y1>y2) {
g.drawOval(x1, y2, x2-x1, y1-y2); //从左下角到右上角
}
else if(x1>x2&&y2>y1) {
g.drawOval(x2, y1, x1-x2,y2-y1); //从右上角到左下角
}
else if(x1>x2&&y1>y2) {
g.drawOval(x2, y2, x1-x2, y1-y2); //从右下角到左上角
}
}
/**
* 画3D rect 的方法
*/
public void draw3DRect() {
if(x1<x2&&y1<y2) {
g.draw3DRect(x1, y1,x2-x1,y2-y1,true); //从左上角到右下角
}
else if(x1<x2&&y1>y2) {
g.draw3DRect(x1, y2, x2-x1,y1-y2,true); //从左下角到右上角
}
else if(x1>x2&&y2>y1) {
g.draw3DRect(x2, y1, x1-x2,y2-y1,true); //从右上角到左下角
}
else if(x1>x2&&y1>y2) {
g.draw3DRect(x2, y2, x1-x2, y1-y2,true); //从右下角到左上角
}
}
/**
* 画fill3D rect 的方法
*/
public void fill3DRect() {
if(x1<x2&&y1<y2) {
g.fill3DRect(x1, y1,x2-x1,y2-y1,true); //从左上角到右下角
}
else if(x1<x2&&y1>y2) {
g.fill3DRect(x1, y2, x2-x1,y1-y2,true); //从左下角到右上角
}
else if(x1>x2&&y2>y1) {
g.fill3DRect(x2, y1, x1-x2,y2-y1,true); //从右上角到左下角
}
else if(x1>x2&&y1>y2) {
g.fill3DRect(x2, y2, x1-x2, y1-y2,true); //从右下角到左上角
}
}
/**
* 没有用到的MouseListener接口里面的抽象方法,抽象方法为空
*/
public void mouseEntered(MouseEvent e) {
}
public void mouseExited(MouseEvent e) {
}
public void mouseClicked(MouseEvent e) {
}
}
实现效果 简单图像的绘画:
相关推荐
画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码画图板 代码...
在画图板程序中,视图会实时反映模型中的图形变化,如绘制、移动或改变颜色等。 - **Controller(控制器)**:控制器作为模型和视图之间的桥梁,接收用户的输入,并将这些输入转化为对模型的更新操作。例如,当用户...
1. 颜色选择:用户可以选择不同颜色进行绘制,画图板支持多种颜色模式,包括标准颜色和自定义颜色,使得动态改变颜色成为可能。 2. 工具选择:画图板提供了多种画笔、线条、形状工具,如直线、曲线、矩形、椭圆等,...
在这个项目中,“vc++画图板(计算机图形学)”是一个基于Microsoft Visual C++(简称VC++)编写的简易画图应用程序,旨在帮助用户理解和实践计算机图形学的基本概念和技术。 VC++是一种强大的集成开发环境,它支持...
【VB画图板 用户图形界面设计】是一个使用Visual Basic(VB)编程语言开发的简易画图应用程序,重点在于用户界面的设计而非复杂的绘图功能。在这个项目中,开发者可能利用了VB的基本控件和事件处理机制来创建一个...
在IT领域,"画图板"通常指的是一个用于创建、编辑和操作简单图形的应用程序,类似于Windows操作系统内置的“画图”程序。这个程序提供了一系列基础的绘图工具,让用户可以进行基本的图像创作和编辑。下面将详细介绍...
Java 画图板是使用 Java 语言编写的图形绘制程序,提供了基本的绘图功能,如画笔、直线、椭圆、矩形等,用户可以使用该程序绘制简单的图形。下面我们将对 Java 画图板程序进行详细的分析和解释。 1. Java 画图板...
QT画图板是一个基于Qt库开发的图形用户界面应用程序,主要功能是提供一个交互式的画布,用户可以在上面进行绘图操作。对于初学者来说,QT画图板是一个极好的学习资源,它展示了Qt库在图形绘制和用户交互方面的强大...
在Java编程语言中,实现一个简单的Windows画图板是一个经典的练习,它可以帮助初学者更好地理解图形用户界面(GUI)的设计以及事件处理机制。这个项目通常会涉及到Java的Swing库,这是一个用于创建桌面应用程序的GUI...
5. **颜色选择**:用户可以改变画笔颜色,这需要实现颜色选择器,可能是一个颜色对话框,用户选择颜色后,将所选颜色设置为当前画笔颜色。 6. **线条样式**:线形大小和虚实的调整提供了更多绘制效果。线宽可以通过...
【描述】"仿XP画图板"实现了画图板的多数核心功能,包括但不限于选择不同的画笔、颜色、线型,以及橡皮擦、填充、复制、粘贴、撤销、重做等操作。它的界面设计与XP原版画图板极其相似,这不仅提供了用户熟悉的操作...
在Android平台上,开发一个画图板应用涉及到许多关键的技术点,包括用户交互、图形渲染、数据存储以及资源管理等。以下是对"基于Android系统的画图板"这一主题的详细解析: 1. **用户交互**:Android系统提供了丰富...
这个画图板允许用户绘制多种图形,包括铅笔画、直线、空心和实心的圆形、椭圆以及矩形,并支持区域填充、颜色选择、画笔大小调整、橡皮擦功能、文件的新建、打开、保存以及字体选择。 一、实验目的 1. 巩固计算机...
这个文件很可能是画图板的源代码、编译后的可执行文件、安装包,或者是关于画图板的教程、说明文档等资源。用户在下载并解压后,可以获取到这个画图板的全部内容,从而在自己的设备上使用或研究。 综合以上信息,...
在本文中,我们将深入探讨基于VC++的"vc画图板源码",这是一个用于创建图形界面应用程序的项目。这个项目的核心是利用MFC(Microsoft Foundation Classes)库,它是Microsoft为C++开发者提供的一个用于构建Windows...
"简单画图板的设计"是一个关于创建一个基本图形编辑器的话题,主要涉及到计算机图形学、用户界面设计以及可能的编程实现。在这个项目中,我们可能会遇到以下关键知识点: 1. **计算机图形学基础**:画图板应用的...
这个"基于qt实现的画图板"项目提供了一个基础的图形用户界面(GUI)应用,让用户能够进行基本的绘画操作,比如选择画笔、填充颜色、打开和保存图像。以下是关于这个项目的一些关键知识点和相关技术的详细解释: 1. ...
Java画图板应用是一种基于Java编程语言开发的图形用户界面(GUI)程序,它提供了类似Windows操作系统内置画图板的功能。这个程序的核心是利用Java的Swing或JavaFX库来构建用户界面,允许用户进行基本的绘图操作,如...
通过这个画图板源码示例,开发者可以学习到图形界面设计、事件处理、图形绘制、颜色管理等多方面的编程知识。此外,它还可以帮助初学者理解对象导向编程、内存管理、数据结构以及用户交互设计等概念。对于想要自己...
总之,"MFC简单画图板"是一个基础的图形界面应用实例,它展示了MFC在GUI编程中的应用,对于想要涉足Windows桌面应用程序开发的初学者而言,这是一个不错的实践项目。通过学习和扩展这个应用,开发者不仅可以提升MFC...