一个利用GUI方法实现简单绘图功能的应用程序.doc_第1页
一个利用GUI方法实现简单绘图功能的应用程序.doc_第2页
一个利用GUI方法实现简单绘图功能的应用程序.doc_第3页
一个利用GUI方法实现简单绘图功能的应用程序.doc_第4页
一个利用GUI方法实现简单绘图功能的应用程序.doc_第5页
已阅读5页,还剩25页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

目 录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); 经典婚庆主持词炮竹声声贺新婚,欢声笑语迎嘉宾.尊敬各位来宾,各位领导,各位亲朋好友,先生们,女士们,活泼可爱的小朋友们,大家好! 好歌好语好季节,好人好梦好姻缘.来宾们今天是公元*年*月*日(农历六月初八)是良辰吉日,在这大吉大利吉祥喜庆的日子里,我们怀着十二分的真诚的祝福相聚在*酒楼一楼婚宴大厅共同庆贺*先生与*小姐新婚典礼.(首先我们给予掌声的恭喜)大家都知道结婚是人生中的一件大事,而婚礼更是人生中最幸福神圣的时刻,尤其婚礼上浪漫温馨高雅别致的婚礼仪式以及亲朋好友的良好祝愿会给新人一生永远带来最美好的回忆.各位亲朋好友,我是本次婚礼庆典的主持人*.今天我十分荣幸地接受新郎新娘的重托,步入这神圣而庄重的婚礼殿堂为新郎*,新娘*的婚礼担任司仪之职.让我们在这里共同见证一对新人人生中最幸福神圣美好的一刻!真是:百鸟朝凤凤求凰,龙凤呈祥喜洋洋.让我们用掌声祝贺他们祝福新人凤凰展翅迎朝晖,恩爱鸳鸯比翼飞.携手同步知心人,共创宏图献真情.郎才女貌天作美,洞房花烛喜成双.在神圣的婚礼进行曲中一对新人手挽手,肩并肩缓缓步入婚礼大厅.脸上充满了无比幸福的笑容让我们用掌声与鲜花给予一对新人最诚挚的祝福.婚姻是人生大事,结婚典礼对青年男女来说是一生中最重要的时刻.你也笑,我也笑,亲朋好友齐来到.天也新,地也新,众星捧月迎新人.新郎新娘台上站,甜蜜感觉涌心间.风风雨雨牵手过,今天喜结美姻缘.亲朋好友齐相聚,欢欢喜喜来贺喜. * * * 天仙配,幸福的生活比蜜甜.在这个激动人心

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论