jjzjj

蓝桥杯单片机第九届省赛题详细讲解(彩灯控制器)

月明Mo 2023-08-14 原文

看之前强烈建议先自己做一遍!!!

演示视频

题目讲解

首先还是从题目的程序框图准备起。

将程序框图的PCF8591(模拟输入),按键,数码管,EEPROM都先调试好。


然后看一下基本功能,让自己对整个流程有一个了解。再将彩灯控制的LED的四种模式准备好。这里我建议是用数组把状态保存起来

uchar LED1[8]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f}; //模式1
uchar LED2[8]={0x7f,0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe}; //模式2
uchar LED3[4]={0x7e,0xbd,0xdb,0xe7}; //模式3
uchar LED4[4]={0xe7,0xdb,0xbd,0x7e}; //模式4

然后继续看题,这里亮度调节需要调节pwm占空比来实现,所以先放一下,先把Rb2电压转化为4个等级。

uchar SMG_mode=0,move; //数码管模式定义,滑动变阻器Rb2定义
uchar shine_mode=0; //定义光强
void main(void)
{
	move=IIC_read(PCF8591_address,Move_address); //读取Rb2电阻阻值
	move=move*1.9608; //500/255 将255转换到500		
	if(move<125) shine_mode=1;
	else if(move<250) shine_mode=2;
	else if(move<375) shine_mode=3;
	else shine_mode=4;
}

然后接着往下看题目。首先设置

S7:控制LED流转,所以设置一个变量控制就行。
S6:为数码管状态切换按键,同样控制一个变量来切换。由于设置的单元需要闪,所以需要用到定时器。注意还要将数据存入eeprom,注意eeprom的大小为255,所以只能将时间变小存

uchar SMG_mode=0,move; //数码管模式定义,滑动变阻器Rb2定义
uchar shine_mode=0; //定义光强
char led_mode=1; //led模式
int gap=400; //设置流转间隔
void main(void)
{
	init(); //初始开发板
	Timer0Init(); //定时器初始化
//	threshold=IIC_read(0xA0,0x00); //上电读取EEPROM
	while(1)
	{
		if(SMG_mode==0)//数码管全息,模式一
		{
			SMG[0]=SMG[1]=SMG[2]=SMG[3]=SMG[4]=SMG[5]=20;
			SMG[6]=SMG[7]=20;
		}
		else if(SMG_mode==1) //模式控制,将模式赋值放定时器闪烁
		{
			SMG[0]=SMG[2]=21;
			SMG[3]=20;
			if(gap<1000){SMG[4]=20;
			SMG[5]=gap/100;SMG[6]=gap%100/10;SMG[7]=gap%10;} //1000以下显示
			else
			{SMG[4]=gap/1000;SMG[5]=gap%1000/100; //1000以上显示
			SMG[6]=gap%100/10;SMG[7]=gap%10;}
		}
		else if(SMG_mode==2)//间隔控制,将间隔赋值放定时器闪烁
		{
			SMG[0]=SMG[2]=21;SMG[1]=led_mode;
			SMG[3]=20;		
		}
		move=IIC_read(PCF8591_address,Move_address); //读取Rb2电阻阻值
		move=move*1.9608; //500/255 将255转换到500		
		if(move<125) shine_mode=1;
		else if(move<250) shine_mode=2;
		else if(move<375) shine_mode=3;
		else shine_mode=4;
		
		SMG_output();
		Dkey_scan();
	}
}
//定时器中断服务函数
uchar t=0; //定时器内计数变量
bit state=0; //闪控制变量
void time0() interrupt 1
{
	if((SMG_mode==1)||(SMG_mode==2))
	{
		t++;
		if(t>=160) //800ms/5ms=160次
		{
			t=0;
			if(state==0)
			{
				state=1;
				switch(SMG_mode)
				{
					case 1:SMG[1]=led_mode;break;
					case 2:
							if(gap<1000){SMG[4]=20;
							SMG[5]=gap/100;SMG[6]=gap%100/10;SMG[7]=gap%10;} //1000以下显示
							else
							{SMG[4]=gap/1000;SMG[5]=gap%1000/100; //1000以上显示
							SMG[6]=gap%100/10;SMG[7]=gap%10;}
						break;
				}
			}
			else
			{
				state=0;
				switch(SMG_mode)
				{
					case 1:SMG[1]=20;break;
					case 2:SMG[4]=SMG[5]=SMG[6]=SMG[7]=20;break;
				}
			}
		}
	}
}
bit ledenable=0; //led工作使能
void Dkey_scan(void)
{
	static uchar keybyte=0;
	static uchar key;
	if(((P3&0X0F)!=0X0F)&&(keybyte==0))
	{
		delay5ms();
		if((P3&0X0F)!=0X0F)
		{
			keybyte=1;key=P3&0x0f;
		}
	}
	if((keybyte==1)&&((P3&0X0F)==0X0F))
	{
		if((P3&0X0F)==0X0F)
		{
			switch(key)
			{
				case 0x0e: //S7
					if(ledenable==0)ledenable=1;
				else ledenable=0;
					break;
				case 0x0d: //S6
				if(SMG_mode==0){SMG_mode=1;P2=0X80;P0=0xff;}//进入设置关灯
				else if(SMG_mode==1)SMG_mode=2;
				else if(SMG_mode==2)
				{SMG_mode=0;IIC_write(AT24C02_address,0x00,led_mode);
				IIC_write(AT24C02_address,0x00,(gap/100));} //保存模式和间隔
					break;
				case 0x0b: //S5
				
					break;
				case 0x07: //S4
				
					break;
			}
			keybyte=0;
		}
	}
}

然后设置S5和S4两个按键。

bit ledenable=0; //led工作使能
void Dkey_scan(void)
{
	static uchar keybyte=0;
	static uchar key;
	if(((P3&0X0F)!=0X0F)&&(keybyte==0))
	{
		delay5ms();
		if((P3&0X0F)!=0X0F)
		{
			keybyte=1;key=P3&0x0f;
		}
	}
	if((keybyte==1)&&((P3&0X0F)==0X0F))
	{
		if((P3&0X0F)==0X0F)
		{
			switch(key)
			{
				case 0x0e: //S7
					if(ledenable==0)ledenable=1;
				else ledenable=0;
					break;
				case 0x0d: //S6
				if(SMG_mode==0)SMG_mode=1;
				else if(SMG_mode==1)SMG_mode=2;
				else if(SMG_mode==2)
				{SMG_mode=0;IIC_write(AT24C02_address,0x00,led_mode);
				IIC_write(AT24C02_address,0x00,gap);} //保存模式和间隔
					break;
				case 0x0b: //S5
				switch(SMG_mode)
				{
					case 1:led_mode++;break;
					case 2:gap+=100;break;
				}
				if(gap>=1200)gap=1200;  //限幅
				if(led_mode>=4)led_mode=4;  //限幅
					break;
				case 0x07: //S4
				switch(SMG_mode)
				{
					case 1:led_mode--;break;
					case 2:gap-=100;break;
				}
				if(gap<=400)gap=400;  //限幅
				if(led_mode<=1)led_mode=1;  //限幅
					break;
			}
			keybyte=0;
		}
	}
}

做完这些,接下来就是调节LED模式和亮度度,当然这些肯定是都需要在定时器里进行调节的。
间隔调节就是按照规定的间隔进行亮灭,亮度调节就是对间隔里面亮的状态进行细分,就是说你亮的时候不能一直亮,要闪亮,闪亮的间隔决定亮度。
这里我拿20ms的周期的pwm,分为四个占空比,11ms/20ms,14ms/20ms,17/20ms,20ms/20ms,这样就能控制亮度,

else //led模式
	{
		if(ledenable==1) //led使能有效才进行
		{
			tt++;
			if(tt>=gap)//gap到达间隔时间控制led间隔
			{
				tt=0;
				if(state==1){state=0;}
				else {state=1;num+=1;}
			}
			
			if(state==1)//亮
			{
				if(ttt<((shine_mode*3)+8))
				{
					switch(led_mode)
					{
						case 1:if(num>=8)num=0;led=LED1[num];break;//led1
						case 2:if(num>=8)num=0;led=LED2[num];break;//led2
						case 3:if(num>=4)num=0;led=LED3[num];break;//led3
						case 4:if(num>=4)num=0;led=LED4[num];break;//led4
					}
				}
				else
				{
					led=0xff;//模式0熄灭
				}
				ttt++;
				if(ttt>=20)ttt=0;
			}
			else//灭
			{
				led=0xff;//模式0控制间隔设置熄灭
			}
		}
	}

然后就是亮度等级显示了。

	while((key==0x07)&&(SMG_mode==0))
	{
		keybyte=0;key=P3&0x0f;
		SMG[6]=21;SMG[7]=shine_mode;
		SMG[0]=SMG[1]=SMG[2]=SMG[3]=SMG[4]=SMG[5]=20;		
		SMG_output();P2=0X80;P0=led;
	}

完整程序

main.c

#include <stc15f2k60s2.h>
#include "intrins.h"
#include "iic.h"

#define uchar unsigned char
#define uint unsigned int

#define AT24C02_address 0xA0 //EEPROM地址
#define PCF8591_address 0x90 //PCF地址
#define Move_address 0x03 //滑动变阻器地址

void init(void);
void Delay1ms(void);
void delay5ms(void);
void Dkey_scan(void);
void SMG_output(void);
void Timer0Init(void);
uchar tab[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,\
0x40,0x79,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10,0xff,0xbf};
uchar SMG[8]={20,20,20,20,20,20,20,20};//初始显示10,全息数码管

uchar LED1[8]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f}; //模式1
uchar LED2[8]={0x7f,0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe}; //模式2
uchar LED3[4]={0x7e,0xbd,0xdb,0xe7}; //模式3
uchar LED4[4]={0xe7,0xdb,0xbd,0x7e}; //模式4

uchar SMG_mode=0; //数码管模式定义
uint move=0; //滑动变阻器Rb2定义
uchar shine_mode=0; //定义光强
char led_mode=1; //led模式
uint gap=400; //设置流转间隔
uchar led=0xff; //led显示变量
bit ledenable=0; //led工作使能
void main(void)
{
	init(); //初始开发板
	led_mode=IIC_read(AT24C02_address,0x00); //上电读取EEPROM
	delay5ms();
	gap=IIC_read(AT24C02_address,0x01);
	gap *=100;
	Timer0Init(); //定时器初始化
	while(1)
	{
		move=IIC_read(PCF8591_address,Move_address); //读取Rb2电阻阻值
		move=move*1.9608; //500/255 将255转换到500		
		if(move<125) shine_mode=1;
		else if(move<250) shine_mode=2;
		else if(move<375) shine_mode=3;
		else shine_mode=4;
		if(SMG_mode==0)//数码管全息,模式一
		{
			SMG[0]=SMG[1]=SMG[2]=SMG[3]=SMG[4]=SMG[5]=20;
			SMG[6]=SMG[7]=20;
		}
		else if(SMG_mode==1) //模式控制,将模式赋值放定时器闪烁
		{
			SMG[0]=SMG[2]=21;
			SMG[3]=20;
			if(gap<1000){SMG[4]=20;
			SMG[5]=gap/100;SMG[6]=gap%100/10;SMG[7]=gap%10;} //1000以下显示
			else
			{SMG[4]=gap/1000;SMG[5]=gap%1000/100; //1000以上显示
			SMG[6]=gap%100/10;SMG[7]=gap%10;}
		}
		else if(SMG_mode==2)//间隔控制,将间隔赋值放定时器闪烁
		{
			SMG[0]=SMG[2]=21;SMG[1]=led_mode;
			SMG[3]=20;		
		}
		
		P2=0X80;P0=led;
		SMG_output();
		Dkey_scan();
	}
}

uint t=0; //定时器内计数变量
uint tt=0;//控制led间隔变量
uint ttt=0; //控制led光强
bit state=0; //闪控制变量
uchar num=0; //led数组选择变量
void time0() interrupt 1
{
	if((SMG_mode==1)||(SMG_mode==2))
	{
		t++;
		if(t>=800) //800ms
		{
			t=0;
			if(state==0)
			{
				state=1;
				switch(SMG_mode)
				{
					case 1:SMG[1]=led_mode;break; //模式一控制模式设置闪烁
					case 2://模式二控制间隔设置闪烁
							if(gap<1000){SMG[4]=20;
							SMG[5]=gap/100;SMG[6]=gap%100/10;SMG[7]=gap%10;} //1000以下显示
							else
							{SMG[4]=gap/1000;SMG[5]=gap%1000/100; //1000以上显示
							SMG[6]=gap%100/10;SMG[7]=gap%10;}
					break;
				}
			}
			else
			{
				state=0;
				switch(SMG_mode)
				{
					case 1:SMG[1]=20;break;//模式一控制模式设置熄灭
					case 2:SMG[4]=SMG[5]=SMG[6]=SMG[7]=20;break;//模式二控制间隔设置熄灭
				}
			}
		}
	}
	else //led模式
	{
		if(ledenable==1) //led使能有效才进行
		{
			tt++;
			if(tt>=gap)//gap到达间隔时间控制led间隔
			{
				tt=0;
				if(state==1){state=0;}
				else {state=1;num+=1;}
			}
			
			if(state==1)//亮
			{
				if(ttt<((shine_mode*3)+8))
				{
					switch(led_mode)
					{
						case 1:if(num>=8)num=0;led=LED1[num];break;//led1
						case 2:if(num>=8)num=0;led=LED2[num];break;//led2
						case 3:if(num>=4)num=0;led=LED3[num];break;//led3
						case 4:if(num>=4)num=0;led=LED4[num];break;//led4
					}
				}
				else
				{
					led=0xff;//模式0熄灭
				}
				ttt++;
				if(ttt>=20)ttt=0;
			}
			else//灭
			{
				led=0xff;//模式0控制间隔设置熄灭
			}
		}
	}
}

void Dkey_scan(void)
{
	static uchar keybyte=0;
	static uchar key;
	if(((P3&0X0F)!=0X0F)&&(keybyte==0))
	{
		delay5ms();
		if((P3&0X0F)!=0X0F)
		{
			keybyte=1;key=P3&0x0f;
		}
	}
	while((key==0x07)&&(SMG_mode==0))
	{
		keybyte=0;key=P3&0x0f;
		SMG[6]=21;SMG[7]=shine_mode;
		SMG[0]=SMG[1]=SMG[2]=SMG[3]=SMG[4]=SMG[5]=20;		
		SMG_output();P2=0X80;P0=led;
	}
	if((keybyte==1)&&((P3&0X0F)==0X0F))
	{
		if((P3&0X0F)==0X0F)
		{
			switch(key)
			{
				case 0x0e: //S7
					if(ledenable==0)ledenable=1;
				else ledenable=0;
					break;
				case 0x0d: //S6
				if(SMG_mode==0){SMG_mode=1;P2=0X80;P0=0xff;}//进入设置关灯
				else if(SMG_mode==1)SMG_mode=2;
				else if(SMG_mode==2)
				{SMG_mode=0;IIC_write(AT24C02_address,0x00,led_mode);delay5ms();
				IIC_write(AT24C02_address,0x01,(gap/100));} //保存模式和间隔
					break;
				case 0x0b: //S5
				if(SMG_mode==1)led_mode++;
				else if(SMG_mode==2)gap+=100;
				if(gap>=1200)gap=1200;  //限幅
				if(led_mode>=4)led_mode=4;  //限幅
					break;
				case 0x07: //S4
				if(SMG_mode==1)led_mode--;
				else if(SMG_mode==2)gap-=100;
				if(gap<=400)gap=400;  //限幅
				if(led_mode<=1)led_mode=1;  //限幅
					break;
			}
			keybyte=0;
		}
	}
}

void Timer0Init(void)		//1毫秒@11.0592MHz
{
	AUXR |= 0x80;		//定时器时钟1T模式
	TMOD &= 0xF0;		//设置定时器模式
	TL0 = 0xCD;		//设置定时初值
	TH0 = 0xD4;		//设置定时初值
	TF0 = 0;		//清除TF0标志
	TR0 = 1;		//定时器0开始计时
	EA=1;ET0=1; //打开定时器中断
}

void SMG_output(void)
{
	uchar i;
	for(i=0;i<8;i++)
	{
	P2=(P2&0X1F)|0XC0;
	P0=(1 << i);
	P2=(P2&0X1F)|0XE0;
	P0=tab[SMG[i]];			
	Delay1ms();
	}
	P2=(P2&0X1F)|0XC0;
	P0=0XFF;
	P2=(P2&0X1F)|0XE0;
	P0=0XFF;		
}

void init(void)
{
	P2=(P2&0X1F)|0XA0;
	P0=0X00;
	P2=(P2&0X1F)|0X80;
	P0=0Xff;
	P2=(P2&0X1F)|0Xc0;
	P0=0Xff;
	P2=(P2&0X1F)|0Xe0;
	P0=0Xff;	
}

void Delay1ms(void)		//@11.0592MHz
{
	unsigned char i, j;

	_nop_();
	_nop_();
	_nop_();
	i = 11;
	j = 190;
	do
	{
		while (--j);
	} while (--i);
}

void delay5ms(void)		//@11.0592MHz
{
	unsigned char i, j;

	i = 54;
	j = 199;
	do
	{
		while (--j);
	} while (--i);
}

iic.c

#include "iic.h"

#define DELAY_TIME 40

void IIC_write(uchar hw_address,uchar reg_address,uchar num)
{
	IIC_Start();
	IIC_SendByte(hw_address&0xfe);
	IIC_WaitAck();
	IIC_SendByte(reg_address);
	IIC_WaitAck();
	IIC_SendByte(num);
	IIC_WaitAck();	
	IIC_Stop();	
}	

uchar IIC_read(uchar hw_address,uchar reg_address)
{
	uchar num;
	IIC_Start();
	IIC_SendByte(hw_address&0xfe);
	IIC_WaitAck();
	IIC_SendByte(reg_address);	
	IIC_WaitAck();
	IIC_Stop();
	
	IIC_Start();
	IIC_SendByte(hw_address|0x01);
	IIC_WaitAck();
	num=IIC_RecByte();
	IIC_WaitAck();
	IIC_Stop();	
	
	return num;
}

//
void IIC_Delay(unsigned char i)
{
    do{_nop_();}
    while(i--);        
}

//
void IIC_Start(void)
{
    SDA = 1;
    SCL = 1;
    IIC_Delay(DELAY_TIME);
    SDA = 0;
    IIC_Delay(DELAY_TIME);
    SCL = 0;	
}

//
void IIC_Stop(void)
{
    SDA = 0;
    SCL = 1;
    IIC_Delay(DELAY_TIME);
    SDA = 1;
    IIC_Delay(DELAY_TIME);
}

//
void IIC_SendAck(bit ackbit)
{
    SCL = 0;
    SDA = ackbit;  					
    IIC_Delay(DELAY_TIME);
    SCL = 1;
    IIC_Delay(DELAY_TIME);
    SCL = 0; 
    SDA = 1;
    IIC_Delay(DELAY_TIME);
}

//
bit IIC_WaitAck(void)
{
    bit ackbit;
	
    SCL  = 1;
    IIC_Delay(DELAY_TIME);
    ackbit = SDA;
    SCL = 0;
    IIC_Delay(DELAY_TIME);
    return ackbit;
}

//
void IIC_SendByte(unsigned char byt)
{
    unsigned char i;

    for(i=0; i<8; i++)
    {
        SCL  = 0;
        IIC_Delay(DELAY_TIME);
        if(byt & 0x80) SDA  = 1;
        else SDA  = 0;
        IIC_Delay(DELAY_TIME);
        SCL = 1;
        byt <<= 1;
        IIC_Delay(DELAY_TIME);
    }
    SCL  = 0;  
}

//
unsigned char IIC_RecByte(void)
{
    unsigned char i, da;
    for(i=0; i<8; i++)
    {   
    	SCL = 1;
		IIC_Delay(DELAY_TIME);
		da <<= 1;
		if(SDA) da |= 1;
		SCL = 0;
		IIC_Delay(DELAY_TIME);
    }
    return da;    
}

iic.h

#ifndef _IIC_H
#define _IIC_H

#include "stc15f2k60s2.h"
#include "intrins.h"

#define uchar unsigned char
#define uint unsigned int

sbit SDA = P2^1;
sbit SCL = P2^0;

void IIC_Start(void); 
void IIC_Stop(void);  
bit IIC_WaitAck(void);  
void IIC_SendAck(bit ackbit); 
void IIC_SendByte(unsigned char byt); 
unsigned char IIC_RecByte(void); 
void IIC_write(uchar hw_address,uchar reg_address,uchar num);
uchar IIC_read(uchar hw_address,uchar reg_address);


#endif

工程文件

工程文件有注释

有关蓝桥杯单片机第九届省赛题详细讲解(彩灯控制器)的更多相关文章

  1. C51单片机——实现用独立按键控制LED亮灭(调用函数篇) - 2

    说在前面这部分我本来是合为一篇来写的,因为目的是一样的,都是通过独立按键来控制LED闪灭本质上是起到开关的作用,即调用函数和中断函数。但是写一篇太累了,我还是决定分为两篇写,这篇是调用函数篇。在本篇中你主要看到这些东西!!!1.调用函数的方法(主要讲语法和格式)2.独立按键如何控制LED亮灭3.程序中的一些细节(软件消抖等)1.调用函数的方法思路还是比较清晰地,就是通过按下按键来控制LED闪灭,即每按下一次,LED取反一次。重要的是,把按键与LED联系在一起。我打算用K1来作为开关,看了一下开发板原理图,K1连接的是单片机的P31口,当按下K1时,P31是与GND相连的,也就是说,当我按下去时

  2. 蓝桥杯备赛(二) - 2

    目录前言: 一、ASC分析代码实现二、 卡片分析代码实现三、 直线分析代码实现四、货物摆放分析代码实现小结:前言:  在刷题的过程中,发现蓝桥杯的题目和力扣的差别很大。让人有一种不一样的感觉,蓝桥杯题目偏向对于实际问题用编程去的解决,而力扣给人感觉很锻炼自己的编程思维,逻辑能力。两者结合去刷,相信会有不一样的收获。 一、ASC  已知大写字母A的ASCII码为65,请问大写字母L的ASCII码是多少?分析  这道题目看上去很简单,我们需确定自己计算的准确,所以我建议用编程去解决。代码实现publicclassTest8{publicstaticvoidmain(String[]args){Sy

  3. 蓝桥杯C/C++VIP试题每日一练之报时助手 - 2

    ?作者主页:静Yu?简介:CSDN全栈优质创作者、华为云享专家、阿里云社区博客专家,前端知识交流社区创建者?社区地址:前端知识交流社区?博主的个人博客:静Yu的个人博客?博主的个人笔记本:前端面试题个人笔记本只记录前端领域的面试题目,项目总结,面试技巧等等。接下来会更新蓝桥杯官方系统基础练习的VIP试题,依然包括解题思路,源代码等等。问题描述:给定当前的时间,请用英文的读法将它读出来。时间用时h和分m表示,在英文的读法中,读一个时间的方法是:  如果m为0,则将时读出来,然后加上“o’clock”,如3:00读作“threeo’clock”。  如果m不为0,则将时读出来,然后将分读出来,如5

  4. micropython复现经典单片机项目(二)可视化音频 频谱解析(基本搞定) - 2

    本人是音乐爱好者,从小就特别喜欢那个随着音乐跳动的方框效果,就是这个:arduino上一大把对,我忍你很久了,我就想用mpy做,全网没有,行我自己研究。果然兴趣是最好的老师,我之前有篇博客专门讲音频,有兴趣的可以回顾一下。提到可视化频谱,必然绕不开fft,大学学过这玩意,当时一心玩,老师讲的一个字都么听进去,网上教程简略扫了一下,大该就是把时域转频域的工具,我大mpy居然没有fft函数,奶奶的,先放着。音频信息如何收集?第一种傻瓜式的ADC,模拟转数字,原始粗暴,第二种,I2S库,我之前博客有讲过,数据是PCM编码。然后又去学PCM编码,一学豁然开朗,舒服,以代码为例:audio_in=I2S

  5. 十四届蓝桥青少组模拟赛Python-20221108 - 2

    十四届蓝桥青少组模拟赛Python-20221108T1.二进制位数十进制整数2在十进制中是1位数,在二进制中对应10,是2位数。十进制整数22在十进制中是2位数,在二进制中对应10110,是5位数。请问十进制整数2022在二进制中是几位数?print(len(bin(2022))-2)#运行结果:11T2.晨跑小蓝每周六、周日都晨跑,每月的1、11、21、31日也晨跑。其它时间不晨跑。已知2022年1月1日是周六,请问小蓝整个2022年晨跑多少天?#样例代码1ls=[0,31,28,31,30,31,30,31,31,30,31,30,31]ans=0k=6foriinrange(1,13)

  6. 蓝桥杯 stm32 MCP4017 - 2

    本文代码使用HAL库。文章目录前言一、MCP4017的重要特性二、MCP4017计算RBW阻值三、MCP4017地址四、MCP4017读写函数五、CubeMX创建工程(利用ADC测量MCP4017电压)、对应代码:总结前言一、MCP4017的重要特性蓝桥杯板子上的是MCP4017T-104ELT,如图1。MCP4017是一个可编程电阻,通过写入的数值可以改变电阻的大小。重点在于6引脚(W),5引脚(B&#

  7. 51单片机——74HC595的应用(SPI实践) - 2

    目录SPI总线SPI总线概述 SPI总线分类SPI优点及缺点SPI接口硬件原理SPI四种工作模式 74HC595应用74HC595芯片概述74HC595封装及管脚功能74HC595工作原理 ​编辑 74HC595串行转并行点亮LED灯 程序实现  Proteus运行结构示意图SPI总线SPI总线概述 SPI(SerialPeripheralinterface):串行外围设备接口 用途:用来在微控制器与外围设备芯片之间实现数据交换 特点:高速、全双工、同步 SPI总线分类四线制全双工SPI(同时收发)MISO    主机输入/从机输出MOSI    主机输出/从机输入SCLK   串行时钟CS或

  8. 【毕业设计】基于单片机的智能温控农业大棚系统 - 物联网 stm32 - 2

    文章目录1简介2绪论2.1课题背景与目的3系统设计详细设计描述3.2硬件部分温度测量电路其他电路部分3.3软件部分主程序子系统程序温湿度程序流程键盘显示子程序3.4实现效果3.5部分相关代码4最后1简介Hi,大家好,这里是丹成学长,今天向大家介绍一个单片机项目基于单片机的智能温控农业大棚系统大家可用于课程设计或毕业设计单片机-嵌入式毕设选题大全及项目分享:https://blog.csdn.net/m0_71572576/article/details/1254090522绪论2.1课题背景与目的近年来我国的温室控制取得了长足的进步,首先在温室群控制方面,进行了初步的探索和理论研究,其次在温室

  9. AT24C04、AT24C08、AT24C16系列EEPROM芯片单片机读写驱动程序 - 2

    一、概述在之前的一篇博文中,记录了AT24C01、AT24C02芯片的读写驱动,先将之前的相关文章include一下:1.IIC驱动:4位数码管显示模块TM1637芯片C语言驱动程序2.AT24C01/AT24C02读写:AT24C01/AT24C02系列EEPROM芯片单片机读写驱动程序本文记录分享AT24C04、AT24C08、AT24C16芯片的单片机C语言读写驱动程序。二、芯片对比介绍型号容量bit容量byte页数字节/页器件寻址位可寻址器件数WordAddress位数/字节数备注AT24C044k5123216A2A149/1WordAddress使用P0位AT24C088k1024

  10. 基于51单片机、DS1302时钟模块的电子闹钟设计 - 2

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录一、设计原理1.DS1302介绍2.闹钟音乐播放原理二、程序设计1.DS1302.h2.ds1302.c3.music.h4.main.c三、电路图四、运行结果1.proteus仿真2.开发板实验五、总结六、附件提示:以下是本篇文章正文内容,下面案例可供参考一、设计原理1.DS1302介绍DS1302是美国DALLAS公司推出的一种高性能、低功耗、带RAM的实时时钟电路,它可以对年、月、日、周、时、分、秒进行计时,具有闰年补偿功能,工作电压为2.0V~5.5V。该芯片采用普通32.768kHz晶振,DS1302工作时功耗很

随机推荐