数字旋转编码开关的原理及使用方法
在电子产品设计中,经常会用到旋转编码开关,比如数码电位器等,它的英文名翻译过来就是Rotary Encoder Switch。在写这个元件的驱动程序之前,我google、baidu了一些它的使用说明资料,知道了它具有左转、右转和按下三个功能,有五个脚,它的外形如下图所示:
(1)1、3脚要外接上拉电阻,一般10K就足矣;
(2)2脚一般接地就行;
(3)4、5脚是下按键的开关接线(按下时,4脚为低电平);
我调试这个元件时的实物接线示意图为:
其实它使用起来并不难,我看到网上的资料大都说操作它时判断正转和反转是一个难点,在这里我希望博友在看了我的代码后会觉得这其实只是一个“传说”!我的代码会把这个问题说的清清楚楚、简简单单的!我觉得其实判断正转和反转的关键就是:当BMA为低电平时,BMB的跳变沿是怎样的——上升沿表示正转,下降沿表示反转。只要用代码把这个描述清楚就OK了,这个器件就基本可以顺利地操作了。
没有多余的再说了,直接附上代码:
#include #define uchar unsigned char #define uint unsigned int sbit BMA=P1^4; sbit BMB=P1^5; sbit BMC=P1^6; sbit P27=P2^7; sbit P26=P2^6; sbit P25=P2^5; uchar code table[]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90}; uchar count=0; uchar flag; uchar Last_BMB_status; uchar Current_BMB_status; //************************************************ void delay(uchar z) //大约1ms的延时 { uchar x,y; for(x=z;x>0;x--) for(y=110;y>0;y--); } //************************************************ void display() //显示子程序 { P0=table[count%10]; //个位 P27=0; delay(10); P27=1; P0=table[count%100/10]; //十位 P26=0; delay(10); P26=1; P0=table[count/100]; //百位 P25=0; delay(10); P25=1; } //************************************************ void main() { TMOD=\"0x01\"; //定时器0,工作方式1 TH0=0xD8; TL0=0xF0; //给定时器装上初值,10ms中断一次 ET0=1; //打开定时器中断 EA =1; //打开总中断 TR0=1; //启动定时器0 while(1) { Last_BMB_status=BMB; while(!BMA) //BMA为低电平时 { Current_BMB_status=BMB; flag=\"1\"; //标志位置为1说明编码开关被旋转了 } if(flag==1) { flag=\"0\"; //时刻要注意这一点!给标志位清零 if((Last_BMB_status==0)&&(Current_BMB_status==1)) //BMB上升沿表示正转 { count++; if(count==255) { count=\"0\"; } } if((Last_BMB_status==1)&&(Current_BMB_status==0)) //BMB下降沿表示反转 { count--; if(count==0) { count=\"255\"; } } } } } //************************************************ void timer0() interrupt 1 //定时器0的中断服务程序 { TH0=0xD8; TL0=0xF0; //再次装入初值 display(); //每隔10ms显示一次 if(!BMC) //按下旋转编码开关则计数清零 { count=\"0\"; } } 因篇幅问题不能全部显示,请点此查看更多更全内容