终于弄好了 homework-09
近一周的时间,顶着编译大作业严重搁置的压力,天天搞,终于把网页动态展示的搞出来了!恩,还挺好看~
因为是最后一次作业了,也是因为天生的完美主义强迫症,做到自己满意才放心停下来。不过,这个过程,看着同学都去测试编译了,我才写了语法分析,真的是压力山大。现在做出来的心情,就是从战场活下来的轻松与兴奋 T^T
闲话少叙,下面展示作品,希望大家喜欢。
网页发布在这个链接:happyjin.com/show/index.html
1. 外观设计及使用说明(一定亲自操作一下才能看到动画效果)
上方,Dynamic Show的标题以及网站主题的简介,采用扁平化风格,清晰干净的观感。因为页面太长,我在这里剪短一下。下面的就是控制和展示部分。
界面具体介绍如下:
1. 控制部分,分为 Mode, Input 和 Control三部分。用户在前两部分指定模式和输入,在最后一个部分操作展示控制,逻辑清晰。
2. 这里面展示普通,水平及竖直联通,轮胎装联通4种模式。因为/A模式采用的是退火算法,这种随机化的过程不仅步骤太多,也没有什么算法逻辑可讲,故不适合这样的动态展示。
3. 输入支持随机化自动输入(需要填写一个维度),和文件读取。但是,文件读取只兼容经过权限设置的某些版本的IE,故意义不大,这里只进行到读取文件并弹窗的状态,展示一下ActiveXObject的应用技术好了。
4. 控制部分有自动跳步开关(动画切换),还有恰好被设计在一起的前后跳步按钮。开始计算后即可方便的导航。
5. Output下面黄色区域初始显示“Current Sum”,演示开始后便动态显示当前的子数组和。
6. 下方的表格显示扫描过程。表格在开始之前是不存在的,重新开始也会重新绘制。绿色部分,是当前算法聚焦的部分。这个算法就是考虑到,新增一个元素到数组末尾,那新的最大子数组要么不变,要么以新元素结尾。绿色展示了根据新增元素的想法进行扫描的过程。在绿色部分之内,算法用动态规划利用中间变量迅速求需要部分的部分和。
然而,不是每个扫描到的区域都被选中保留,因为算法是对比取优的,那么黄色的部分就显示我们保留的部分的和。当黄色区域的值变化,用户就知道当前的绿色区域被选中了。这样要比黄色区域显示绿色区域的和要更有意义,因为用户其实并不会去算部分和,只要知道什么时候更新选区就可以了,用户关心的是算法的聚焦目标的变化,这也是不好理解,需要展示的部分。
细心的设计:
1. 当用户选择自动输入或文件输入时,相应的输入框会有变化,巧妙提示用户该输入哪里;另一个输入框被禁用,避免了误输入。比如,当我们选择随机产生数值,那文件路径的输入框就不可编辑。
2. 考虑到很多用户只需要理解一下算法,那我们就设置了默认选项,这使得用户只需要输入一个维度,然后按一下最醒目的按钮“Let's Go!!!”,就可以自动逐步显示,非常方便。
3. 在运行过程中,可以随意换输入重开始,可以随时开关自动跳步,可以在自动跳步的同时前进和后退。
2. 技术实现
1. 我在W3School上学习了html, javascript, jquery三个课程,并读了bootstrap框架的一些代码。随后,选择了Flat-UI这个框架,读懂了其代码,并用Flat-UI实现了主页html文件。
2. 我编写了js/shonejin.js这个文件,里面包含调度动态效果的事件处理函数,以及算法展示的各种函数。
3. 代码质量
第一次写javascript,代码质量其实和C++要求是不太一样的。
1. 代码风格上,变量命名采用骆驼命名法,函数首字母大写。空间上,有整齐的缩进,保证可读性强。当然,实际发布的js文件为了传输迅速,是把空白符号全去掉的。
2. 注释:首先,变量和函数名已经力求有一定的自解释性能(如上图),其次,各个变量均有言简意赅的注释,每个函数有注释,说明其使用场景和作用,以及必要的参数说明。
对于难以理解的算法,在程序之中也有必要注释。
3. 结构:首先,相关函数划分到本js文件中是科学的,还有一些其他的控件效果函数,直接到框架包里面修改了。
其次,函数的划分按照其相应不同DOM实践的逻辑划分,给理解和修改带来便利,也方便html文档中写其onclick等函数。这些函数,要尽量少得耦合。
对于算法实现的函数,因为算法就是不断使用归结法,那么函数之间的重用性很高,显得很简洁清晰。
3. 单元测试:用Qunit这个框架测试了自己写的js,效果是这样的:
但是,这种测试更适合测最小子数组的部分函数,而DOM事件处理的函数无参数无返回值,我选择使用Chrome或Safari浏览器的控制台调试,不仅能看到错误,还能看到其错误的行数。
例如下面的截图:
4. 屏幕录制
我的两篇博客:http://www.cnblogs.com/shone/p/3330268.html, http://www.cnblogs.com/shone/p/3348372.html
分别从一维子数组、二维子数组介绍了动态规划,那里面介绍的非常详细,便不在此处赘述。为了更加形象的展示算法的执行过程,
我使用LICEcap制作了gif动画。下面两个动画作为事例,分别是normal模式,和水平连接的拓展模式。我也会将gif更新到原来两篇博客里,方便大家学习。
水平连接模式:
Personal Software Process Stages |
时间百分比(%) |
实际花费的时间 (分钟) |
原来估计的时间 (分钟) |
|
Planning |
计划 |
|||
· Estimate |
· 估计这个任务需要多少时间,把工作细化并大致排序 |
10% | 10小时 | 10小时 |
Development |
开发 |
|||
· Analysis |
· 需求分析 (包括学习新技术) |
83% | 5小时 | 6小时 |
· Design Spec |
· 生成设计文档(博客) |
100% | 90 | 90 |
· Design Review |
· 设计复审 (和同事审核设计文档) |
100% | 30 | 30 |
· Coding Standard |
· 代码规范 (制定合适的规范) |
100% | 30 | 30 |
· Design |
· 具体设计 |
150% | 240 | 360 |
· Coding |
· 具体编码 |
100% | 8小时 | 8小时 |
· Code Review |
· 代码复审 |
100% | 30 | 30 |
· Test |
· 测试(自我测试,修改代码,提交修改) |
100% | 60 | 60 |
Reporting |
总结报告 |
|||
|
(博客) | |||
|
100% | 40 | 40 | |
Total | 总计 | 100% |
总用时 约15小时 |
总估计的用时 15小时
|
终于弄好了 homework-09的更多相关文章
- os.getcwd()、sys.path[0]、sys.argv[0]和__file__的区别,终于弄清楚了
os.getcwd().sys.path[0].sys.argv[0]和__file__的区别 要分清这几个的区别与使用条件,实际测试一下是最准确的. 设计测试方法: 一个主模块用来运行,一个子模块用 ...
- 【第一次玩Travis CI】终于弄好了我的马鸭
真是不容易,我都要哭了.熬了半天终于弄完了!! 终于可以坐这儿挺会小曲,写写感受了. 作为一个程序写的不咋滴的程序员,倒是特别喜欢写博客,也是绝了. 高三的时候,用OneNote,后来转到Lofter ...
- 我终于弄懂了Python的装饰器(一)
此系列文档: 1. 我终于弄懂了Python的装饰器(一) 2. 我终于弄懂了Python的装饰器(二) 3. 我终于弄懂了Python的装饰器(三) 4. 我终于弄懂了Python的装饰器(四) 一 ...
- 我终于弄懂了Python的装饰器(二)
此系列文档: 1. 我终于弄懂了Python的装饰器(一) 2. 我终于弄懂了Python的装饰器(二) 3. 我终于弄懂了Python的装饰器(三) 4. 我终于弄懂了Python的装饰器(四) 二 ...
- 我终于弄懂了Python的装饰器(四)
此系列文档: 1. 我终于弄懂了Python的装饰器(一) 2. 我终于弄懂了Python的装饰器(二) 3. 我终于弄懂了Python的装饰器(三) 4. 我终于弄懂了Python的装饰器(四) 四 ...
- [转]Hibernate与Jpa的关系,终于弄懂
原文地址:http://blog.sina.com.cn/s/blog_5f1619e80100yoxz.html 我知道Jpa是一种规范,而Hibernate是它的一种实现.除了Hibernate, ...
- Hibernate与Jpa的关系,终于弄懂
我知道Jpa是一种规范,而Hibernate是它的一种实现.除了Hibernate,还有EclipseLink(曾经的toplink),OpenJPA等可供选择,所以使用Jpa的一个好处是,可以更换实 ...
- 沙雕去死吧! 劳资终于弄好了toimcat9 apt和ssl配置
搜一下吧,要不就是不用apr模式,也不用nio模式,直接用bio模式跑的,麻烦问一下,您们都是傻屌吗? APR模式必须要用!!!!! 然后全他妈的用jks证书,然后再提取公钥*.cer,然后再转换为* ...
- 学习Python一年,这次终于弄懂了浅拷贝和深拷贝
官方文档:copy主题 源代码: Lib/copy.py 话说,网上已经有很多关于Python浅拷贝和深拷贝的文章了,不过好多文章看起来还是决定似懂非懂,所以决定用自己的理解来写出这样一篇文章. 当别 ...
随机推荐
- 经典K线组合图解 > 正文
日K线波段中上下影线的箱体操作法(完整) http://video.sina.com.cn/v/b/130809461-2486130757.html!!经典K线组合图解 > 正文 http:/ ...
- 在Ubuntu下安装imx6linux系统的交叉编译环境遇到的问题总结
这段时间一直忙于手上的嵌入式项目,可以说自己从嵌入式的菜鸟一点点的入门了,关于嵌入式和imx6核心板的开发有了一点的了解,尤其是对于板子环境的搭建.硬件的开发,搭建环境,是一个很大的工程量,也是很重要 ...
- 车牌识别LPR(一)-- 研究背景
在年尾用了几天的时间将2014年的所有工作都总结了一遍,将之前的文档综合了下. 以下是LPR系统,车牌识别的一些总结资料. 第一篇:LPR研究背景 汽车的出现改变了以往出行徒步和以马代步的时代,极大地 ...
- C Socket Programming for Linux with a Server and Client Example Code
Typically two processes communicate with each other on a single system through one of the following ...
- sql server 读取表结构
SELECT 表名 then d.name else '' end, 字段序号=a.colorder, 主键 FROM sysobjects where xtype='PK' and name in ...
- Nginx+Tomcat+Memcached 集群
写过一篇 Apache Httpd+Tomcat 的集群, 现在来看看Nginx+Tomcat+Memcached是怎么集群的. 先看看用的版本和工具: Nginx: nginx-1.8.1 Tomc ...
- mac 下php运行bug
如下所说bug在window下没有,在mac下存在. mac下的php报如下错误: fopen("data.json") Error: failed to open stream: ...
- trackr: An AngularJS app with a Java 8 backend – Part IV 实践篇
REST API对于前后端或后端与后端之间通讯是一个好的接口,而单页应用Single Page Applications (SPA)非常流行. 我们依然以trackr为案例,这是一个跟踪工作时间 请假 ...
- Smack IQ包的扩展
前几天一直很烦躁,怎么扩展smack的IQ包堵了我好久,今天静下心来看了下smack的源码,把这个问题解决了.下面给出步骤: 如果我们要扩展一个如下所示的IQ包: <iq id="00 ...
- Spring MVC 的请求参数获取的几种方法
通过@PathVariabl注解获取路径中传递参数 @RequestMapping(value = "/{id}/{str}") public ModelAndView hello ...