当前位置:首页 > 单片机 > 单片机
[导读]这一节,介绍如何利用DATA寄存器检测引脚上的高低电平变化。新建一个工程,结构如下图所示:在main.c文件中,输入以下代码:#include “LPC11XX.H”#define LED1_ON LPC_GPIO1->DATA &= ~(1

这一节,介绍如何利用DATA寄存器检测引脚上的高低电平变化。

新建一个工程,结构如下图所示:

在main.c文件中,输入以下代码:

#include “LPC11XX.H”

#define LED1_ON LPC_GPIO1->DATA &= ~(1<<0)

#define LED1_OFF LPC_GPIO1->DATA |= (1<<0)

#define LED2_ON LPC_GPIO1->DATA &= ~(1<<1)

#define LED2_OFF LPC_GPIO1->DATA |= (1<<1)

#define KEY1_DOWN (LPC_GPIO1->DATA&(1<<9))!=(1<<9)

#define KEY2_DOWN (LPC_GPIO1->DATA&(1<<10))!=(1<<10)

#define KEY3_DOWN (LPC_GPIO1->DATA&(1<<4))!=(1<<4)

#define KEY4_DOWN (LPC_GPIO1->DATA&(1<<10))!=(1<<10)

void delay()

{

uint16_t i,j;

for(i=0;i<5000;i++)

for(j=0;j<10;j++);

}

void led_init()

{

LPC_SYSCON->SYSAHBCLKCTRL |= (1<<16); // 使能IOCON时钟

LPC_IOCON->R_PIO1_0 &= ~0x07;

LPC_IOCON->R_PIO1_0 |= 0x01; //把P1.0脚设置为GPIO

LPC_IOCON->R_PIO1_1 &= ~0x07;

LPC_IOCON->R_PIO1_1 |= 0x01; //把P1.1脚设置为GPIO

LPC_SYSCON->SYSAHBCLKCTRL &= ~(1<<16); // 禁能IOCON时钟

LPC_GPIO1->DIR |= (1<<0); // 把P1.0设置为输出引脚

LPC_GPIO1->DATA |= (1<<0); // 把P1.0设置为高电平

LPC_GPIO1->DIR |= (1<<1); // 把P1.1设置为输出引脚

LPC_GPIO1->DATA |= (1<<1); // 把P1.1设置为高电平

}

int main()

{

led_init();

while(1)

{

if(KEY1_DOWN) // 如果按下了KEY1键

{

delay(); // 延时消抖

if(KEY1_DOWN) // 再次判断是否按下了KEY1键

{

LED1_ON;

while(KEY1_DOWN); // 如果KEY1一直按着不放,程序停留在此处

LED1_OFF;

}

}

if(KEY2_DOWN) // 如果按下了KEY2键

{

delay(); // 延时消抖

if(KEY2_DOWN) // 再次判断是否按下了KEY2键

{

LED2_ON;

while(KEY2_DOWN); // 如果KEY2一直按着不放,程序停留在此处

LED2_OFF;

}

}

}

}

关于LED部分的代码解释,请看上一节。

第6~9行,按键1和按键2的宏定义,读取P1.9和P1.10引脚上的电平。

例如,读取P1.0引脚的电平:(LPC_GPIO1->DATA&(1<<9))!=(1<<9)

这条语句的思想是,给DATA寄存器bit9“与”1,如果bit9变为0,说明此位在没有“与”之前为0,即低电平;如果bit9还是1,说明是高电平。这样,即可判断按键有无按下。

在main函数中,没有对按键的初始化,是因为P1.9和P1.10引脚在默认的情况下就是GPIO,而且是输入功能。


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除( 邮箱:macysun@21ic.com )。
换一批
延伸阅读
关闭