但是我们知道,除了C51提供位操作为,其他单片机并不提供位操作的定义方式,但是,基本上所有的编译器都提供位段的定义方式,所以下面我们将使用位段进行定义:

由原理图和液晶资料我们可以看出,Seg0对应第一个数码管的F、G、E三段,Seg1对应第一个数码管的A、B、C、D四段。而第二个数码管和第三个数码 管的每一段顺序与第一个相同。所以,我们可以使用与第一个数码管相同的结构体进行三个数码管的定义,当然有时候每个数码管的每一段顺序并不一定相同,这个 是由段式液晶在设计时的走线确定的。如果每一个数码的顺序不同,我们就得分别定义其结构体了。

typedef union

{

struct

{

u8 DA   : 1;         //

u8 DB   : 1;         //

u8 DC   : 1;         //

u8 DD   : 1;         //

u8 Rcv  : 4;         //

} BtL;

struct

{                                 //

u8 DF   : 1;         //

u8 DG   : 1;

u8 DE   : 1;         //

u8 DO   : 1;         //

u8 Rcv  : 4;         //

} BtH;

} HTB_SEG;

在这里,我们把同一个数码管的7段定义在一个结构体中,如果使用F、G、E三个段式,我们使用BtH这个变量,如果使用A、B、C、D四段时,我们使用 BtL这个变量。当然,我们也可以把这两个分开定义。由于第二个数码管多了个冒号,同样把其放入BtH变量中,第一个和第三个数码管中没有使用这个位,不 用即可。

typedef union

{

struct

{

u8 K1   : 1;         //

u8 K2   : 1;         //

u8 K3   : 1;         //

u8 Rcv  : 5;         //

} BtL;

struct

{

u8 K7   : 1;         //

u8 K6   : 1;         //

u8 K5   : 1;         //

u8 K4   : 1;         //

u8 Rcv  : 4;         //

} BtH;

} HTB_ICN;

用同样的方法定义剩余的图标,获得上面的结构体。由此我们看出,每个寄存器实际上只使用了前面4个位,后面的4个位没有使用,保留。

typedef struct

{

HTB_SEG Seg0;

HTB_SEG Seg1;

HTB_SEG Seg2;

HTB_SEG Seg3;

HTB_SEG Seg4;

HTB_SEG Seg5;

HTB_ICN Seg6;

HTB_ICN Seg7;

} HTB_RAM;

HTB_RAM HTBRam;

最后我们把使用的8个寄存器分别使用上面的结构体变量进行定义,前面6个为数码管,后面2个为图标。有了这个结构体,后面定义一个变量用于操作每个数码管。

数码管显示驱动如下,从0~9通过控制每一段形成字符:

/**************************************************************************************

* FunctionName   : HTB_SegVal()

* Description    : 数码管填值

* EntryParameter : None

* ReturnValue    : None

**************************************************************************************/

void HTB_SegVal(HTB_SEG *pSg1, HTB_SEG *pSg2, u8 dat)

{

switch (dat)

{

case 0:  pSg2->BtL.DA = 1; pSg2->BtL.DB = 1; pSg2->BtL.DC = 1; pSg2->BtL.DD = 1;

pSg1->BtH.DE = 1; pSg1->BtH.DF = 1; pSg1->BtH.DG = 0; break;

case 1:  pSg2->BtL.DA = 0; pSg2->BtL.DB = 1; pSg2->BtL.DC = 1; pSg2->BtL.DD = 0;

pSg1->BtH.DE = 0; pSg1->BtH.DF = 0; pSg1->BtH.DG = 0; break;

case 2:  pSg2->BtL.DA = 1; pSg2->BtL.DB = 1; pSg2->BtL.DC = 0; pSg2->BtL.DD = 1;

pSg1->BtH.DE = 1; pSg1->BtH.DF = 0; pSg1->BtH.DG = 1; break;

case 3:  pSg2->BtL.DA = 1; pSg2->BtL.DB = 1; pSg2->BtL.DC = 1; pSg2->BtL.DD = 1;

pSg1->BtH.DE = 0; pSg1->BtH.DF = 0; pSg1->BtH.DG = 1; break;

case 4:  pSg2->BtL.DA = 0; pSg2->BtL.DB = 1; pSg2->BtL.DC = 1; pSg2->BtL.DD = 0;

pSg1->BtH.DE = 0; pSg1->BtH.DF = 1; pSg1->BtH.DG = 1; break;

case 5:  pSg2->BtL.DA = 1; pSg2->BtL.DB = 0; pSg2->BtL.DC = 1; pSg2->BtL.DD = 1;

pSg1->BtH.DE = 0; pSg1->BtH.DF = 1; pSg1->BtH.DG = 1; break;

case 6:  pSg2->BtL.DA = 1; pSg2->BtL.DB = 0; pSg2->BtL.DC = 1; pSg2->BtL.DD = 1;

pSg1->BtH.DE = 1; pSg1->BtH.DF = 1; pSg1->BtH.DG = 1; break;

case 7:  pSg2->BtL.DA = 1; pSg2->BtL.DB = 1; pSg2->BtL.DC = 1; pSg2->BtL.DD = 0;

pSg1->BtH.DE = 0; pSg1->BtH.DF = 0; pSg1->BtH.DG = 0; break;

case 8:  pSg2->BtL.DA = 1; pSg2->BtL.DB = 1; pSg2->BtL.DC = 1; pSg2->BtL.DD = 1;

pSg1->BtH.DE = 1; pSg1->BtH.DF = 1; pSg1->BtH.DG = 1; break;

case 9:  pSg2->BtL.DA = 1; pSg2->BtL.DB = 1; pSg2->BtL.DC = 1; pSg2->BtL.DD = 1;

pSg1->BtH.DE = 0; pSg1->BtH.DF = 1; pSg1->BtH.DG = 1; break;

case 0:  pSg2->BtL.DA = 0; pSg2->BtL.DB = 0; pSg2->BtL.DC = 0; pSg2->BtL.DD = 0;

pSg1->BtH.DE = 0; pSg1->BtH.DF = 0; pSg1->BtH.DG = 0; break;

default:break;

}

}

/**************************************************************************************

* FunctionName   : HTBColon()

* Description    : 冒号

* EntryParameter : None

* ReturnValue    : None

**************************************************************************************/

void HTBColon(OS_SWT swt)

{

HTBRam.Seg2.BtH.DO = (swt > 0) ? 1 : 0;

}

/**************************************************************************************

* FunctionName   : HTBTemStl()

* Description    : 温度

* EntryParameter : None

* ReturnValue    : None

**************************************************************************************/

void HTBTemStl(u8 stl)

{

HTBRam.Seg7.BtH.K4 = 0;

HTBRam.Seg7.BtH.K5 = 0;

HTBRam.Seg7.BtH.K6 = 0;

HTBRam.Seg7.BtH.K7 = 0;

switch (stl)

{

case 0: HTBRam.Seg7.BtH.K4 = 1; break;

case 1: HTBRam.Seg7.BtH.K5 = 1; break;

case 2: HTBRam.Seg7.BtH.K6 = 1; break;

case 3: HTBRam.Seg7.BtH.K7 = 1; break;

default : break;

}

}

/**************************************************************************************

* FunctionName   : HTBWndStl()

* Description    : 风速

* EntryParameter : None

* ReturnValue    : None

**************************************************************************************/

void HTBWndStl(u8 stl)

{

HTBRam.Seg6.BtL.K1 = 0;

HTBRam.Seg6.BtL.K2 = 0;

HTBRam.Seg6.BtL.K3 = 0;

switch (stl)

{

case 0: HTBRam.Seg6.BtL.K3 = 1; break;

case 1: HTBRam.Seg6.BtL.K2 = 1; break;

case 2: HTBRam.Seg6.BtL.K1 = 1; break;

default : break;

}

}

图标的驱动如上,其实就是根据需要修改每一个寄存器位,这个寄存器修改后,我们还必须得传递给HT1621更新显示,才能真正实现显示的驱动:

/**************************************************************************************

* FunctionName   : HTB_SendBitMsb()

* Description    : 发送发送多位[高位在前]

* EntryParameter : None

* ReturnValue    : None

**************************************************************************************/

void HTB_SendBitMsb(u8 dat, u8 cnt)

{

for (u8 i=0; i

{

(dat & 0x80) ? GPIO_WriteHigh(HTB_DT_PORT, HTB_DT_PIN) :

GPIO_WriteLow(HTB_DT_PORT, HTB_DT_PIN);

dat <<= 1;

GPIO_WriteLow(HTB_WR_PORT, HTB_WR_PIN);

HTB_DelayUs(3);

GPIO_WriteHigh(HTB_WR_PORT, HTB_WR_PIN);

}

}

/**************************************************************************************

* FunctionName   : HTB_SendBitLsb()

* Description    : 发送多位[低位在前]

* EntryParameter : None

* ReturnValue    : None

**************************************************************************************/

void HTB_SendBitLsb(u8 dat, u8 cnt)

{

for (u8 i=0; i

{

(dat & 0x01) ? GPIO_WriteHigh(HTB_DT_PORT, HTB_DT_PIN) :

GPIO_WriteLow(HTB_DT_PORT, HTB_DT_PIN);

dat >>= 1;

GPIO_WriteLow(HTB_WR_PORT, HTB_WR_PIN);

HTB_DelayUs(3);

GPIO_WriteHigh(HTB_WR_PORT, HTB_WR_PIN);

}

}

/**************************************************************************************

* FunctionName   : HTB_SendCmd()

* Description    : 发送命令

* EntryParameter : None

* ReturnValue    : None

**************************************************************************************/

void HTB_SendCmd(u8 cmd)

{

GPIO_WriteLow(HTB_CS_PORT, HTB_CS_PIN);

HTB_SendBitMsb(0x80, 3);                                                     // 前面3位命令代码

HTB_SendBitMsb(cmd, 9);                                                      // 后面10位: a5~a0[RAM地址]+d3~d0[RAM数据]

GPIO_WriteHigh(HTB_CS_PORT, HTB_CS_PIN);

}

/**************************************************************************************

* FunctionName   : HTBSendNDat()

* Description    : 发送N数据

* EntryParameter : None

* ReturnValue    : None

**************************************************************************************/

void HTBSendNDat(u8 addr, u8 *pDat, u8 cnt, u8 bitNum)

{

GPIO_WriteLow(HTB_CS_PORT, HTB_CS_PIN);

HTB_SendBitMsb(0xA0, 3);                                                    // 前面3位命令代码

HTB_SendBitMsb(addr<<2, 6);                                                 // a5~a0[RAM地址]

for (u8 i=0; i

{

HTB_SendBitLsb(*pDat++, bitNum);                                        // RAM数据

}

GPIO_WriteHigh(HTB_CS_PORT, HTB_CS_PIN);

}

上面的函数是通过按位传递的方式把数据发给HT1621,并不复杂,这里就不相信介绍了:

typedef enum

{

HTB_CMD_BIAS   = 0x29,                                         // 0B:0010 abXc  -ab控制占空比,-c控制偏压

HTB_CMD_SYSEN  = 0x01,                                         //

HTB_CMD_LCDOFF = 0x02,                                         //

HTB_CMD_LCDON  = 0x03,                                         //

} HTB_CMD;

最后,我们可以看出,在修改了全局变量后,在把更新的数据传递给驱动芯片就可以了,非常简单方便灵活,这个示例让我们充分了解和使用位段进行位控制是非常方便。

ht1621b和单片机电平匹配_基于HT1621B段式液晶模块的驱动应用相关推荐

  1. ht1621b和单片机电平匹配_基于单片机的HT1621液晶显示系统设计

    耗电子产品中被广泛选用. 2 硬件电路设计 考虑到单片机的外围扩展电路尽可能少,硬件结构越简单越好.如果液晶显示器的8位数据线与单片机采用并行接口的话,数据线就占用了8位,再加上其他的一些控制线,将占 ...

  2. ht1621b和单片机电平匹配_有备无患,单片机面试问题集

    点击箭头处 "蓝色字" ,关注我们哦!! 这十八个经典问答,讲透了RS485接口! 模拟技术之传感器电路实例讲解 三种单片机对比:51系列.PIC和AVR 几个单片机汇编语言教学例 ...

  3. ht1621b和单片机电平匹配_上一个HT1621B的驱动程序!绝对原创啊!

    HT1621B作为一片便宜的LCD驱动器,真是不错!控制也很方便!这是我产品上用的一个分支程序!希望对大家有用! 觉得有用就顶一下啊!谢谢! 下面是我的程序:注释个人觉得很清晰! #define uc ...

  4. ht1621b和单片机电平匹配_关于ht1621的使用和初始化....

    由于是初次接触这个..所以有很多东西不是很懂: 1.首先是ht1621的初始化,给一个高电平脉冲,指的是CS端直接置1,还是先置0,再置1: 2.ht1621的数据传输时(比如写的模式),在WR由高电 ...

  5. ht1621b和单片机电平匹配_HT1621B驱动液晶LCD连接及程序

    (2014-03-04 12:11:47) 转 载 ▼ 标签: ht1621 ht1621b stm8s ht1621 驱动 lcd 程序 分类: 单片机 最近需要把 AD 转换的数据显示出来,因为手 ...

  6. ht1621b和单片机电平匹配_HT1621B驱动段码液晶屏参考程序——晶拓液晶屏

    (1)    段码屏的驱动程序跟数码管的静态驱动程序一样,只要我们弄懂了怎样显示一个基本单位,根据此基本单位编写一个字库表,然后   用与(&)和或(|)这两种位运算符就可以随心所欲编写我们要 ...

  7. ht1621b和单片机电平匹配_HT1621B读数据问题 - Microchip论坛 - PIC单片机论坛 - Microchip(微芯科技)MCU官方技术支持论坛 - 中国电子网技术论坛...

    /*****ht1621写字节函数*****/ void sendbit(unsigned char data,unsigned char cnt)//data的高cnt位写入,高位在前 { unsi ...

  8. ht1621b和单片机电平匹配_51单片机对HT1621 LCD 控制器的使用

    51 单片机对 HT1621 LCD 控制器的使用 HT1621 是一款 128 个位元的 LCD 控制器件,内部 RAM 直接对应 LCD 的显示单元.相应 的软件使它适用于包括 LCD 模块和显示 ...

  9. ht1621b和单片机电平匹配_STM32液晶显示HT1621驱动原理及程序代码

    1 unsigned char Lcdram[32]= 2 {3 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,4 0x00,0x00,0x00,0x00,0x00, ...

最新文章

  1. Nginx的rewrite之rewrite_log指令
  2. 硅谷历史_使其新颖:硅谷设计的历史
  3. Getmemory函数详解--内存操作的理解
  4. Hbase table DDL操作及scala API操作
  5. 十分钟完成的操作系统编写 你信吗?
  6. for (;;) 与 while (true),哪个更快?
  7. win10 安装 framework3.5
  8. springboot+Vue在线考试系统
  9. YonBIP—助力企业数字化转型之道
  10. 网站编辑,你们的名字叫搬运工?
  11. 小于n的最大素数python_求m下n个最大素数
  12. 修改bounds属性后的效果
  13. CRM-如何获取客户
  14. openstack kolla 安装报错
  15. PTA|团队程序设计天梯赛-练习集题解(L1)
  16. 解决win10部分程序文本乱码,亲测有效
  17. Word中设置论文参考文献对齐方法
  18. google浏览器 使用css: transform造成字体模糊问题
  19. 【C语言】求一个四位整数各位数字之和
  20. prototype.js详解

热门文章

  1. Duplicate property mapping of contactPhone found in
  2. hdu 3631 Shortest Path(Floyd)
  3. 加速度传感器与车祸报警解决方案
  4. ifttt.com:让你的网络行为能引发连锁反应
  5. javascript小技巧 JavaScript[对象.属性]集锦 [zz]
  6. linux软件包管理 pdf,中标麒麟Linux系统软件包管理介绍(22页)-原创力文档
  7. php ci is numeric,CI继承类MY_Model
  8. 向日葵linux 用电脑远程控制与管理,远程控制软件向日葵和teamviewer的区别和使用...
  9. 操作系统时间片轮换_操作系统   时间片轮转法
  10. Linux关闭java命令,Linux系统关闭或重新启动主机的命令详解