在此,百位只接两根用来显示百位的1,十位和个位除小数点位各需要7根。本文介绍如何配置和使用这16个GPIO。
先上代码:
const unsigned char led[] = {
0x3f,/* 0 */
0x06,/* 1 */
0x5b,/* 2 */
0x4f,/* 3 */
0x66,/* 4 */
0x6d,/* 5 */
0x7d,/* 6 */
0x07,/* 7 */
0x7f,/* 8 */
0x6f /* 9 */
};
struct digit obj[DIGIT_MAX] =
{
{0, D3a, D3b, D3c, D3d, D3e, D3f, D3g},
{0, D2a, D2b, D2c, D2d, D2e, D2f, D2g }
};
/* the number ranges from 0 to 199 */
void show_number(uint8_t number)
{
volatile uint8_t i, j;
obj[0].value = led[number % 10];
if(number < 10)
{
obj[1].value = 0x00;
R_BSP_PinWrite(D1b, 1);
R_BSP_PinWrite(D1c, 1);
}
else if(number < 100)
{
number /= 10;
obj[1].value = led[number % 10];
R_BSP_PinWrite(D1b, 1);
R_BSP_PinWrite(D1c, 1);
}
else if(number < 200)
{
number /= 10;
obj[1].value = led[number % 10];
R_BSP_PinWrite(D1b, 0);
R_BSP_PinWrite(D1c, 0);
}
else
{
obj[0].value = 0x40;
obj[1].value = 0x40;
R_BSP_PinWrite(D1b, 1);
R_BSP_PinWrite(D1c, 1);
}
for(i=0; i< DIGIT_MAX; i++)
{
for(j=0; j< 7; j++)
{
R_BSP_PinWrite((bsp_io_port_pin_t) obj[i].pin[j], ~(obj[i].value >> j) & 0x01);
}
}
}
管脚名使用应用的名称,那怎么和实际的管脚对应呢?
依次,在配置菜单中,将要用到的所有管脚定义下别名,然后重新自动生成代码:
优点是:
当需要更换管脚时,我们的代码一行不用动,只要去配置界面重新配置下新的管脚,重新生成即可。
而且还能自动生成注释!
缺点是:
这个路径好奇怪啊,找了好久。
引用的时候也不好引用。
编译工具不会自动搜索该文件。
总结:入门时摸索了好久,IDE缺乏必要的提示,不过熟悉以后还是挺好用的。