/*该实验是流水灯(8个发光二极管循环点亮),功能是8个发光二极管循环以1S间隔点亮*/ include
MAIN: MO SP, #60H ;给堆栈指针赋初值 MO P1,#0FFH ;给P1口赋值 MO DPTR,#TABLE;查表 LIGHT: MO R4,#42 ;设置循环次数 LOOP: MO A,#42 ;给A赋初值 SUBB A,R4 ;将A的值与R4的值相减
输出“0”时,发光二极管亮,开始时P0.0→P0.1→P0.2→P0.3→┅→P0.7→P0.6→┅→P0.0亮,重复循环。/ ORG 0000H LJMP START ORG 0030H START:MOV R2,#8 ;左移次数 MOV A,#0FEH ;A的初始值,即
设置一个按键,功能是切换任务任务1,8个发光二极管每隔1s依次点亮,循环显示,任务二,8个led灯每隔2秒,依次点亮循环显示任务三,8个led每隔1s闪亮3次,求流程图,和原理图,编程 设置一个按键,功能是切换任务任务1,8个发光二极管每隔1s
设置一个按键,功能是切换任务 任务1,8个发光二极管每隔1s依次点亮,
ioport equ 0ff00h - 0280h io8253a equ ioport + 280h ;counter 0 address io8253b equ ioport + 281h ;counter 1 address io8253c equ ioport + 282h ;counter 2 address io8253d equ ioport + 283h ;8253
换为PieCtrl.PIEACK.bit.ACK1=1;
首先搞清LED管是高电平导通还是低电平导通。如果是低电平导通,P2赋0x00时,发光管全亮,0xff时,全灭。具体程序:define uint unsigned int define uchar unsigned char void delay(uint time_out){ uint i,j;for(i=0
如果你的时钟信号频率比较高,再设计一个分频器,将其频率降为2Hz即可。
那个VHDL开发板~~怎么用quartus编程~~编出一个led灯每隔一秒闪一次啊~~
while(1){ P3=0xfe;//第一个灯亮 delay();//延时 P3=0xfd;//第二个灯亮 delay();P3=0xfb;//第三个灯亮 delay();P3=0xf7;//第四个灯亮 delay();P3=0xef;//第五个灯亮 delay();P3=0xdf;//第六
看来是你自己把自己搞晕了。那P2口接的8个LED灯是怎么排列的?注意那P2.0的灯排在左边还是右边了吗?见下图,P2输出的就是0x55,看到的就是灭亮灭亮,那是因为P2.0所接的灯是在左边,而你又是从左边向右看的,
1:设定一个变量i,可以从0到3循环的变化 2:检测一个经过消抖处理的按键,按一下,i+1 3:当i值为各个值时,执行相应的花样。流水灯参考程序 include include define uchar unsigned char uchar j,temp;void delay(un
可见执行结果是:LED由外向内,再由内向外点亮
void main(){ uchar i;while(1){ P2=0x01;//此处有改 for(i=0;i<7;i++){ P2=_crol_(P2,1); //P2 的值向左循环移动 DelayMS(150);} P2=0x80;//此处有改 for(i=0;i<7;i++){ P2=_cror_(P2,
void main(){ while(1){ P2=0xfe; //第1个管亮 delay(500);P2=0xfd; //第2个管亮 delay(500);P2=0xfb; //依次类推 delay(500);P2=0xf7;delay(500);P2=0xef;delay(500);P2=0xdf;delay(500);P2=0x
画出一个仿真图,让p2口接8个LED发光二极管,并书写一道程序,让LED灯做亮灭闪烁每一秒闪烁一次
OUTPUT); pinMode(LED_PIN_B , OUTPUT); // 设置为每1ms调用一次TimerCbk函数。 MsTimer2::set(1, TimerCbk); MsTimer2::start();}void loop(){ if (timerCntA >= TM_MS(1000)) { d
TF0 初始值为0。TR0 = 1;//启动计数器0 启动后,TH0TL0就会自动加一。如下:B800 B801 B802 ……当加到0000时,TF0就自动为1。
我再帮你补一课,看了你的标题,我写了一个用定时器0来控制一个LED灯第隔1秒钟亮灭一次的程序,希望对你有用,另外我也写了一个你说的那个程序,一起发上来吧 这个是用定时器0控制一个灯的亮和灭 include
设置定时器时间间隔为1s,计数总共不到1s的话,就再定义一个变量,循环多次,以实现1s 然后再1s时的定时器中断子程序中设置输出脚的电平交替即可
当减到0时,表示1秒时间到 (重新送初始值20)判断拨动开关状态 如果为低低电平 则选择控制LED的端口内容左移一位 如果为高低电平 则选择控制LED的端口内容右移一位 即可实现对流水灯的方向控制。呵呵 满意
sbit ledbP0^1 void delay(int t){ while(t--)} void main(void){ while(1){ leda=0;ledb=1 delay( );leda=1;ledb=0;delay();} } 说明:IO口自己修改定义,因为不知道工作频率延时函数自己确定。
只要主程序中使用定时器行成间隔1s的定时,然后依次顺序点亮即可,可以通过对应GPIO依次置1或0实现,视外部电路而定。
单片机led灯一亮一灭间隔1秒
图二7图二72.4整点报时设计思路:首先要做到在整点的时候报时(也就是说再整点的时候蜂鸣器响),那么我们就观察在整点的时候电路有什么特征。我们观察到的特征就是:在整点的时候秒钟,分钟都是为零的,也就是说
2.1单一信号(如控制信号)的处理 如果这个输入信号来自异步时钟域(比如FPGA芯片外部的输入),一般采用同步器进行同步。最基本的结构是两个紧密相连的触发器,第一拍将输入信号同步化,同步化后的输出可能带来建立/保持时间的冲
只有红灯和绿灯?clk分频到0.2或者0.25S,灯亮0.2S,灭0.2S,再亮再灭。。。人眼可以识别到绿灯灯在闪烁就可以了
always@(posedge clk)begin // 顺序语句,到end止 if(buffer==26'd50000000) //判别buffer中的数值为25000000时,//做输出处理 begin led<=~led; // led反转一次。buffer<=0;end else begin buffer<=buffer+1;
1、产生一个0.5hz的时钟 2、每一1s时钟,灯亮灭一次(闪烁)以下是参考代码:// 这个是50Mhz产生0.5hz的时钟代码:reg [31:0] cnt;reg clk_led;always@(posedge clk_50M or negedge rst_n) begin
基于fpga的1hz小灯闪烁设计,应该怎么写
--试试这个吧: LIBRARY IEEE; USE IEEE.STD_LOGIC_1164.ALL; ENTITY Light IS PORT (CLK,S:IN STD_LOGIC; --CLK选4Hz,或选择其他频率再通过分频产生4Hz LOUT:OUT STD_LOGIC);--LOUT为输出,用于控制灯的闪灭 END Light; ARCHITECTRRE bhv OF Light IS BEGIN LOUT<=CLK WHEN S='1' ELSE '0’; END bhv;1HZ就是1秒一次, 用1秒时钟脉冲就可以了, 各品牌PLC1秒时钟脉冲指令各有区别, 比如欧姆龙用P_1s, 三菱用M8013等.
#include #define uchar unsigned char void delay(uchar a) { uchar i,j; for(i=0;i<a;i++) for(j=0;j<120;j++); } main() { while(1) { P2=0x00; delay(100); P2=0xff; delay(100); } }
#include #define uchar unsigned char #define uint unsigned int uint num=0,i=0; uchar code LED[]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80}; void main() { EA=1; ET0=1; TMOD=0x01; TH0=(65536-50000)/256; TL0=(65536-50000)%256; TR0=1; P1=0; while(1) { if(num==2) { num=0; P1=LED[i]; i++; if(i>7) i=0; } } } void time0() interrupt 1 { num++; TH0=(65536-50000)/256; TL0=(65536-50000)%256; }
#include sbit led=P2^7; sbit key=P3^2; void delayms(int a) { unsigned char i; while(a--)for(i=0;i<120;i++); } void ext0() interrupt 0 { led=0; while(key==0); } main() { EX0=1; IT0=1; EA=1; while(1) { led=0; delay(1000); led=1; delay(1000); } }
LIBRARY IEEE; USE IEEE.STD_LOGIC_1164.ALL; --USE IEEE.STD_LOGIC_ARITH.ALL; --USE IEEE.STD_LOGIC_UNSIGNED.ALL; entity led is port(led1,led2,led3,led4:out bit;clk:in bit); end led; architecture led_blink of led is begin process(clk) variable s1:integer:=0; variable s2:integer:=0; begin i1:if (clk'event and clk='1') then s1:=s1+1; if(s1>20000) then s2:=s2+1; if(s2>2500 and s2<5000) then led1<='1'; led2<='0'; led3<='1'; led4<='0'; elsif(s2>=5000) then led1<='0'; led2<='1'; led3<='0'; led4<='1'; s2:=0; end if; s1:=0; end if; end if i1; end process; end led_blink;
LED点阵显示屏摘要 LED大屏幕显示系统,以AT89S52单片机为核心,由键盘显示、温度采集、串口通信、LED大屏幕显示等功能模块组成。本系统的灰阶控制功能由软件来实现,吸收了硬件软件化的思想,本系统不仅可以实现题目要求的基本功能,同时发挥部分也得到完全的实现,最主要的是LED显示屏的内容可以通过PC机进行实时修改,而且有一定的创新功能。关键字:单片机 LED大屏幕 滚屏显示 PC机控制1.任务设计并制作一台简易LED电子显示屏,16行*16列*16灰阶点阵显示,原理示意图如下:PC机LED灰阶电子显示屏原理框图2.要求 (1)基本要求:设计并制作LED电子显示屏和控制器。1) 自制一台简易16行*16列*16灰阶点阵显示的LED电子显示屏; 2) 自制显示屏控制器,扩展键盘和相应的接口实现多功能显示控制,显示屏显示16灰阶图像(可以是渐变灰阶条纹)、数字和字母亮度适中,应无闪烁。 3) 显示屏通过按键切换显示图像、数字和字母; 4) 显示屏能显示3组特定图像、数字或者英文字母组成的句子,通过按键切换显示内容; 5) 能显示2组特定汉字组成的句子,通过按键切换显示内容。(2)发挥部分:1) 自制一台简易16行*32列*灰阶点阵显示的LED电子显示屏;2) LED显示屏亮度连续可调。3) 实现信息的左右滚屏显示,预存信息的定时循环显示;4) 实现实时时间的显示,显示屏数字显示: 时∶分∶秒(例如 18∶38∶59);5) 增大到10组(每组汉字8个或16个数字和字符)预存信息,信息具有掉电保护; 6)实现和PC机通讯,通过PC机串口直接对显示信息进行更新(须做PC机客户程序); 7)其他发挥功能。3.说明 (1)显示格式和显示信息可以自定义。 (2)电子显示屏LED显示灯只允许使用8*8 LED点阵显示模块。 (3) 显示屏的显示控制方案和控制器的选择方案任选。 (4) 不允许使用LED集成驱动模块和集成灰阶产生模块,可用CPLD或FPGA。2、方案论证2.1 显示部分:显示部分是本次设计最核心的部分,对于LED8*8点阵显示有以下两种方案:方案一:静态显示,将一帧图像中的每一个二极管的状态分别用0 和1 表示,若为0 ,则表示L ED 无电流,即暗状态;若为1 则表示二极管被点亮。若给每一个发光二极管一个驱动电路,一幅画面输入以后,所有L ED 的状态保持到下一幅画。对于静态显示方式方式,所需的译码驱动装置很多,引线多而复杂,成本高,且可靠性也较低。方案二:动态显示,对一幅画面进行分割,对组成画面的各部分分别显示,是动态显示方式。动态显示方式方式,可以避免静态显示的问题。但设计上如果处理不当,易造成亮度低,闪烁问题。因此合理的设计既应保证驱动电路易实现,又要保证图像稳定,无闪烁。动态显示采用多路复用技术的动态扫描显示方式, 复用的程度不是无限增加的, 因为利用动态扫描显示使我们看到一幅稳定画面的实质是利用了人眼的暂留效应和发光二极管发光时间的长短, 发光的亮度等因素. 我们通过实验发现, 当扫描刷新频率(发光二极管的停闪频率) 为50Hz, 发光二极管导通时间≥1m s 时, 显示亮度较好, 无闪烁感.。鉴于上述原因, 我们采用方案二2.2.数字时钟数字时钟是本设计的重要的部分。根据需要,可利用两种方案实现。方案一:本方案完全用软件实现数字时钟。原理为:在单片机内部存储器设三个字节分别存放时钟的时、分、秒信息。利用定时器与软件结合实现1秒定时中断,每产生一次中断,存储器内相应的秒值加1;若秒值达到60,则将其清零,并将相应的分字节值加1;若分值达到60,则清零分字节,并将时字节值加1;若时值达到24,则将时字节清零。该方案具有硬件电路简单的特点,但当单片机不上电,程序将不执行。且由于每次执行程序时,定时器都要重新赋初值,所以该时钟精度不高。方案二:本方案采用Dallas公司的专用时钟芯片DS。该芯片内部采用石英晶体振荡器,其芯片精度不大于10ms/年,且具有完备的时钟闹钟功能,因此,可直接对其以用于显示或设置,使得软件编程相对简单。为保证时钟在电网电压不足或突然掉电等突发情况下仍能正常工作,芯片内部包含锂电池。当电网电压不足或突然掉电时,系统自动转换到内部锂电池供电系统。而且即使系统不上电,程序不执行时,锂电池也能保证芯片的正常运行,以备随时提供正确的时间。基于时钟芯片的上述优点,本设计采用方案二完成数字时钟的功能。2.3 温度采集部分能进行温度测量是本设计的创新部分,由于现在用品追求多样化,多功能化,所以我们决定给系统加上温度测量显示模块,方便人们的生活,使该设计具有人性化。方案一:采用热敏电阻,可满足 40 摄氏度至 90 摄氏度测量范围,但热敏电阻精度、重复性、可靠性较差,对于检测小于 1 摄氏度的信号是不适用的。方案二:采用温度传感器DS18B20。DS18B20可以满足从-55摄氏度到+摄氏度测量范围,且DS18B20测量精度高,增值量为0.5摄氏度,在一秒内把温度转化成数字,测得的温度值的存储在两个八位的RAM中,单片机直接从中读出数据转换成十进制就是温度,使用方便。基于DS18b20的以上优点,我们决定选取DS18b20来测量温度。2.4 显示接口芯片的选择方案一:采取并口输入,占用大量I/O口资源方案二:选取串口输入,使用较少。所以我们选用串口输入。串口输入我们可以选用芯片有74HC、74LS、TPIC6B。但是74HC和74LS两种芯片必须加驱动才能驱动LED,而TI 公司的DMOS 器件TPIC6B , 除具有TTL 和CMOS 器件中移位寄存器 的逻辑功能外, 其最大的特点是驱动功率大, 可直接用作LED的驱动。综合以上比较,我们选取TPIC6B来驱动LED点阵。2.5 串口通讯芯片的选择AT89S52串行口采用的是TTL电平,因此必须的有电平转换电路,可以选择,,MAXA.方案一:采用或芯片实现电平转换,但在使用中发现这两种芯片可靠性不高,且需要正负12V电源,使用麻烦。方案二:采用单电源电平转换芯片MAXA可以使电路变得简单,可靠。基于以上分析,我们选用方案二,选用芯片MAXA2.6 电源模块方案一:采用干电池作为LED点阵系统的电源,由于点阵系统耗电量较大,使用干电池需经常换电池,不符合节约型社会的要求。点阵系统要悬挂在墙上,电池总量大,使用会有较大安全隐患。方案二:采用W/5V直流稳压电源作为系统电源,不仅功率上可以满足系统需要,不需要更换电源,并且比较轻便,使用更加安全可靠基于以上分析,我们决定采用方案二3、总体方案3.1 工作原理:利用单片机AT89S52单片机作为本系统的中控模块。单片机可把由DS18B20、DS读来的数据利用软件来进行处理,从而把数据传输到显示模块,实现温度、日历的显示。点阵LED电子显示屏显示器为主要的显示模块,把单片机传来的数据显示出来,并且可以实现滚动显示。在显示电路中,主要靠按键来实现各种显示要求的选择与切换。3.2 总体设计设计总体框图如图14、系统硬件设计(单元电路设计及分析)4.1 AT89S52单片机最小系统最小系统包括晶体振荡电路、复位开关和电源部分。图2为AT89S52单片机的最小系统。4.2 温度测量模块图3 DS18B20测量电路温度测量传感器采用DALLAS公司DS18B20的单总线数字化温度传感器,测温范围为-55℃~℃,可编程为9位~12位A/D转换精度,测温分辨率达到0.℃,采用寄生电源工作方式, CPU只需一根口线便能与DS18B20通信,占用CPU口线少,可节省大量引线和逻辑电路。接口电路如图3所示。4.3 时钟模块时钟模块采用DS芯片,DS 是DALLAS 公司推出的涓流充电时钟芯片内含有一个实时时钟/日历和31 字节静态RAM 通过简单的串行接口与单片机进行通信实时时钟/日历电路提供秒分时日日期月年的信息每月的天数和闰年的天数可自动调整时钟操作可通过AM/PM 指示决定采用24 或12 小时格式DS 与单片机之间能简单地采用同步串行的方式进行通信仅需用到三个口线1 RES 复位2 I/O 数据线3 SCLK串行时钟时钟/RAM 的读/写数据以一个字节或多达31 个字节的字符组方式通信DS 工作时功耗很低保持数据和时钟信息时功率小于1mW,其接线电路如图4图4 时钟电路4.4 键盘模块键盘、状态显示模块:为了使软件编程简单,本设计利用可编程芯片。接法如表1所示。PA口接按键,PC口则用于控制状态显示所用LED点阵。每个按键都通过一个10K的上拉电阻接电源+Vcc,按键的另一端接地。当有键按下时,与该键相连的PA口的相应位变为低电平,单片机检测到该变化后即转到相应的键处理程序,同时在程序中点亮LED点阵。模块电路如图54.5 LED显示模块点阵数据串行输入, 器件为 移位寄存器TPIC6B, 门控和扫描信号常以16 点阵为一行进行并行处理。在点阵显示中以4×8个L ED 点阵构成一个L ED 显示单元, 采用行共阳列共阴的编排方式。其驱动分为行列两部分, 分别来自于行、列移位寄存器, 行数据是扫描数据, 16 行中每次只有一行被驱动, 采用逐行扫描方式, 列数据则为汉字的点阵码。。对于字符和图形显示也可以用点阵处理, 其显示原理和方法相同.电路如图6图6 LED显示电路4.6灰阶控制4.6.1 阶灰度控制方法对于LED 发光灯, 灰度控制方法主要有驱动电流控制法和驱动脉冲占空比控制法。占空比控制法是在一定的显示重复扫描频率下, LED 器件的亮度可由发光时间Tu 与扫描周期T 的比Tu/T 进行控制。在相同的LED 正向电流作用下, Tu 越长发光能量越大, 只要周期性扫描的速度足够快的话, 人眼发觉不了1 个周期内不发光的部分, 只是感觉LED 的亮度更高。本设计采用占空比控制法。4.6.2 图像扫描方法在图像扫描显示过程中, 每次传输和显示的只是带有8 bit 灰度级的某一列数据的1 bit, 这样传输并显示8次, 就可以反映出8 bit 的灰度级。具体方法为:首先扫描显示16 行各列8 bit 灰度值的D0 比特, 其次扫描显示16行各列的D1比特, 依此类推, 直到显示16 行各列灰度值的D7 bit。各部分按顺序重复上述过程, 直到整屏扫描显示完, 对于16 行各列1 bit 的扫描细节过程为: 从第一行开始, 首先送这一行各列D0 位灰度值数据到各列移位寄存器锁存器, 然后, 送第2 行各列的D0 位数据, 同时显示第1 行数据。依次类推, 直到显示第16 行各列的D0位数据, 同时开始第1 行的D1 位数据。重复8 次扫描显示16 行。每比特扫描时间如下图2所示,整个扫描过程可以如图3所示。方案一、通过FPGA来实现灰阶控制, 是在FPGA 设计工具中利用译码器产生一系列OE 脉宽的具体电路图。E2…E10 来自计数器; H1, H2, H4, H8, H16, H32, H64, H,H 为译码器译出的不同脉宽的OE 信号源。H1为一个时钟周期, H2 为半个时钟周期, 以此类推,H 为1/ 个时钟周期[2]。这一系列脉冲需要进入数据选择器进行分时输出, 最终输出的只有OE一条线。表1 是OE 脉冲分配表。因为H1 最宽, H1 输出时LED 最亮, 所以在这里不是将H1连续输出, 而是分散开, 其目的是提高显示屏的扫描频率, 降低频闪, 使屏幕图像看上去更加稳定。方案二、通过单片机软件扫描来实现LED不同灰阶的现实,从而达到显示图像的效果。由于缺少FPGA的开发工具,所以采用方案二。4.7亮度连续可调控制方案一 通过在软件中调节刷新频率。刷新频率高的时候,连续点亮的时间短,显示屏亮度低,当刷新频率调低时,连续点亮的时间延长,显示屏变亮。因此通过调节占空比来实现显示屏亮度的调整。但是由于软件调节亮度变化不连续.不能实现连续的亮度调节。并且会出现闪烁。调节的效果不明显,故不采用此方案。方案二 通过调节电位器来改变电压,实现亮度的调节。调节电位器实现线形电压调整,从而控制三极管使显示屏压降发生改变。从而达到连续调节亮度的目的。电位器的调节范围较大,因此用此方法来调节。4.8电源选择W/5V的直流稳压电源更加安全,电路图如图7图7 电源电路4.9 PC机通讯4.9.1硬件连接设计MAX是标准的串口通信接口,对于一般的双向通讯,只需要使用串行输入口RXD(第3脚)、串行输出TXD(第2脚)和地线(第7脚)。MAX逻辑电平的规定如表2.图8 串口通讯4.9.2软件设计通过VC++在PC机上编写一个上位机软件实现对单片机的控制,实现LED显示内容和现实方式的控制。4.10整体电路系统整体电路如下:图9 整体电路5、系统软件设计5.1主程序5.2显示子程序流程5.3 显示时间子程序流程5.4 与PC串口通讯程序5.5温度测量流程图 实在不行换一个 或者在硬之城上面找找这个型号的资料
MAIN: MOV P1, #11111110B ; P1 口 点亮一个发光二极管 ACALL DELAY ; 调用延时子程序 MOV P1, #11111101B ; 从左向右移动 一位 ACALL DELAY MOV P1, #11111011B ACALL DELAY MOV P1, #11110111B ACALL DELAY MOV P1, #11101111B ACALL DELAY MOV P1, #11011111B ACALL DELAY MOV P1, #10111111B ACALL DELAY MOV P1, #01111111B ACALL DELAY JMP MAIN ; 转移 至 MAIN 循环 DELAY: MOV R5,#250 ; 延时子程序 6.000 M 晶振 约 0.5 秒 D1: MOV R6,#250 D2: DJNZ R6,$ DJNZ R5,D1 RET