资源描述
西安科技大学
软件工程课程设计报告
题目:画图板应用程序开发
班级
学号:
姓名:
12月
目 录
1 绪论…………………………………………………………………………3
2 可行性研究报告……………………………………………………………3
3 需求分析报告………………………………………………………………4
4 总体设计报告………………………………………………………………7
5 详细设计报告………………………………………………………………8
6 系统实现报告………………………………………………………………12
7软件测试报告………………………………………………………………32
参照文献
1、绪论
1.1 目和意义
用过微软Windows操作系统人一定都对Windows自带画图板非常熟悉了。同图像解决软件界老大Photoshop比起来,它虽然不及Photoshop功能强大,内容丰富,但是作为Windows始终以来都内带附件程序,它具备小巧玲珑,简朴实用等其她绘图软件所不具备长处。同步它风格也被许多其她绘图软件所仿效。
作为一种软件工程专业学生自己也想亲自动手编写一种属于自己,简朴实用绘图程序。通过本次课程设计可以增长对整个流程熟悉以及对程序组织构造和框架理解,对后来开发和设计更大更复杂程序无疑有更大协助。
1.2 任务
书写开发文档,分析和制定整个开发过程,然后开发一种自己画图板应用程序。
2、可行性研究报告
2.1 进行可行性研究办法
本应用程序可行性研究是通过对比windows自带画板程序方式进行,对Windows里面画板进行分析研究,分析得出本应用软件应当实现基本功能,并依照自己能力进行了功能上增长。
2.2 评价尺度
本软件在评价时应从如下几种方面进行分析:
开发时间应尽量短;
功能实当代码应尽量少;
代码执行效率要高;
有较强容错能力;
2.3技术方面可行性
系统现阶段发展过程中,运用既有人力和物力是完全具备能力开发出来,作为阶段性产品,日后发展空间大,实现办法逐渐简朴容易,因此画图板应用程序在技术上是完全可行。
a. 在当前限制条件下,该程序功能目的能达到;
b. 运用既有技术,该程序功能可以实现;
c. 由于能力局限性,现阶段功能不够完美,还可以在日后完善;
d. 在规定限期内,本程序可以完毕;
2.4法律方面可行性
本程序不会在后台扫描顾客磁盘文献;
本程序为完全免费,没有任何赚钱行为,并且仅在内部流通,不予推广,因此不涉及浸犯微软版权行为,因此本软件完全合法。
软件服务条款要与中华人民共和国法律解释相一致,一致批准服从高等法院所有管辖。如发生软件服务条款与中华人民共和国法律相抵触时,则这些条款将完全按法律规定重新解释,而其他条款则仍旧保持对顾客产生法律效力和影响。
2.3 经济可行行
本系统开发成本低,不需要特殊规定。
2.4 可行性结论
综上所述,本应用程序在技术上可行,经济上可行,操作上可行,因而本应用程序可及时着手开发。
3、需求分析报告
对软件需求完全理解对于软件开发工作成功是至关重要,需求阐明任务是发现、规范过程,有益于提高软件开发过程中能见度,便于对软件开发过程中控制与管理,便于采用工程办法开发软件,提高软件质量,便于开发人员、维护人员、管理人员之间交流、协作,并作为工作成果原始根据,并且在向潜在顾客传递软件功能、性能需求,使其可以判断该软件与否与自己需求有关。
3.1 编写目
为开发人员,维护人员,客户之间提供共同合同而创立基本,对本画图板软件功能实现做一全面描述;
本阐明书预期读者为客户、业务或需求分析人员、测试人员、文档编写者、项目管理人员;
3.2 任务概述
本软件攻打学习、研究之用,目的是让使用该软件顾客感觉可以轻松掌握本软件各个功能模块。为了以便顾客使用,本软件在设计时尽量追求可操作性和简洁大方人机交互界面设计,力求尽量减少顾客直接输入性东西,大量使用可选框。
3.3 功能概述
通过各方面理解,本软件初步设计功能为:
1. 新建一种空白图形文献:用于绘制新图形。
2. 打开或保存一种图形文献,便于对图形文献管理。
3. 绘制某些基本图形组件:直线,矩形,实心矩形,椭圆,实心椭圆,圆,实心圆,圆角矩形,实心圆角矩形等。
4. 用鼠标在绘图板上单击拖动进行随笔花。
5. 橡皮擦:可以将已绘制图形擦掉。
6. 添加文字:可以在绘图区域内添加文字。
7. 选取文字字体:通过一种下拉式选取条,可以选中所需要字体。本程序中涉及:宋体,隶书,华文彩云,仿宋-GB2312,华文行楷,Times New Roman,Serif,Monospaced,SonsSerif,Garamond。固然,在下面程序分析中可以看到,由于设立了字体选取数组,使得可以随意添加系统支持任何字体。大大以便和简化了程序设计。
8. 选取文字字体风格:通过两个复选框按钮,可以选取需要字体风格,涉及:粗体,斜体,用同步选中两者,只选取其中一种或两者都不选中3种选取方式。
9. 设立画笔颜色:可以选取当前绘制图形画笔颜色,让图形更加丰富多彩,生动活泼。
10. 设立画笔粗细:该选项在作用于基本图形组件和文字时,它效果是不同。当作用于绘制图形组建时,它作用是变化画笔绘制线条粗细;当作用于文字时,它作用是变化文字大小。
由此可以看出,虽然这个画图板程序不如那些专业绘图程序,但是,“麻雀虽小五脏俱全”,它已经具备了一种绘图软件所应当有基本功能和操作。
3.4 功能构造图
图3-1 软件功能层次图
3.5 用例图
用例图
4、总体设计报告
4.1 编写目
总体设计目就是回答“概括说,系统该如何实现?”这个问题,也就是说这个阐明书编写目就是告诉程序员和软件设计人员本软件系统构造和软件构造。
4.2 本软件系统层次构造图
图3-1 是该软件系统层次构造图。
4.3 基本图形按钮
基本图形按钮涉及:Pencil(随笔画)、Line(直线)、Rect(矩形)、fRect(实心矩形)、Oval(椭圆)、fOval(实心椭圆)、Circle(圆)、fCircle(实心圆)、RoundRect(圆角矩形)、frrect(实心圆角矩形)、Rubber(橡皮擦)、Word(字)。
基本图形都继承自同一种父类:drawings。Drawings具备变量(属性):
int x1,y1,x2,y2; //用来存储相应图形元素左边
int R,G,B; //用来存储图形色彩信息
float stroke; //用来存储画笔粗细
int type; //用来保存图形类型
string s1; //用来保存输入文字字符串
string s2; //用来保存字体类型字符串
同步,drawings尚有办法:
Void draw(Graphics2D g2d) {};
draw()办法中用到了java绘图里面Graphics2D类,所有继承drawings类图形子类都重写此办法。这就是Java中类继承概念。
4.4 基本操作按钮
1. New:新建一种图形文献。
2. Open:打开一种图形文献。
3. Save:保存当前图形文献。
4.5 菜单条及其构成
1. File菜单项,涉及:New(新建一种图形文献)、Load(打开一种图形文献)、Save(保存一种图形文献)、Exit(退出程序)。
2. Color菜单项:用来设立当前颜色。
3. Stroke菜单项:用来设立当前画笔粗细。
4. Help菜单项:关于程序协助提示。
4.6 其她功能构成
1. 选取颜色和设立当前画笔粗细按钮分别为:Color、Stroke。
2. 选取当前字体风格选取框为:BOLD、ITALIC,用以设立当前字体风格。
3. 选取当前字体下来是复选框为:Styles。
4.7 完毕程序界面效果为:
图4-1 完毕程序界面效果图
5、详细设计报告
5.1 编写目
详细设计阶段主线目是拟定应当怎么详细地实现所规定系统,也就是说,通过这个阶段设计工作,应当得出对目的系统精准描述,从而在编码阶段可以把这个描述直接翻译成用某种设计语言书写程序。本阐明书是为了给程序员提供出一种程序“蓝图”,指引她们更好地完毕编码任务。
本阐明书读者是:软件设计师、所有参加这个项目编码人员和测试人员。
5.2 新建一种图形文献
单击工具栏上图标,或选取Fileà New菜单,则清除当前所绘制图像,回到初始画面,如图4-1所示。
5.3 打开已有文献
单击工具栏上图标,或选取FileàLoad菜单,则清除当前所绘制图像,并弹出打开文献对话框规定选取打开文献,如图5-1所示。
图5-1 选取打开文献对话框
5.4 保存
单击工具栏上图标,或者选取FileàSave菜单,则弹出规定保存文献对话框,如图5-2所示。
图5-2 保存文献对话框
5.5 绘制基本图形
基本图形涉及:
1. Pencil:随笔画,图标为。
2. Line:直线,图标为。
3. Rect:矩形,图标为。
4. fRect:实心矩形,图标为。
5. Oval:椭圆,图标为。
6. fOval:实心椭圆,图标为。
7. Circle:圆,图标为。
8. Fcircle:实心圆,图标为。
9. RoundRect:圆角矩形,图标为。
10. frRect:实心圆角矩形,图标为。
11. Rubber:橡皮擦,图标为。
画图时,单击工具栏上相应图形图标,然后用鼠标拖动,在绘图区域内进行绘画即可。
5.6 设立画笔大小
单击工具栏上图标,或者单击StrokeàSet Stroke菜单,则弹出相应设立当前画笔粗细对话框,如图5-3所示。
图5-3 设立当前画笔粗细对话框
5.7 选取颜色
单击工具栏上图标,或单击ColoràChoose Color菜单,则弹出相应选取当前画图颜色对话框,如图5-4所示。
图5-4 选取颜色对话框
5.8 选取字体风格
在工具栏区域,可以选取相应字体风格,有粗体和斜体两种风格可供选取。
5.9选取字体
在工具栏区域,可以选取字体,本程序中有如下几种字体可供选取:宋体,隶书,华文彩云,仿宋-GB2312,华文行楷,Times New Roman,Serif,Monospaced,SonsSerif,Garamond。
5.10 程序构造阐明
本程序主体文献为一种文献:MiniDrawPad.Java。其中涉及程序段有:
1. MiniDrawPad():构造函数,用以初始化。
2. chooseColor():选取当前绘图颜色程序段。
3. setStroke():设立当前画笔粗细程序段。
4. loadFile():调用图形文献程序段。
5. newFile():新建一种图形文献程序段。
6. saveFile():保存当前所绘制图形程序段。
7. createNewItem():新建一种基本图形单元程序段。
相应内部类有:
1. ButtonHandler:用来解决基本图形单元按钮事件。
2. ButtonHandler1:用来解决New、Open、Save三个操作按钮按钮事件。
3. DrawPanel:用老创立绘图区域子类。
4. MouseA:继承了MouseAdapter,用来完毕鼠标相应事件操作,如单击、松开、进入和离开等。
5. MouseB:继承了MouseMotionAdapter,用来完毕鼠标拖动和鼠标移动时相应操作。
6、系统实现报告
6.1 开发环境
CPU:Intel Core(TM)2 E5300 内存:2G
运营平台:Windows XP 主频:2.60GHz
开发平台:Eclipse 主板:ASUSTeK Computer INC. P5QL-ASUS-SE
6.2 核心技术
本软件核心技术有主窗体设计、菜单栏和工具栏设计、事件响应解决、画图基本功能实现。
6.3 运营成果
1. 主界面框架
主界面类继承自JFrame类,涉及构造函数及各种功能定义,重要代码如下 :
import java.awt.*;
import java.awt.geom.*;
import java.awt.event.*;
import javax.swing.*;
import java.io.*;
import java.util.*;
public class MiniDrawPad extends JFrame //主类,扩展了JFrame类,用来生成主界面
{
private ObjectInputStream input;
private ObjectOutputStream output;//定义输入输出流,用来调用和保存图像文献
private JButton choices[]; //按钮数组,存储如下名称功能按钮
private String names[]={
"New",
"Open",
"Save", //这三个是基本操作按钮,涉及"新建"、"打开"、"保存"
"Pencil", //铅笔画,也就是用鼠标拖动着随意绘图
"Line", //绘制直线
"Rect", //绘制空心矩形
"fRect", //绘制以指定颜色填充实心矩形
"Oval", //绘制空心椭圆
"fOval", //绘制以指定颜色填充实心椭圆
"Circle", //绘制圆形
"fCircle", //绘制以指定颜色填充实心圆形
"RoundRect", //绘制空心圆角矩形
"frRect", //绘制以指定颜色填充实心圆角矩形
"Rubber", //橡皮擦,可用来擦去已经绘制好图案
"Color", //选取颜色按钮,可用来选取需要颜色
"Stroke", //选取线条粗细按钮,输入需要数值可以实现绘图线条粗细变化
"Word" //输入文字按钮,可以在绘图板上实现文字输入
};
private String styleNames[]={
" 宋体 " ," 隶书 " ," 华文彩云 " ," 仿宋_GB2312 " ," 华文行楷 " ,
" 方正舒体 " ," Times New Roman " ," Serif " ," Monospaced " ," SonsSerif " ," Garamond "
}; //可供选取字体项
private Icon items[];
private String tipText[]={
//这里是鼠标移动到相应按钮上面上停留时给出提示阐明条
"Draw a new picture",
"Open a saved picture",
"Save current drawing",
"Draw at will",
"Draw a straight line",
"Draw a rectangle",
"Fill a ractangle",
"Draw an oval",
"Fill an oval",
"Draw a circle",
"Fill a circle",
"Draw a round rectangle",
"Fill a round rectangle",
"Erase at will",
"Choose current drawing color",
"Set current drawing stroke",
"Write down what u want"
};
JToolBar buttonPanel ; //定义按钮面板
private JLabel statusBar; //显示鼠标状态提示条
private DrawPanel drawingArea; //画图区域
private int width=800,height=550; //定义画图区域初始大小
drawings[] itemList=new drawings[5000];//用来存储基本图形数组
private int currentChoice=3; //设立默认画图状态为随笔画
int index=0; //当前已经绘制图形数目
private Color color=Color.black; //当前画笔颜色
int R,G,B; //用来存储当前色彩值
int f1,f2; //用来存储当前字体风格
String style1; //用来存储当前字体
private float stroke=1.0f; //设立画笔粗细,默认值为1.0f
JCheckBox bold,italic; //定义字体风格选取框
//bold为粗体,italic为斜体,两者可以同步使用
JComboBox styles;
public MiniDrawPad() //构造函数
{
super("Drawing Pad");
JMenuBar bar=new JMenuBar(); //定义菜单条
JMenu fileMenu=new JMenu("File");
fileMenu.setMnemonic('F');
2. 新建、保存、打开、退出菜单项
代码如下:
//新建文献菜单条
JMenuItem newItem=new JMenuItem("New");
newItem.setMnemonic('N');
newItem.addActionListener(
new ActionListener(){
public void actionPerformed(ActionEvent e)
{
newFile(); //如果被触发,则调用新建文献函数段
}
}
);
fileMenu.add(newItem);
//保存文献菜单项
JMenuItem saveItem=new JMenuItem("Save");
saveItem.setMnemonic('S');
saveItem.addActionListener(
new ActionListener(){
public void actionPerformed(ActionEvent e)
{
saveFile(); //如果被触发,则调用保存文献函数段
}
}
);
fileMenu.add(saveItem);
//打开文献菜单项
JMenuItem loadItem=new JMenuItem("Load");
loadItem.setMnemonic('L');
loadItem.addActionListener(
new ActionListener(){
public void actionPerformed(ActionEvent e)
{
loadFile(); //如果被触发,则调用打开文献函数段
}
}
);
fileMenu.add(loadItem);
fileMenu.addSeparator();
//退出菜单项
JMenuItem exitItem=new JMenuItem("Exit");
exitItem.setMnemonic('X');
exitItem.addActionListener(
new ActionListener(){
public void actionPerformed(ActionEvent e)
{
System.exit(0); //如果被触发,则退出画图板程序
}
}
);
fileMenu.add(exitItem);
bar.add(fileMenu);
3. 线条宽度、颜色、提示功能
代码如下:
//设立颜色菜单条
JMenu colorMenu=new JMenu("Color");
colorMenu.setMnemonic('C');
//选取颜色菜单项
JMenuItem colorItem=new JMenuItem("Choose Color");
colorItem.setMnemonic('O');
colorItem.addActionListener(
new ActionListener(){
public void actionPerformed(ActionEvent e)
{
chooseColor(); //如果被触发,则调用选取颜色函数段
}
}
);
colorMenu.add(colorItem);
bar.add(colorMenu);
//设立线条粗细菜单条
JMenu strokeMenu=new JMenu("Stroke");
strokeMenu.setMnemonic('S');
//设立线条粗细菜单项
JMenuItem strokeItem=new JMenuItem("Set Stroke");
strokeItem.setMnemonic('K');
strokeItem.addActionListener(
new ActionListener(){
public void actionPerformed(ActionEvent e)
{
setStroke();
}
}
);
strokeMenu.add(strokeItem);
bar.add(strokeMenu);
//设立提示菜单条
JMenu helpMenu=new JMenu("Help");
helpMenu.setMnemonic('H');
//设立提示菜单项
JMenuItem aboutItem=new JMenuItem("About this Drawing Pad!");
aboutItem.setMnemonic('A');
aboutItem.addActionListener(
new ActionListener(){
public void actionPerformed(ActionEvent e)
{
JOptionPane.showMessageDialog(null,
"This is a mini drawing pad!\nBy Jian Yongkang "," 画图板程序阐明 ",JOptionPane.INFORMATION_MESSAGE );
}
}
);
helpMenu.add(aboutItem);
bar.add(helpMenu);
items=new ImageIcon[names.length];
4. 工具栏图形按钮功能实现
创立基本图形按钮、导入图标、加入动作侦听器、字体风格选取、字体选取、画图板等功能实现。
代码如下:
//创立各种基本图形按钮
drawingArea=new DrawPanel();
choices=new JButton[names.length];
buttonPanel = new JToolBar( JToolBar.VERTICAL ) ;
buttonPanel = new JToolBar( JToolBar.HORIZONTAL) ;
ButtonHandler handler=new ButtonHandler();
ButtonHandler1 handler1=new ButtonHandler1();
//导入图形图标,这些图标都存储在与源文献相似目录下面
for(int i=0;i<choices.length;i++)
{
items[i]=new ImageIcon(names[i] + ".jpg");
choices[i]=new JButton("",items[i]);
choices[i].setToolTipText(tipText[i]);
buttonPanel.add(choices[i]);
}
//将动作侦听器加入按钮里面
for(int i=3;i<choices.length-3;i++)
{
choices[i].addActionListener(handler);
}
choices[0].addActionListener(
new ActionListener(){
public void actionPerformed(ActionEvent e)
{
newFile();
}
}
);
choices[1].addActionListener(
new ActionListener(){
public void actionPerformed(ActionEvent e)
{
loadFile();
}
}
);
choices[2].addActionListener(
new ActionListener(){
public void actionPerformed(ActionEvent e)
{
saveFile();
}
}
);
choices[choices.length-3].addActionListener(handler1);
choices[choices.length-2].addActionListener(handler1);
choices[choices.length-1].addActionListener(handler1);
//字体风格选取
styles=new JComboBox(styleNames);
styles.setMaximumRowCount(8);
styles.addItemListener(
new ItemListener(){
public void itemStateChanged(ItemEvent e)
{
style1=styleNames[styles.getSelectedIndex()];
}
}
);
//字体选取
bold=new JCheckBox("BOLD");
italic=new JCheckBox("ITALIC");
checkBoxHandler cHandler=new checkBoxHandler();
bold.addItemListener(cHandler);
italic.addItemListener(cHandler);
JPanel wordPanel=new JPanel();
buttonPanel.add(bold);
buttonPanel.add(italic);
buttonPanel.add(styles);
styles.setMinimumSize( new Dimension ( 50,20 ) );
styles.setMaximumSize(new Dimension ( 100,20 ) );
Container c=getContentPane();
super.setJMenuBar( bar );
c.add(buttonPanel,BorderLayout.NORTH);
c.add(drawingArea,BorderLayout.CENTER);
statusBar=new JLabel();
c.add(statusBar,BorderLayout.SOUTH);
statusBar.setText(" Welcome To The Little Drawing Pad!!! :)");
createNewItem();
setSize(width,height);
show();
}
//按钮侦听器ButtonHanler类,内部类,用来侦听基本按钮操作
public class ButtonHandler implements ActionListener
{
public void actionPerformed(ActionEvent e)
{
for(int j=3;j<choices.length-3;j++)
{
if(e.getSource()==choices[j])
{currentChoice=j;
createNewItem();
repaint();}
}
}
}
//按钮侦听器ButtonHanler1类,用来侦听颜色选取、画笔粗细设立、文字输入按钮操作
public class ButtonHandler1 implements ActionListener
{
public void actionPerformed(ActionEvent e)
{
if(e.getSource()==choices[choices.length-3])
{chooseColor();}
if(e.getSource()==choices[choices.length-2])
{setStroke();}
if(
展开阅读全文