相关文章

数字旋转编码开关的原理及使用方法

导读: 在电子产品设计中,经常会用到旋转编码开关,比如数码电位器等,它的英文名翻译过来就是Rotary Encoder Switch。在写这个元件的驱动程序之前,我google、baidu了一些它的使用说明资料,知道了它具有左转、右转和按下三个功能,有五个脚...

        在电子产品设计中,经常会用到旋转编码开关,比如数码电位器等,它的英文名翻译过来就是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";    }}