编辑:[db:作者] 时间:2024-08-25 08:17:55
(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\公众;
}
}
本站所发布的文字与图片素材为非商业目的改编或整理,版权归原作者所有,如侵权或涉及违法,请联系我们删除,如需转载请保留原文地址:http://www.baanla.com/xyj/192202.html
Copyright 2005-20203 www.baidu.com 版权所有 | 琼ICP备2023011765号-4 | 统计代码
声明:本站所有内容均只可用于学习参考,信息与图片素材来源于互联网,如内容侵权与违规,请与本站联系,将在三个工作日内处理,联系邮箱:123456789@qq.com