|
<table class=ubb cellspacing=0><TR><td class=ubb>LED 显示摇棒全套方案及源程序</td></TR><TR><td class=ubb>发布者:</td><td class=ubb>匿名</td><td class=ubb>点击次数:</td><td class=ubb>53</td><td class=ubb>发布时间:</td><td class=ubb>2008-4-20</td></TR><TR><td class=ubb> </td></TR><TR><td class=ubb><br />情人节我们做电的兄弟们送什么礼物给心仪已久的MM?在离情人节还有一个月的时间,给大家提供一个适合作为礼物的简单电路,自己动手做的漂亮玩具一定会是送给MM的最好的礼物。<br />显示效果图片: <br /><img src="http://www.bluepw.com/htmanage/ljf_WebEditor/UploadFile/2007111617429567.jpg"><br />以下是详细说明:<br /> 图形显示的原理:<br /><img src="http://www.bluepw.com/htmanage/ljf_WebEditor/UploadFile/20071116165847530.jpg"><br /> 利用人眼的视觉暂留效应,使手在摆动到不同位置的时候,让位于一条直线上的LED显示二维图像的不同的列,实现图形扫描显示。<br />物理机制:<br /> 当我们在摆动手臂的时候,短时间内摆动位置和左右幅度不会有太大变化,利用我们手臂的这个运动规律,只要能得到棒从一侧摆动到另一侧的时间,然后把这个时间分成N份,然后在每一份的时间里显示不同的花样就能实现图形的显示。当我们在摆动手臂的时候,并不能预先得知此次摆动需要的时间,怎样得到从一侧摆动到另一侧的时间呢?再想想,短时间内我们手臂的摆动频率也不会有特别大的变化,我们只要能得到前一次摆动所用的时间,然后用这个时间近似得到下一次摆动所需要的时间,然后分N 份就可以了。得到一次摆动所需的时间的任务由光遮断器完成,在棒上装一个可以摆动的用来遮挡光遮断器光线的细杆,粗细比光遮断器的狭缝稍宽,我用的是整流桥焊后剪下的一段管脚。每左右摆动一次这个杆就会通过一次光遮断器,使单片机产生一次中断,两次中断之间的时间就是想要得到的时间,实现这个功能用掉2051 的一个定时器T0 和外部中断INT0。然后用2051 的另一个定时器T1,其定时时间是T0 的N 分之一,每次中断依次显示一列,就是照片上的效果。<br /> 再细想一下,手臂摆动的频率大于2Hz 的时候才大概能由视觉暂留看出图形,再快也不过十几Hz,由T0 为16 位定时器的最长计时时间得到2051 的时钟频率1MHz 最合适,还有遮挡用的细杆的粗细也可以大概估算,使其不会对计时精度产生太大影响。<br />所用元件:<br />AT89C2051 8 元<br />高亮LED 共8 个 3.6 元<br />电池盒 0.5 元<br />单面万用板 8 元 可以裁成3 块,做3 个摇棒<br />陶瓷谐振器 1 元<br />光遮断器 2 元<br />电阻电容导线 2 元<br />外壳* 0.7 元 可以裁成2 块<br />可选元件:<br />电源开关 1 元<br />总成本不超过20 元<br />*外壳我用在家乐福买的半透明文件夹卷成的<br /> 此电路电路非常简单,代码短,但是用到了2051 的外部中断编程和T0、T1 定时器编程,非常适合初学者练习。我制作这个玩具花费了两个晚上的时间。此电路和程序还有扩展改进的空间,如在长时间不摆动的情况下可以使单片机进入省电模式,显示不仅限于对称图片等,大家可以试试。<br />以下是源程序:<br />/********************************************************/<br />// ---------------<br />// LED 显示摇棒<br />// ---------------<br />// 作者:nim 于 http://www.21icbbs.com 2005-1-7<br />//<br />// email: linyige@yahoo.com<br />//<br />// 本设计版权归作者所有,请勿擅自用于商业目的,转载请注明作者及出处<br />/*******************************************************/<br />#include<br />#define SEG 17 //每帧图片分成17 列来显示<br />#define INTERVAL 20 //每幅图片在左右摇摆20 次后换下一幅<br />typedef unsigned char uchar;<br />typedef unsigned int uint;<br />code char pattern[17][3]={ //3 幅图片的字模<br />{0xff,0xff,0xff},<br />{0xff,0xff,0xff},<br />{0xff,0xff,0xff},<br />{0xff,0x9f,0xff},<br />{0xff,0x6f,0xf9},<br />{0xff,0x77,0x65},<br />{0xfe,0xbb,0x1e},<br />{0x7e,0xdd,0xfe},<br />{0x00,0xee,0xfe},<br />{0x7e,0xdd,0xfe},<br />{0xfe,0xbb,0x1e},<br />{0xff,0x77,0x65},<br />{0xff,0x6f,0xf9},<br />{0xff,0x9f,0xff},<br />{0xff,0xff,0xff},<br />{0xff,0xff,0xff},<br />{0xff,0xff,0xff},<br />};<br />uchar phase,th1,tl1,index,count;<br />main()<br />{<br />EA=0;<br />EX0=1;<br />ET1=1;<br />PX0=1;<br />IT0=1;<br />TMOD=0x11;<br />index=0;<br />EA=1;<br />while(1)<br />{<br />}<br />}<br />void Int0_Handle(void) interrupt 0 using 2<br />{<br />uint t0_time;<br />TR0=0;<br />TR1=0;<br />TF1=0;<br />t0_time=TH0<<8|TL0;<br />TL0=0;<br />TH0=0;<br />TR0=1;<br />t0_time=65535-t0_time/SEG;<br />th1=t0_time/256;<br />TH1=th1;<br />tl1=t0_time % 256;<br />TL1=tl1;<br />if (count<3*INTERVAL){ //3 幅图片循环<br />count++;<br />}<br />else{<br />count=0;<br />}<br />index=count/INTERVAL;<br />if (th1!=0xff || tl1!=0xff){ //如果摆动特别慢,定时器溢出就不显示<br />phase=0;<br />TR1=1;<br />}<br />else{<br />TR1=0;<br />}<br />}<br />void Timer1(void) interrupt 3 using 3<br />{<br />if<br />(phase<SEG)&NBSP;&NBSP;&NBSP;&NBSP;&NBSP;&NBSP;&NBSP;&NBSP;&NBSP;&N<br />BSP;&NBSP;&NBSP; 17 段依次显示<br />{<br />P1=pattern[phase][index];<br />phase++;<br />TH1=th1;<br />TL1=tl1;<br />}<br />}<br /></td></TR></table>
|