蓝桥杯单片机----学习二数码管显示(STC15F2K60S2)

一、原理图

 二、原理分析

        我们的数码管是共阳极的,当段选置0时(低电平)点亮数码管。段选A‘ -> DP'由锁存器74HC573(U7)控制,通过138译码器使能Y7C,进而将P0数据传出。位选COM1 -> COM8由U8控制,通过使能Y6C,来选择想要点亮的某一位数码管。例如若想使第一个数字为零。

(1).令P2.7、P2.6、P2.5为1、1、1,使能段选锁存器。然后令P0为0xc0,即段选输出为0使能段选锁存器。
(2).令P2.7、P2.6、P2.5为1、1、0,使能位选锁存器。然后令P0为0x01,即打开第一个数码管使能位选锁存器。

若想显示0,需将a,b,,c,d,e,f置0,其余置1。

三、代码

#include "dsp.h"
DisplayStruct dsp;
code unsigned char segCode[] = 
	{0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xff,0xbf,0xc6,0x89,0x8e,0x8c,0x86,0x88};
DisplayStruct* GetDisplayStruct(){
	return &dsp;
}

void SegDisplay()
{
	SEG(0xff);
	COM(0x01 << dsp.com);
	if(dsp.com != dsp.dot){
		SEG(segCode[dsp.buf[dsp.com]]);
	}else{
		SEG(segCode[dsp.buf[dsp.com]] & 0x7f);
	}
	if(++dsp.com >= 8)
		dsp.com = 0;
}

void InitDsp()
{
	unsigned char i;
	for(i=0;i<8;i++)
	{
		dsp.buf[i] = 10;
	}
	dsp.dot = 255;
	dsp.SegDisplay = SegDisplay;
}

 数据导入

#include "task.h"
void InitBsp()
{
	BUZ(0x00);
	LED(0xff);
	InitDsp();
}
void TaskDisplay()
{
	DisplayStruct* seg = GetDisplayStruct();
	GetDisplayStruct()->SegDisplay();
	seg->dot = 6;
	seg->buf[0] = 17;
	seg->buf[1] = 10;
	seg->buf[2] = 10;
	seg->buf[3] = 10;
	seg->buf[4] = 10;
	seg->buf[5] = 10;
	seg->buf[6] = 1;
	seg->buf[7] = 1;
}
#include "main.h"

void main()
{
	InitBsp();
	while(1)
	{
		TaskDisplay();
	}
}
#ifndef	__MAIN_H
#define __MAIN_H
#include <STC15F2K60S2.H>
#include "task.h"
#include "dsp.h"

#define LED(x) {P0 = x;P2 = (P2 & 0x1f)|0x80;P2&=0x1f;}
#define BUZ(x) {P0 = x;P2 = (P2 & 0x1f)|0xa0;P2&=0x1f;}
#define COM(x) {P0 = x;P2 = (P2 & 0x1f)|0xc0;P2&=0x1f;}
#define SEG(x) {P0 = x;P2 = (P2 & 0x1f)|0xe0;P2&=0x1f;}

#endif

### STC15F2K60S2单片机数码管动态显示0-8的实现方法 #### 硬件连接方式 STC15F2K60S2单片机通常采用P0口作为段选信号,P2口作为位选信号来控制数码管。对于共阳极数码管,段选信号需要取反;而对于共阴极数码管,则无需额外操作[^1]。 #### 示例代码 以下是基于STC15F2K60S2单片机实现数码管动态显示数字0到8的完整代码: ```c #include <STC15F2K60S2.H> // 定义共阴极数码管段码表 (对应数字 0 到 9) unsigned char code SEG_CODE[] = { 0x3F, // 0 0x06, // 1 0x5B, // 2 0x4F, // 3 0x66, // 4 0x6D, // 5 0x7D, // 6 0x07, // 7 0x7F, // 8 0x6F // 9 }; // 延时函数 void delay(unsigned int time) { unsigned int i, j; for (i = 0; i < time; i++) for (j = 0; j < 120; j++); } // 数码管动态显示函数 void display_digit(unsigned char digit) { P2 = 0xE0; // 设置段选锁存器地址 P0 = SEG_CODE[digit];// 输出对应的段码 P2 = 0xC0; // 设置位选锁存器地址 P0 = 0x01; // 启动第一位数码管 delay(5); // 延时一段时间 P0 = 0xFF; // 清除显示 } void main() { unsigned char count = 0; TMOD = 0x01; // 配置T0为模式1 TH0 = 0xFC; // 设置初值 TL0 = 0x67; // 设置初值 EA = 1; // 开启总中断 ET0 = 1; // 开启T0中断 TR0 = 1; // 启动定时器 while (1) { for (count = 0; count <= 8; count++) { // 循环显示数字0至8 display_digit(count); delay(200); // 每次延时适当时间 } } } ``` #### 实现细节解析 1. **段码定义**:`SEG_CODE`数组存储了从0到9的数码管段码,其中每一位代表一个七段数码管点亮的状态[^1]。 2. **硬件初始化**:通过设置P2寄存器的不同值分别指定段选和位选锁存器的地址。 3. **动态扫描机制**:每次只点亮一位数码管,并快速轮询其他位置以形成视觉上的连续显示效果。 4. **延迟处理**:为了让人眼能够正常识别所显示的内容,在每次切换显示之前加入短暂停顿(由`delay()`完成),从而避免闪烁现象发生. ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值