个人毕业设计基于python开发的图像(共20页).doc
《个人毕业设计基于python开发的图像(共20页).doc》由会员分享,可在线阅读,更多相关《个人毕业设计基于python开发的图像(共20页).doc(21页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上河北大学工商学院装订线 本科生毕业论文(设计) 题目:基于python开发的图像 采集器之Airppt 学 部 学科门类 专 业 基于python开发的图像采集器之Airppt摘要装订线 本文设计了一个基于python开发的图像采集器,该设计通过普通的USB数字摄像头来捕捉和获取实时图像,利用linux系统下的python脚本中的Opencv图像处理模块和Huigui摄像头识别模块实现了采集图像信息并对图像信息进行分析的功能,该设计具有可靠性高、灵活稳定、低成本的特点,基于python开发的图像采集器将采集到的数据输入到python脚本进行分析处理,并从外部引入C编程
2、,根据不同的处理结果,系统将会调用不同的C程序,从而实现对ppt的翻页。本文系统介绍了用python开发的图像采集器基本满足设计要求。关键词:图像采集器;Python语言;Python C扩展;混合语言编程专心-专注-专业Development the image acquisition based on pythonABSTRACT Design one based on python development of image capture device, the design by ordinary USB digital camera head to capture and acces
3、s to real-time image using python script in linux system Opencv image processing module and Huigui camera head identification module to achieve the capture image informationand image information analysis function, the design has high reliability, flexible and stable, low-cost, will be collected base
4、d on the the python development of image acquisition data input to a python script analysis and processing, from the outside to the introduction of the C programming, depending on the processing results, the system will call the C program, in order to achieve the next page of ppt. We introduce the b
5、asic meet the design requirements with the the python development of image acquisition. Key words:Image acquisition;Python;Python C extension;Mixed-language programming目录 2. 2Python语言特性 4 3设计思路和编程5 3.1设计思路 5 3.2设计流程图 5 3.3编程 6 3.3.1Opencv模块引用 6 3.3.2Highgui模块引用 6 3.3.3Image模块引用 6 3.3.4Os模块引用 6 3.4py
6、thon与C混合编程接口问题 6 5341 引 言信息和网络技术的飞速发展, 使得图像信息量激增,人们对检索图像信息的需求也日益增加。作为一种纯面向对象的动态脚本语言, python 已经在网络应用软件、系统配置软件及科学研究领域获得了广泛的使用,因此本文介绍了一种基于Python的利用Linux平台下Python与C+/C+语言的两种Os.systeam接口, 实现了python与VC的混合语言编程,并将这种软件结构应用于一套图像采集器系统。实际应用表明, 这种结构可以充分发挥Python编程的灵活简单和VC执行效率高的优点, 克服Python执行效率低和VC开发效率低的缺点,实现了软件开发
7、效率和执行效率的双赢。当今社会,科技发达成长了人们的懒惰性,利用各种机器设备做家务,利用远程监控来遥控远在千里之外的东西,总之一切事务趋于自动化。图像采集器(Image acquisition),是指通过摄像头采集图像信息,批量获取图像信息,能够根据图像信息获取到物体运动的位移和执行的动作,这样采集到的图像信息分析更加的准确,可靠性更强。本文设计了一种不用点击鼠标,不用按下键盘,只需要轻轻的挥挥手就可以操纵PPT的翻页的软件-Airppt, 解决了以往操作PPT的繁琐性,满足了人们对方便快捷生活的向往,并且提升了宣讲效率。有了airppt,老师上课讲课就不用总在电脑旁用鼠标控制ppt,这样就加
8、大了老师与学生的互动性。 Airppt利用的原理就是图像采集器,它在国内外应用广泛,并且发展迅速,在国外它应用于军事,医疗,监控等领域。在国内还没有太多的应用,据目前了解到的在国内一般应用于监控的比较多,还有运用于娱乐的,通过采集器将用户的身形采集到屏幕中并且可以采集到你的动作与里面的事物发生互动。本文通过对模块应用环境及功能的认证,确定了应用opencv模块处理图像,huigui模块来识别并调用摄像头采集信息,image模块处理采集到的图像大小等,os模块引入外部C扩展,在利用python代码将这些功能连接起来,最终实现了airppt的相关协议所设定的功能。本文主要研究内容如下:(1) op
9、encv模块的安装调用及作用;(2) Image模块的用法安装;(3) Huigui模块的用法及调用;(4) Python外部C扩展的引入; 本设计采用python程序编写,硬件只需一个外置摄像头作为采集信息的工具。2 Python语言介绍2.1 Python语言简介 Python是一种解释型、交互式、纯面向对象的脚本程序设计语言,它结合了多种不同语言最经典的设计原则和思想。自1990年Guido van Rossum 发明Python以来,它的简单、清晰和优雅吸引了广泛的关注,Python 社区以每两年翻番的速度迅速扩张。例如:Python自google创建之初就是其主要网络应用开发工具;美
10、国国家航空航天局使用Python开发CAD/CAE/PDM资源库, 在此基础上建设新一代协作式工程环境NGCEE(Next Generation Collaborative Engineering Environment);美国国家研究推进机构CNRI(Corporation for National Research Initiatives )1999年启动的Computer Programming for Everybody(C4PE)计划将Python作为未来程序设计语言向教育机构推广; Microsoft于2005年推出Iron Python 的开源项目, 在Visual Studio
11、 2005 中接纳Python语言作为唯一动态脚本语言开发.net应用程序16。2.2 Python语言特性 相比其他任何程序设计语言, Python允许软件设计者更关注于问题本身而不是实现细节, 其主要特性有: (l) 面向对象 Python 是一种纯面向对象语言, 支持面向对象的所有机制, 这使它可以应用于大型软件项目开发。 (2) 虚拟机机制 Python代码编译为字节码在虚拟机上执行,这种类似Java的机制使Python具有平台无关性, 并获得比其他脚本语言更快的执行效率。 (3) 内置高级数据类型 Python中的元组、列表、数组、字典等高级数据类型具有极强的表达能力, 几乎任意复杂
12、的对象在Python中均可以以最简单的方式进行描述。 (4) 交互式开发方式和单元测试 类似Foxpro 和 Matlab ,Python 提供了内置交互式窗口, 可以允许开发者边尝试边书写代码, 极大地提高了软件开发效率。另外单元测试机制在每个类代码完成后均可以单独执行、测试。这两种开发方式使得”搭积木” 式的软件开发过程成为现实。 (5) 动态执行特性 类似早期Dbase系统的宏代替、Python允许动态构造程序代码并执行, 使得软件中的重复代码得到简化。 (6) 高度可扩展性Python 语言本身只实现了一个小内核,其强大功能体现在大量的扩展模块。计算机科学领域几乎所有的已知算法均可找到
13、Python语言扩展。不仅c / c + + 编写的程序可以方便地改写成Python扩展模块,而且Python自身也可以被嵌人到口C/C+项目中。 (7) 平台无关性Python字节码可以不经修改跨平台运行在所有主流操作系统上, 甚至包括Pocket PC 、Palm等嵌入式系统1。 3 设计思路和编程3.1 设计思路 本文的设计思路是: (1).编辑器的选择:python固定的编辑器是vim编辑器,这个编辑器很容易实现脚本的创建保存和运行,能大大提高程序员的编程速度,它还有一个非常强大的功能,在电脑发生意外突然关机的情况下,这个编辑器就会自动保存你之前你没有保存的程序。这样就不会丢失有用的信
14、息 (2).图像坐标的产生:设计中采用的是判断红点的个数,红点指定义的一个红色RGB色调,当我们动作时就会采集到红点动作的个数,通过判断红点的个数,来判断鼠标是否要动作,通过动作的位移来判断鼠标动作的方向。 (3).图像的处理:图像的处理是用Image模块处理的,可改变图像的大小,像素等,这样就可以把采集到的图像信息处理成所需要的。 (4).摄像头接口的处理:这里用的是Opencv模块来实现图像的坐标的采集,opencv的设计意图是为用户提供简单易用的图形用户接口。 (5).动作的反馈:当你用手在摄像头前挥动时,该动作就会被程序所识别,然后发出相应的相应。 (6).功能的设定:这些功能是由C语
15、言写的,然后引入os模块,通过os模块将写好的C功能引入到脚本语言中去。然后再用判断语句,当程序符合哪种条件是就会执行哪些C功能。2软件编程思想本文的软件编程思想是:摄像头要采集手指运动的图像,来判断执行什么样的动作,那么摄像头怎么样才能识别你的手指呢?本文在这里是用颜色(R,G,B)来解决的,本设计把手指用(R,G,B)定义成红点,现在红点就代表手指,应用指令控制摄像头来采集红点。这是本设计的第一步打算。第二步,需要采集的目标已经确定,接下来就是判断红点的运动方向和位移,我这里是通过判断红点运动的方向来确定对airppt执行什么样的动作;通过红点的位移和个数来确定airppt是否要执行该动作
16、,本设计在这里定义的是位移大于70mm,红点个数大于20个时airppt才会执行相应的动作。因为动画都是由一张张图片组成的,假如不判断位移,当你不动作时它也会自动采集红点,进而发生动作反应,这样就出错了。这里的中心思想就是if判断语句,事件处理系统和for循环语句。3.2 设计流程图 本文定义的参照物是一个用代码编写的RGB红点。并且分析每张图片的红点数,当红点数达到70个时将该图片列为有效图片,否则无效。 有效图片 无效图片抛弃红点数目是否大于70判断图像中红点数目通过摄像头采集图片 遍历该图片中每个坐标点 开始NY 图 3-1 设计全局架构结构图 图3-1是本设计的全局架构结构图,是本设计
17、得以实现的最重要部分,对获取到的图片分析是否有效,接下来则是细节部分,分析两张最近的有效图片中心点位置来判断左翻页还是右翻页还是不翻页。 位移的正负有效动作,ppt动作 开始 找到有效图片中所有红点坐标的中心坐标 对比两张最近的有效图片中心坐标 得到两次对比的位移大小位移大小是否大于5cm无效动作,ppt不动作NY左翻页右翻页负正 图3-2 有效图片筛选架构图 图3-2实现的是对有效图片进行分析,通过判断最近两张有效图片的中心位置点的位置关系来决定ppt是否执行动作,执行动作时是左翻页还是右翻页等一系列功能。完成这一步所需的程序如下:if len(list2)20: #如果列表中坐标个数大于2
18、0个 if len(list2) 20:tn3=list2-10-list200 #将横坐标的长度赋值给tn3 tn4=list2-11-list201 #将纵坐标的长度赋值给tn4while len(list2)3: #list2.pop(0)#print .,tn3#print tn4if tn450 and tn3-50 and tn350:os.system(./a.x 71)if tn4-50 and tn350:os.system(./a.x 9)if tn3100:os.system(./a.x 113)#print left#time.sleep(0.8) 每次判断完一张图片后
19、,就把列表中的红点数目与坐标等都删除。这样就不会对下一张图片造成影响。3.3 编程 在开始编程之前要先确定编程工具,本设计用的是vim编辑器。这个编辑器的最大优势就是,在意外情况下可以自动保存代码。当代码错误时,会提示错误信息,能够及时进行修改。以下是本设计的部分代码:#!/usr/bin/python这是解释python语言在电脑中的位置#-*- coding: UTF-8 -*-这是python脚本中的中文解释器3.3.1opencv模块import opencv从外部引入opencv模块本设计用到的opencv代码如下:cam=highgui.cvCreateCameraCapture(
20、0) #定义摄像头端口位置tn1=opencv.adaptors.Ipl2PIL(im) #采集到的图像定义为tn1OpenCV的全称是Open Source Computer Vision Library,是一个跨平台的库。OpenCV是由发起并参与开发,以授权发行,可以在商业和研究领域中免费使用。OpenCV可用于开发对实时的、以及程序。OpenCV用语言编写,它的主要接口也是C+语言,但是依然保留了大量的接口。该库也有大量的, and /的接口。这些语言的API接口函数可以通过在线文档获得。现在也提供对于,的支持。安装Opencv所需的依赖工具:cmake, gtk+*, ffmpeg*
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 个人 毕业设计 基于 python 开发 图像 20
限制150内