蓝桥杯单片机13届模拟题程序题

练习的时候写的,本人创作,有错误的话希望大家多多指正。

题目

#include <STC15F2K60S2.H>
#include "intrins.h"
#define Y4  P2=(P2&0x1f)|0x80
#define Y5  P2=(P2&0x1f)|0xa0
#define Y6  P2=(P2&0x1f)|0xc0
#define Y7  P2=(P2&0x1f)|0xe0
#define uchar unsigned char
#define uint  unsigned int
uchar code t_display[]={                       //标准字库
//   0    1    2    3    4    5    6    7    8    9    A    B    C    D    E    F
    0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x77,0x7C,0x39,0x5E,0x79,0x71,
//black  -     H    J    K    L    N    o   P    U     t    G    Q    r   M    y
    0x00,0x40,0x76,0x1E,0x70,0x38,0x37,0x5C,0x73,0x3E,0x78,0x3d,0x67,0x50,0x37,0x6e,
    0xBF,0x86,0xDB,0xCF,0xE6,0xED,0xFD,0x87,0xFF,0xEF,0x46};    //0. 1. 2. 3. 4. 5. 6. 7. 8. 9. -1

uint code T_COM[]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};      //位码
uchar n1=16,n2=16,n3=16,n4=16,n5=16,n6=16,n7=16,n8=16;
uint HZ=0,T=0,AD=0;// 频率,周期,电压/光敏
uint  count_f=0;//频率刷新
uchar S4=1,S5,S6,S7;//按键功能
uint temp_vcc=0,temp_HZ=0,temp_vcc1=0,temp_HZ1=0;
uint count_key=0;
uchar tongdao=0;
bit vcc_light=0,led_kg=1;
uchar LED1=0xff,LED2=0xff;
void Init()
{
	Y5;P0=0x00;
	Y4;P0=0xff;
}
void SMG_show(uchar n1,n2,n3,n4,n5,n6,n7,n8)
{
	static uchar i=0;
	i++;
	if(i==9)i=1;
	Y7;P0=0xff;
	switch(i)
	{
		case 1:
			Y6;P0=T_COM[0];
			Y7;P0=~t_display[n1];
		break;
		case 2:
			Y6;P0=T_COM[1];
			Y7;P0=~t_display[n2];
		break;
		case 3:
			Y6;P0=T_COM[2];
			Y7;P0=~t_display[n3];
		break;
		case 4:
			Y6;P0=T_COM[3];
			Y7;P0=~t_display[n4];
		break;
		case 5:
			Y6;P0=T_COM[4];
			Y7;P0=~t_display[n5];
		break;
		case 6:
			Y6;P0=T_COM[5];
			Y7;P0=~t_display[n6];
		break;
		case 7:
			Y6;P0=T_COM[6];
			Y7;P0=~t_display[n7];
		break;
		case 8:
			Y6;P0=T_COM[7];
			Y7;P0=~t_display[n8];
		break;
	}
}
void Timer1Init(void)		//2毫秒@12.000MHz
{
	AUXR |= 0x40;		//定时器时钟1T模式
	TMOD &= 0x0F;		//设置定时器模式
	TL1 = 0x40;		//设置定时初值
	TH1 = 0xA2;		//设置定时初值
	TF1 = 0;		//清除TF1标志
	TR1 = 1;		//定时器1开始计时
	ET1=1;
	EA=1;
}
void Timer1()interrupt 3
{
	count_f++;
	SMG_show(n1,n2,n3,n4,n5,n6,n7,n8);
	if(P30==0)
	{
		count_key++;
		if(count_key>500&&count_key<502)
		{
			count_key=0;
			led_kg=~led_kg;
		}
	}
	else
	{
		count_key=0;
	}
	if(count_f>400)
	{
		count_f=0;
		HZ=((uint)TH0<<8|(uint)TL0);
		T=1000000/HZ;
		TH0=0;
		TL0=0;
	}
}
void Delay15ms()		//@12.000MHz
{
	unsigned char i, j, k;

	_nop_();
	_nop_();
	i = 1;
	j = 176;
	k = 19;
	do
	{
		do
		{
			while (--k);
		} while (--j);
	} while (--i);
}

uchar key_num=0;
void duli_Scanf()
{
	if(P30==0)
	{
		Delay15ms();
		if(P30==0)
		{
			key_num=7;
		}while(!P30);
	}
	if(P31==0)
	{
		Delay15ms();
		if(P31==0)
		{
			key_num=6;
		}while(!P31);
	}
	if(P32==0)
	{
		Delay15ms();
		if(P32==0)
		{
			key_num=5;
		}while(!P32);
	}
	if(P33==0)
	{
		Delay15ms();
		if(P33==0)
		{
			key_num=4;
		}while(!P33);
	}
	
}
/*
  程序说明: IIC总线驱动程序
  软件环境: Keil uVision 4.10 
  硬件环境: CT107单片机综合实训平台 8051,12MHz
  日    期: 2011-8-9
*/
void Delay5us()		//@12.000MHz
{
	unsigned char i;

	_nop_();
	_nop_();
	i = 12;
	while (--i);
}

#define somenop Delay5us()    
#define SlaveAddrW 0xA0
#define SlaveAddrR 0xA1
//总线引脚定义
sbit SDA = P2^1;  /* 数据线 */
sbit SCL = P2^0;  /* 时钟线 */
//总线启动条件
void IIC_Start(void)
{
	SDA = 1;
	SCL = 1;
	somenop;
	SDA = 0;
	somenop;
	SCL = 0;	
}

//总线停止条件
void IIC_Stop(void)
{
	SDA = 0;
	SCL = 1;
	somenop;
	SDA = 1;
}

//应答位控制
void IIC_Ack(bit ackbit)
{
	if(ackbit) 
	{	
		SDA = 0;
	}
	else 
	{
		SDA = 1;
	}
	somenop;
	SCL = 1;
	somenop;
	SCL = 0;
	SDA = 1; 
	somenop;
}

//等待应答
bit IIC_WaitAck(void)
{
	SDA = 1;
	somenop;
	SCL = 1;
	somenop;
	if(SDA)    
	{   
		SCL = 0;
		IIC_Stop();
		return 0;
	}
	else  
	{ 
		SCL = 0;
		return 1;
	}
}

//通过I2C总线发送数据
void IIC_SendByte(unsigned char byt)
{
	unsigned char i;
	for(i=0;i<8;i++)
	{   
		if(byt&0x80) 
		{	
			SDA = 1;
		}
		else 
		{
			SDA = 0;
		}
		somenop;
		SCL = 1;
		byt <<= 1;
		somenop;
		SCL = 0;
	}
}

//从I2C总线上接收数据
unsigned char IIC_RecByte(void)
{
	unsigned char da;
	unsigned char i;
	
	for(i=0;i<8;i++)
	{   
		SCL = 1;
		somenop;
		da <<= 1;
		if(SDA) 
		da |= 0x01;
		SCL = 0;
		somenop;
	}
	return da;
}
uchar PCF_ADC(uchar addr)
{
	uchar dat;
	IIC_Start();
	IIC_SendByte(0x90);
	IIC_WaitAck();
	IIC_SendByte(addr);
	IIC_WaitAck();
	IIC_Stop();
	
	IIC_Start();
	IIC_SendByte(0x91);
	IIC_WaitAck();
	dat=IIC_RecByte();
	IIC_Ack(0);
	IIC_Stop();
	return dat;
}
uchar ER_read(uchar addr)
{
	uchar dat;
	IIC_Start();
	IIC_SendByte(0xa0);
	IIC_WaitAck();
	IIC_SendByte(addr);
	IIC_WaitAck();
	IIC_Stop();
	
	IIC_Start();
	IIC_SendByte(0xa1);
	IIC_WaitAck();
	dat=IIC_RecByte();
	IIC_Ack(0);
	IIC_Stop();
	return dat;
}
void ER_write(uchar addr,dat)
{
	IIC_Start();
	IIC_SendByte(0xa0);
	IIC_WaitAck();
	IIC_SendByte(addr);
	IIC_WaitAck();
	IIC_SendByte(dat);
	IIC_WaitAck();
	IIC_Stop();
}
void Timer_count()
{
	TMOD&=0xf0;
	TMOD|=0x05;
	TH0=0;
	TL0=0;
	TR0=1;
	ET0=0;
}
void Key_gn()
{
	if(key_num==4)
	{
		S4++;
		if(S4==4)S4=1;
		key_num=0;
	}
	if(S4==1)
	{
		n1=15;
		if((HZ/10000000)==0)n2=16;
		else n2=HZ/10000000;
		if(((HZ%1000000)/100000)==0&&n2==16)n3=16;
		else n3=(HZ%1000000)/100000;
		if(((HZ%100000)/10000)==0&&n3==16)n4=16;
		else n4=(HZ%100000)/10000;
		if(((HZ%10000)/1000)==0&&n4==16)n5=16;
		else n5=(HZ%10000)/1000;
		if(((HZ%1000)/100)==0&&n5==16)n6=16;
		else n6=(HZ%1000)/100;
		if(((HZ%100)/10)==0&&n6==16)n7=16;
		else n7=(HZ%100)/10;
		n8=HZ%10;
	}
	else if(S4==2)
	{
		n1=22;
		if((T/10000000)==0)n2=16;
		else n2=T/10000000;
		if(((T%1000000)/100000)==0&&n2==16)n3=16;
		else n3=(T%1000000)/100000;
		if(((T%100000)/10000)==0&&n3==16)n4=16;
		else n4=(T%100000)/10000;
		if(((T%10000)/1000)==0&&n4==16)n5=16;
		else n5=(T%10000)/1000;
		if(((T%1000)/100)==0&&n5==16)n6=16;
		else n6=(T%1000)/100;
		if(((T%100)/10)==0&&n6==16)n7=16;
		else n7=(T%100)/10;
		n8=T%10;
	}
	else if(S4==3)
	{
		AD=PCF_ADC(tongdao)*1.961;
		n1=25;n2=16;n3=16;n4=16;n5=16;n6=AD/100+32;n7=(AD%100)/10;n8=AD%10;
	}
	if(key_num==5)
	{
		vcc_light=~vcc_light;
		key_num=0;
	}
	if(vcc_light==0)
	{
		tongdao=1;
	}
	else tongdao=3;
	if(key_num==6)
	{
		if(tongdao==3)
		{
		  ER_write(0x00,PCF_ADC(tongdao));
			
		}
		key_num=0;
	}
	if(key_num==7)
	{
			temp_HZ=HZ;
		  ER_write(0x01,HZ/10000);
		  Delay15ms();
		  ER_write(0x02,(HZ%10000)/1000);
		  Delay15ms();
		  ER_write(0x03,(HZ%1000)/100);
		  Delay15ms();
		  ER_write(0x04,(HZ%100)/10);
		  Delay15ms();
			ER_write(0x05,HZ%10);;
		key_num=0;
	}
	
}
void LED_gn()
{
	if(tongdao==3)
	{
		if(PCF_ADC(tongdao)>temp_vcc1)
		{
			Y4;LED1=0xfe;
		}
		else{
			Y4;LED1=0xff;
		}
	}
	if(HZ>temp_HZ1)
	{
		Y4;LED2=LED1&0xfd;
	}
	else{
		Y4;LED2=LED1&0xff;
	}
	if(S4==1)
	{
		Y4;P0=LED2&0xfb;
	}
		if(S4==2)
	{
		Y4;P0=LED2&0xf7;
	}
		if(S4==3)
	{
		Y4;P0=LED2&0xef;
	}

	
}
void main()
{
	Init();
	Timer1Init();
	Timer_count();
	temp_vcc1=ER_read(0x00);
	temp_HZ1=ER_read(0x01)*10000+ER_read(0x02)*1000+ER_read(0x03)*100+ER_read(0x04)*10+ER_read(0x05);
	while(1)
	{
		duli_Scanf();
		Key_gn();
		if(led_kg==1)
		{
			LED_gn();
		}
		else{
			Y4;P0=0xff;
		}
		
	}
	
}

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值