一个利用GUI方法实现简单绘图功能的应用程序

上传人:痛*** 文档编号:46350245 上传时间:2021-12-12 格式:DOC 页数:28 大小:299.18KB
返回 下载 相关 举报
一个利用GUI方法实现简单绘图功能的应用程序_第1页
第1页 / 共28页
一个利用GUI方法实现简单绘图功能的应用程序_第2页
第2页 / 共28页
一个利用GUI方法实现简单绘图功能的应用程序_第3页
第3页 / 共28页
点击查看更多>>
资源描述
目 录1. 程序设计内容概论11.1程序设计的目的11.2程序设计的任务12 设计思想12.1需求分析12.2总体设计12.2.1面板布局 12.2.2实现绘画图形22.2.3填充功能22.2.4画笔的粗细及画笔的颜色变更22.2.5实现鼠标单击和鼠标拖拽进行绘图22.3编程环境32.4.工具说明33 系统流程44 设计UML类图55 设计层次结构树66 运行结果与分析77 设计总结128.参考文献139.附录141 程序设计内容概论1.1程序设计的目的 本程序是一个利用GUI方法实现简单绘图功能的应用程序。1.2程序设计的任务程序主要创建了5个JRadioButton, 1个JCheckBox,2个JButton以及一个JSlider用于选择绘画功能操作。接着创建三个面板用于设计绘图的整体画板,并利用按钮监听器,滑动条和鼠标操作实现在面板上绘图的简单功能。在程序中,利用创建JRadioButton实现多选一绘画功能,创建JCheckBox实现填充功能,而2个JButton则分别实现颜色更变和清除画板。同时本程序使用了鼠标点击,鼠标释放和鼠标拖拽来进行画板绘画,利用鼠标点击实现初点坐标获取,在绘画曲线时,主要通过鼠标拖拽实现在画板上不断绘制(不断进行末点坐标赋值初点);在绘画直线时,主要通过鼠标拖拽达到动态效果,并通过鼠标释放最终描绘出直线;在绘画矩形和圆时,主要通过鼠标拖拽达到动态效果,并通过鼠标释放最终描绘出矩形和圆;在绘画粗线时,主要通过不断重画实心圆来实现。 2 设计思想2.1需求分析2.1.1面板布局2.1.2实现绘画图形(曲线,直线,圆,椭圆,矩形)3.1.3填充功能(其中包括圆的填充,椭圆圆的填充,矩形圆的填充)3.1.4画笔的粗细及画笔的颜色变更3.1.5实现鼠标单击和鼠标拖拽进行绘图2.2总体设计2.2.1面板布局主要创建5个JRadioButton, 1个JCheckBox,2个JButton以及一个JSlider,同时创建三个面板(一个面板用于绘图,一个面板用于把所有按钮及滑动条等添加进去,一个面板用于把已经添加了按钮和滑动条的面板添加进去,用于区分绘图面板和按钮面板的位置),利用盒式布局管理器将所有的组件(包括5个JRadioButton, 1个JCheckBox,2个JButton以及一个JSlider)进行布局,再利用边界布局管理器对面板进行位置编排,绘图面板在中间,另一个在西边。最终完成了画板的布局。2.2.2实现绘画图形(曲线,直线,圆,椭圆,矩形)在实现绘画的功能,主要通过创建ButtonGroup从而把所有的JRadioButton都添加进去,从而达到在描绘图形时多选一的选择功能;利用按钮监听器,利用Object source=event.getSource()语句当source=op1时进行曲线绘画,在实现曲线绘画的功能时,主要利用了鼠标的点击和鼠标的拖拽,通过鼠标的点击来扑捉第一个坐标点,然后利用鼠标的拖拽来不断变换第一个点的坐标(利用sx=x和sy=y语句),从而将所有点都连接起来,最终实现了在画板上描绘曲线的功能;当source=op2时进行直线绘画,在实现直线绘画的功能时,主要利用了鼠标的点击,鼠标的释放和鼠标的拖拽,通过鼠标的点击来扑捉直线的第一个坐标点,然后利用鼠标的拖拽选择直线的另一个点,最终通过鼠标的释放在画板上描绘出直线来;当source=op3时进行圆和椭圆绘画,在实现圆和椭圆绘画的功能时,主要利用了鼠标的点击,鼠标的释放和鼠标的拖拽,通过鼠标的点击来扑捉圆和椭圆的一个坐标点,然后利用鼠标的拖拽选择圆和椭圆的大小,最终通过鼠标的释放在画板上描绘出圆和椭圆来;当source=op4时进行矩形绘画,在实现矩形绘画的功能时,主要利用了鼠标的点击,鼠标的释放和鼠标的拖拽,通过鼠标的点击来扑捉矩形的一个坐标点,然后利用鼠标的拖拽选择矩形的大小,最终通过鼠标的释放在画板上描绘出矩形来。2.2.3填充功能(其中包括圆的填充,椭圆圆的填充,矩形圆的填充)通过JCheckBox创建一个按钮,利用按钮监听器决定是否要描绘填充图形,如果是则将实现赋值fill=true,否则fill=false,然后通过布尔值判断在描绘图形时是draw还是fill,如果布尔值是ture时则实现了图形的填充。2.2.4画笔的粗细及画笔的颜色变更画笔的粗细主要是通过不断地重画填充圆来实现,通过鼠标的拖拽不断地在画板上进行重画;而粗细则由创建的JSlider来调节圆的半径, 如果圆的半径越大则所绘出的曲线越粗,反则越细;画笔的颜色变更主要通过创建的JButton按钮,利用按钮监听器,当按下了按钮,则实现c=JColorChooser.showDialog(right,choose,c)语句,从而把初始的画笔颜色(黑色)改变。2.2.5实现鼠标单击和鼠标拖拽进行绘图 通过语句right.addMouseListener和语句addMouseMotionListener(new listen1()来设计在right面板上进行鼠标单击和鼠标拖拽等绘图,通过鼠标的单击(mousePressed)获取图形的第一个点,再利用鼠标的拖拽(mouseDragged)选择图形的形状,大小和方向等。2.3编程环境 本次编程的环境为JDK。2.4.工具说明 本次编程工具为UltraEdit。3 系统流程开始填充画笔粗细清除颜色粗线按钮矩形按钮画圆按钮直线按钮曲线按钮f=2f=3f=4f=5f=1填充 Y Nsize 改变fill=falsefill=true改变颜色输入颜色 Y N f=5f=4f=3f=2f=1画出粗线画出矩形画出圆画出直线画出曲线结束画板 4 设计UML类图 DrawPanelf:intsx:intsy:intx:inty:intfill:booleanflag:booleanmousePressed():voidmouseReleased():voidmouseDragged():voidmouseEntered():voidmouseExited():voidmouseClicked():voidmouseMoved():voidactionPerforned():voidstateChanged():voidDraw1main(args:String):void 绘图程序UML类图5 设计层次结构树JFrameJPanel(Border Layout)JPanelCenter-rightJPanelWest-left(Vertial Box Layout)JRadioButtonJRadioButtonJRadioButtonJRadioButtonJRadioButtonJCheckBoxJButtonJButtonJSliderJLabel6 运行结果与分析6.1 整体画板展示画板分析:利用盒式布局管理器将所有的组件(包括5个JRadioButton, 1个JCheckBox,2个JButton以及一个JSlider)进行布局,再利用边界布局管理器对面板进行位置编排,绘图面板在中间(Center),另一个在西边(West)。6.2用曲线、直线、圆、矩形画黑白小屋子6.3用粗线写祝福语6.4用填充效果画图6.5.用带有颜色的画笔画图7 设计总结在本次java课程设计中,我设计了一个绘图应用程序。该绘图应用程序实现了画曲线,直线,画圆,画矩形和粗线功能,同时可以实现图形的填充和颜色的变换,另外还设计了一个清除画板按键,可以应用于平时一些简单的画图操作。在本绘图应用程序中,所存在的问题是图形的种类不够完善,未能实现画弧,画多边形等功能,另外一个不足的地方时整个画板只能画一种颜色的图形,未能满足更高要求的绘画需要。在本次java课程设计中,我收获了很多。特别是在编写java程序时,必须先对程序的功能进行初步的分析,得到程序中每一个功能所需要用到的方法或思路,同时根据功能的相似来设计一类功能的实现,并通过某些语句的改变达到多功能效果,例如在本次设计中,分析可得圆和矩形有很大的相似度,利用drawOval和drawRect的变换可以达到绘画的效果。在设计图形的填充时,我参考了本学期所学的JCheckBox方法和判断语句,有效地处理了图形的填充问题,并系统地学习了鼠标拖拽的应用。在本次设计中,最难处理的问题是用鼠标拖拽来画直线,圆和矩形,因为在使用鼠标拖拽时,会出现在画板上不断重画的效果,无法达到自己想要的效果,后来在同学的帮助和参考部分java教科书下,成功了解决了这个问题,而在解决这个问题,使我认识到学习不能只局限于课本,必要时应该要多阅读一些相关的java书籍,从而让自己的知识面更加广,处理问题更加有效率。所以,经过本次编写绘图应用程序,使我把本学期所学的java知识充分地运用到课程设计中来,既提高了自己学习的主动性,同时为自己以后的学习打下了更深的基础。参考文献1 John Lewis、Willian Loftus,Java程序设计教程,北京:电子工业出版社,2009;2 杨树林、胡洁萍,Java语言最新实用案例教程,北京:清华大学出版社,2006;3 谭浩强,C程序设计,北京:清华大学出版社,2008。附录:import javax.swing.JFrame;public class Draw1 public static void main (String args) JFrame frame = new JFrame (Draw); frame.setDefaultCloseOperation (JFrame.EXIT_ON_CLOSE); DrawPanel draw =new DrawPanel(); frame.getContentPane().add (draw); frame.pack(); frame.setVisible(true); import java.awt.*;import java.awt.event.*;import javax.swing.*;import javax.swing.event.*;import java.util.*;import javax.swing.colorchooser.*;public class DrawPanel extends JPanel private JPanel p1,right,left; private JRadioButton op1,op2,op3,op4,op5; private JCheckBox c1; private JButton a,b; private int f=1; private int sx, sy, x,y; private boolean fill=false; private boolean flag=false; private Color c; private Point point1=null,point2=null; private JSlider slider; private JLabel label1; private int size=10; public DrawPanel() c =Color.black; right = new JPanel(); left = new JPanel(); p1 = new JPanel(); ButtonGroup g = new ButtonGroup(); op1 = new JRadioButton(曲线,true); op2 = new JRadioButton(直线,false); op3 = new JRadioButton(画圆,false); op4 = new JRadioButton(矩形,false); op5 = new JRadioButton(粗线,false); g.add(op1); g.add(op2); g.add(op3); g.add(op4); g.add(op5); c1 = new JCheckBox(填充); a=new JButton(颜色); b=new JButton(清除); slider =new JSlider(JSlider.VERTICAL,0,25,10); slider.setMajorTickSpacing(5); slider.setMinorTickSpacing(1); slider.setPaintTicks(true); slider.setPaintLabels(true); slider.setAlignmentX(Component.LEFT_ALIGNMENT); label1 =new JLabel(size:10); label1.setAlignmentX(Component.LEFT_ALIGNMENT); p1.setLayout(new BoxLayout(p1,BoxLayout.Y_AXIS); p1.add(op1); p1.add(op2); p1.add(op3); p1.add(op4); p1.add(op5); p1.add(c1); c1.addActionListener(new listen3(); p1.add(a); p1.add(Box.createRigidArea(new Dimension(0,10); p1.add(b); a.addActionListener(new listen4(); b.addActionListener(new listen5(); p1.add(slider); slider.addChangeListener(new listen6(); p1.add(label1); left.add(p1); right.setBackground(Color.white); op1.addActionListener(new listen2(); op2.addActionListener(new listen2(); op3.addActionListener(new listen2(); op4.addActionListener(new listen2(); op5.addActionListener(new listen2(); right.addMouseListener(new listen1(); right.addMouseMotionListener(new listen1(); setLayout(new BorderLayout(); add(right,Center); add(left,West); setBackground(Color.white); setPreferredSize(new Dimension(500,450); private class listen1 implements MouseListener,MouseMotionListener public void mousePressed(MouseEvent event) flag=false; point1=event.getPoint(); sx=point1.x; sy=point1.y ; public void mouseReleased(MouseEvent event) int x0,y0; Graphics g=right.getGraphics(); switch(f) case 2: point2=event.getPoint(); x=point2.x; y=point2.y ; g.setColor(c); g.drawLine(sx,sy,x,y); break; case 3: point2=event.getPoint(); x=point2.x; y=point2.y ; x0=xsx?sx:x; y0=ysy?sy:y; g.setColor(c); if(! fill) g.drawOval(x0,y0,Math.abs(x-sx),Math.abs(y-sy); else g.fillOval(x0,y0,Math.abs(x-sx),Math.abs(y-sy); break; case 4: point2=event.getPoint(); x=point2.x; y=point2.y ; x0=xsx?sx:x; y0=ysy?sy:y; g.setColor(c); if(! fill) g.drawRect(x0,y0,Math.abs(x-sx),Math.abs(y-sy); else g.fillRect(x0,y0,Math.abs(x-sx),Math.abs(y-sy); break; public void mouseEntered(MouseEvent event) public void mouseExited(MouseEvent event) public void mouseClicked(MouseEvent event) public void mouseMoved(MouseEvent event) public void mouseDragged(MouseEvent event) int x0,y0; Graphics g=right.getGraphics(); switch(f) case 1: point2=event.getPoint(); x=point2.x; y=point2.y ; g.setColor(c); g.drawLine(sx,sy,x,y); sx=x; sy=y; break; case 2: if(! flag) point2=event.getPoint(); x=point2.x; y=point2.y ; g.drawLine(sx,sy,x,y); flag=true; else g.setXORMode(Color.white); g.drawLine(sx,sy,x,y); point2=event.getPoint(); x=point2.x; y=point2.y ; g.drawLine(sx,sy,x,y); break; case 3: if(! flag) point2=event.getPoint(); x=point2.x; y=point2.y ; x0=xsx?sx:x; y0=ysy?sy:y; if(! fill) g.drawOval(x0,y0,Math.abs(x-sx),Math.abs(y-sy); else g.fillOval(x0,y0,Math.abs(x-sx),Math.abs(y-sy); flag=true; else g.setXORMode(Color.white); x0=xsx?sx:x; y0=ysy?sy:y; if(! fill) g.drawOval(x0,y0,Math.abs(x-sx),Math.abs(y-sy); else g.fillOval(x0,y0,Math.abs(x-sx),Math.abs(y-sy); point2=event.getPoint(); x=point2.x; y=point2.y ; x0=xsx?sx:x; y0=ysy?sy:y; if(! fill) g.drawOval(x0,y0,Math.abs(x-sx),Math.abs(y-sy); else g.fillOval(x0,y0,Math.abs(x-sx),Math.abs(y-sy); break; case 4: if(! flag) point2=event.getPoint(); x=point2.x; y=point2.y ; x0=xsx?sx:x; y0=ysy?sy:y; if(! fill) g.drawRect(x0,y0,Math.abs(x-sx),Math.abs(y-sy); else g.fillRect(x0,y0,Math.abs(x-sx),Math.abs(y-sy); flag=true; else g.setXORMode(Color.white); x0=xsx?sx:x; y0=ysy?sy:y; if(! fill) g.drawRect(x0,y0,Math.abs(x-sx),Math.abs(y-sy); else g.fillRect(x0,y0,Math.abs(x-sx),Math.abs(y-sy); point2=event.getPoint(); x=point2.x; y=point2.y ; x0=xsx?sx:x; y0=ysy?sy:y; if(! fill) g.drawRect(x0,y0,Math.abs(x-sx),Math.abs(y-sy); else g.fillRect(x0,y0,Math.abs(x-sx),Math.abs(y-sy); break; case 5: point2=event.getPoint(); x=point2.x; y=point2.y ; g.setColor(c); g.fillOval(x,y,size,size); break; private class listen2 implements ActionListener public void actionPerformed(ActionEvent event) Object source=event.getSource(); if(source=op1)f=1; else if(source=op2)f=2; else if(source=op3)f=3; else if(source=op4)f=4; else f=5; private class listen3 implements ActionListener public void actionPerformed(ActionEvent event) if(c1.isSelected() fill=true; else fill=false; private class listen4 implements ActionListener public void actionPerformed(ActionEvent event) JColorChooser colorChooser =new JColorChooser(); c=JColorChooser.showDialog(right,choose,c); private class listen5 implements ActionListener public void actionPerformed(ActionEvent event) repaint(); private class listen6 implements ChangeListener public void stateChanged(ChangeEvent event) size=slider.getValue(); label1.setText(size+size);
展开阅读全文
相关资源
相关搜索

最新文档


当前位置:首页 > 办公文档


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!