//4*4键盘检测程序,按下键后相应的代码显示在数码管上
#include<reg51.h>
sbit beep=P2^3
sbit dula=P2^6
sbit wela=P2^7
unsigned char i=100
unsigned char j,k,temp,key
void delay(unsigned char i)
{
for(j=ij>0j--)
for(k=125k>0k--)
}
unsigned char code table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,
0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71}
display(unsigned char num)
{
P0=table[num]
dula=1
dula=0
P0=0xc0
wela=1
wela=0
}
void main()
{
dula=0
wela=0
while(1)
{
P3=0xfe
temp=P3
temp=temp&0xf0
if(temp!=0xf0)
{
delay(10)
if(temp!=0xf0)
{
temp=P3
switch(temp)
{
case 0xee:
key=0
break
case 0xde:
key=1
break
case 0xbe:
key=2
break
case 0x7e:
key=3
break
}
while(temp!=0xf0)
{
temp=P3
temp=temp&0xf0
beep=0
}
beep=1
display(key)
P1=0xfe
}
}
P3=0xfd
temp=P3
temp=temp&0xf0
if(temp!=0xf0)
{
delay(10)
if(temp!=0xf0)
{
temp=P3
switch(temp)
{
case 0xed:
key=4
break
case 0xdd:
key=5
break
case 0xbd:
key=6
break
case 0x7d:
key=7
break
}
while(temp!=0xf0)
{
temp=P3
temp=temp&0xf0
beep=0
}
beep=1
display(key)
}
}
P3=0xfb
temp=P3
temp=temp&0xf0
if(temp!=0xf0)
{
delay(10)
if(temp!=0xf0)
{
temp=P3
switch(temp)
{
case 0xeb:
key=8
break
case 0xdb:
key=9
break
case 0xbb:
key=10
break
case 0x7b:
key=11
break
}
while(temp!=0xf0)
{
temp=P3
temp=temp&0xf0
beep=0
}
beep=1
display(key)
}
}
P3=0xf7
temp=P3
temp=temp&0xf0
if(temp!=0xf0)
{
delay(10)
if(temp!=0xf0)
{
temp=P3
switch(temp)
{
case 0xe7:
key=12
break
case 0xd7:
key=13
break
case 0xb7:
key=14
break
case 0x77:
key=15
break
}
while(temp!=0xf0)
{
temp=P3
temp=temp&0xf0
beep=0
}
beep=1
display(key)
}
}
}
}
键盘为4*4矩阵式连接,一共有16个按键。 工作原理为。P1端的低四位为列,高四位行。所先置低四位为低,高四位为高,当有按键按下时高四位就会有某位被拉低。只要判断高四位不为全高就说明有按键按下。判断有按键按下后就要判断是某位按下的,方法为,选将高四位的某一位置低。判断低四位是否有低电平出现。依次对高四位的每位置低并判断低四位出现的低电平。如高四位某位置低后低四某也有出现低电平。这样就能判断出低四位与高四位相连的位某位按键被按下了。通过定义好的编码就可以查出是某个按键被按下了,程序将按键值通过查表并发送到LED上显示。 6位LED为动态扫描方式 。先显示第一位,延时一定时间后在显示第二位依次类推。。。 共有17个按键。按下按键后数码管显示相应的数字,并左移一位。uchar kbscan(void) /*键扫描函数*/{uchar j uchar sccode,recode P2=0x0f /*发0行扫描码*/ if((P2 &0x0f)!= 0x0f) /*若有键按下*/ { dlms() if((P2&0x0f)!= 0x0f) /*逐行扫描初值*/ { sccode=0xfe for(j=4j>0j--){ while((sccode&0x10)!=0){ P2=sccode /*输出行扫描码*/ if((P2&0xf0)!=0xf0) /*本行有键按下*/ { recode=(P2&0xf0)|0x0freturn((~sccode)+(~recode)) /*返回特征字节码*/ } elsesccode=(sccode<<1)|0x01 /*行扫描码做移一位*/ } } } }return(0) /*无键按下,返回0值*/}参考链接: http://www.picavr.com/news/2008-07/6869.htm接口:FactorialImp抽象类:FactorialAbs实现计算阶乘n!的类:Fatorial代码:/** * * 阶乘计算器 * * 接口 */public interface FactorialImp {// 计算阶乘n!的值long factorial(int n)}/** * * 阶乘计算器 * * 抽象类 继承 FactorialImp */public abstract class FactorialAbs implements FactorialImp {/** * 实现计算阶乘n!的值的方法 */public long factorial(int n) {return multiplicationCount(n, n - 1)}/** * 增加抽象方法--计算两数相乘 * * @param param1Int * @param param2Int * @return 两数相乘的积 */abstract long multiplicationCount(long param1Int, long param2Int)}/** * 实现阶乘计算器类 * */public class Fatorial extends FactorialAbs {@Overridelong multiplicationCount(long param1Int, long param2Int) {if (param2Int == 1) {return param1Int} else {return multiplicationCount(param1Int * param2Int, param2Int - 1)}}}/** * 测试类 * */public class Test {public static void main(String[] args) {Fatorial localFatorial = new Fatorial()System.out.println("100! = " + localFatorial.factorial(10))}}欢迎分享,转载请注明来源:内存溢出
评论列表(0条)