蓝桥杯——定时扫描独立按键

一、原理部分

和定时扫描矩阵按键差不多的原理,只不过跳线帽连接2和3。不明白的可以看这篇博客。
定时扫描矩阵

二、代码部分

实验平台:CT107D
实验芯片:stc15f2k60s2
实验现象:S7打开蜂鸣器,S6关闭蜂鸣器,S5打开继电器,S4关闭继电器
代码如下(这里使用了标志位控制蜂鸣器和继电器)

#include<stc15f2k60s2.h>

#define uchar unsigned char
#define uint unsigned int

sbit buzz = P0^6;
sbit relay = P0^4;

bit buzz_flag = 0;
bit relay_flag = 0;

sbit key_in1 = P3^0;
sbit key_in2 = P3^1;
sbit key_in3 = P3^2;
sbit key_in4 = P3^3;

uchar keysta[] = {1,1,1,1};
uchar kaymap[] = {1,2,3,4};
//uchar code duan[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x00};//定义段码数组
//uchar disbuff[8];//定义显示数字数字


void set_buzz()
{
	if(buzz_flag == 0)
	{
		P2 = P2&0x1f|0xa0;
		buzz = 0;
		P2 = P2&0x1f;
	}

	if(buzz_flag == 1)
	{
		P2 = P2&0x1f|0xa0;
		buzz = 1;
		P2 = P2&0x1f;
	}
}

void set_relay()
{
	if(relay_flag == 0)
	{
		P2 = P2&0x1f|0xa0;
		relay = 0;
		P2 = P2&0x1f;
	}

	if(relay_flag == 1)
	{
		P2 = P2&0x1f|0xa0;
		relay = 1;
		P2 = P2&0x1f;
	}
}

void keyscan()
{
	static uchar keybuff[]={0xff,0xff,0xff,0xff};
	uchar j;

	keybuff[0] = keybuff[0]<<1|key_in1;	
	keybuff[1] = keybuff[1]<<1|key_in2;
	keybuff[2] = keybuff[2]<<1|key_in3;
	keybuff[3] = keybuff[3]<<1|key_in4;

	for(j=0;j<4;j++)
	{
		if((keybuff[j]&0x0f) == 0x00)
		{
			 keysta[j]=0;
		}
		
		else if((keybuff[j]&0x0f) == 0x0f)
		{
			 keysta[j]=1;
		}	
	}
}

void keyfun(uchar key_value)
{
	switch(key_value)
	{
		case 1:buzz_flag=1;break;
		case 2:buzz_flag=0;break;
		case 3:relay_flag=1;break;
		case 4:relay_flag=0;break;
	}
}

void keydrive()
{
	static uchar keyback[]={1,1,1,1};
	uchar i;
	for(i=0;i<4;i++)
	{
		if(keysta[i]!=keyback[i])
		{
			if(keysta[i] != 0)
			{
				keyfun(kaymap[i]);
			}
			keyback[i]=	keysta[i];
		}		
	}
}

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

void time0() interrupt 1
{
	 keyscan();
}

void main()
{
	Timer0Init();
	while(1)
	{
		set_buzz();
		set_relay();
		keydrive();
	}
}


在Java中,带分数可以用分数类来表示。下面是一个简单的带分数类的实现: ```java public class Fraction { private int integer; private int numerator; private int denominator; public Fraction(int integer, int numerator, int denominator) { this.integer = integer; this.numerator = numerator; this.denominator = denominator; simplify(); } private void simplify() { if (numerator < 0 && denominator < 0) { numerator = -numerator; denominator = -denominator; } if (denominator < 0) { numerator = -numerator; denominator = -denominator; } if (integer < 0 && numerator > 0) { numerator = -numerator; } if (integer < 0 && numerator == 0) { integer = -integer; } if (numerator >= denominator) { integer += numerator / denominator; numerator = numerator % denominator; } int gcd = gcd(numerator, denominator); numerator /= gcd; denominator /= gcd; } private int gcd(int a, int b) { if (b == 0) { return a; } return gcd(b, a % b); } public Fraction add(Fraction other) { int newNumerator = this.numerator * other.denominator + other.numerator * this.denominator; int newDenominator = this.denominator * other.denominator; int newInteger = this.integer + other.integer; return new Fraction(newInteger, newNumerator, newDenominator); } public String toString() { if (integer == 0 && numerator == 0) { return "0"; } String result = ""; if (integer != 0) { result += integer; if (numerator != 0) { result += "_"; } } if (numerator != 0) { result += numerator + "/" + denominator; } return result; } } ``` 这个带分数类实现了以下功能: - 构造函数可以根据整数部分、分子和分母创建一个带分数对象。 - simplify() 方法可以将带分数对象化简,如将负号移到分子上、将整数部分和真分数部分合并、将分数化简等。 - add() 方法可以将两个带分数对象相加,返回一个新的带分数对象。 - toString() 方法可以将带分数对象转换为字符串形。 这个类实现了带分数的加法操作,可以参考这个类来实现其他的运算操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

天地神仙

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值