MCU是STM8S207

/*LED 字模结构*/
typedef struct
{
char mChar;
u8 mModal;
}LED_MODAL_DEFINE; typedef struct
{
u8 Addr;
u8 Ddat;
} LED_ICON_DEFINE;
#define ht1621_BIAS 0x52
#define ht1621_SYSEN 0x02
#define ht1621_LCDOFF 0x04
#define ht1621_LCDON 0x06
#define ht1621_RC256 0X30
#define ht1621_SYSDIS 0X00
#define ht1621_WDTDIS 0X0A
#define ht1621_BLON 0x12
#define ht1621_BLOFF 0x10 #undef LED_WIDTH
#define LED_WIDTH 6 #define PIN_HT1621_CS ht_cs
#define PIN_HT1621_WR ht_wr
#define PIN_HT1621_DAT ht_data #define HT1621_SET_CS(value) GPIOEX_BitWrite(PIN_HT1621_CS,value)
#define HT1621_SET_WR(value) GPIOEX_BitWrite(PIN_HT1621_WR,value)
#define HT1621_SET_DAT(value) GPIOEX_BitWrite(PIN_HT1621_DAT,value) /*常用的LED字模定义,需要扩充的自己增加数组*/
const LED_MODAL_DEFINE LED_MODAL[]={
{' ',0x00} ,
{'',0xf5} ,
{'',0x05} ,
{'',0xb6} ,
{'',0x97} ,
{'',0x47} ,
{'',0xd3} ,
{'',0xf3} ,
{'',0x85} ,
{'',0xf7} ,
{'',0xd7} ,
{'A',0xe7} ,
{'b',0x73} ,
{'C',0xf0} ,
{'E',0xf2} ,
{'F',0xe2} ,
{'H',0x67} ,
{'L',0x70} ,
{'n',0xe5} ,
{'U',0x75} ,
{'O',0xf5} ,
{'-',0x02} ,
{'I',0x60} ,
{'q',0xc7} ,
{'d',0x37} ,
{'S',0Xd3} ,
{'y',0x57} ,
{'t',0x72} ,
{'r',0x22} ,
{'j',0x15} ,
{'P',0xe6} ,
}; const LED_ICON_DEFINE ICON_DEFINE[] =
{
{,0x0},
{,0x8},
{,0x8},
{,0x8},
{,0x8},
{,0x8},
{,0x8},
{,0x40},
{,0x20},
{,0x4},
{,0x2},
{,0x40},
{,0x2},
{,0x4},
{,0x80},
{,0x8},
{,0x20},
{,0x80},
{,0x8},
}; static char led_content[LED_WIDTH*+]; //显示内容 考虑小数点的问题,内容长度为LED宽度×2
static u8 led_len;
u8 led_disp_mem[];
u8 led_prev_disp_mem[];
static _eCM led_prev_icon[];
static char _l_prev_blink[];
extern char _l_blink_state[]; /*取字符对应的字模参数:iValue 需要取模的字符 区分大小写*/
static u8 LED_GetModal(char iValue)
{
u8 i;
for (i=;i<sizeof(LED_MODAL)/sizeof(LED_MODAL[]);i++)
{
if (iValue == LED_MODAL[i].mChar)
{
return LED_MODAL[i].mModal;
}
}
return ;
} /*将内容写入显示设备参数:bGlint 需要闪烁的部分是否显示*/
void LED_DisplayToDevice()
{
u8 i = ;
u8 pos = ;
u8 value = ;
u8 mode[LED_WIDTH];
u8 dispMemAddr[] = {,,,,,};
memset(mode,,sizeof(mode));
for (i=;i<led_len;)
{
//取字模
value=LED_GetModal(led_content[i++]);
//小数点和前面的字符结合成一个字符
if (led_content[i]=='.')
{
i++;
}
// if (_l_blink_state[i] == 0)
// value = LED_GetModal(' '); mode[pos++]=value;
if (pos>LED_WIDTH-)
break;
} //
for (i=; i<pos; i++)
{
if (_l_blink_state[i] == )
led_disp_mem[dispMemAddr[i]] = ;
else
led_disp_mem[dispMemAddr[i]] = mode[i];
}
//
}
void WrCmd(u8 Cmd)
{
u8 data, i, CmdByte = 0x80; HT1621_SET_CS();
for (i=; i<; i++)
{
if (CmdByte&0x80)
HT1621_SET_DAT();
else
HT1621_SET_DAT();
HT1621_SET_WR();
DelayUS();
HT1621_SET_WR();
CmdByte <<= ;
} for (i=; i<; i++)
{
if (Cmd&0x80)
HT1621_SET_DAT();
else
HT1621_SET_DAT();
HT1621_SET_WR();
DelayUS();
HT1621_SET_WR();
DelayUS();
Cmd <<= ;
} HT1621_SET_CS();
} void WrAddData(u8 Add, u8 Ddat)
{
u8 i, CmdByte = 0xA0; //
led_disp_mem[Add] |= Ddat;
// HT1621_SET_CS();
for (i=; i<; i++)
{
if (CmdByte&0x80)
HT1621_SET_DAT();
else
HT1621_SET_DAT();
HT1621_SET_WR();
DelayUS();
HT1621_SET_WR();
CmdByte <<= ;
} Add <<= ;
for (i=; i<; i++)
{
if (Add&0x80)
HT1621_SET_DAT();
else
HT1621_SET_DAT();
HT1621_SET_WR();
DelayUS();
HT1621_SET_WR();
Add <<= ;
} for (i=; i<; i++)
{
if (Ddat&0x80)
HT1621_SET_DAT();
else
HT1621_SET_DAT();
HT1621_SET_WR();
DelayUS();
HT1621_SET_WR();
Ddat <<= ;
} HT1621_SET_CS();
} void HT1621Cls(void)
{
u8 i;
for (i=; i<; i+=)
{
WrAddData(i, 0x00);
} memset(led_disp_mem, , sizeof (led_disp_mem));
} void HT1621AllOn(void)
{
u8 i; for (i=; i<; i+=)
{
WrAddData(i, 0xff);
}
} void HT1621_Init()
{
_eCM cm[] = {CM_bph,CM_gw};
GPIOEX_InitIOPin(PIN_HT1621_CS, GPIO_MODE_OUT_PP_LOW_FAST);
GPIOEX_InitIOPin(PIN_HT1621_WR, GPIO_MODE_OUT_PP_LOW_FAST);
GPIOEX_InitIOPin(PIN_HT1621_DAT, GPIO_MODE_OUT_PP_LOW_FAST); GPIOEX_InitIOPin(PIN_RUNLED, GPIO_MODE_OUT_PP_LOW_FAST);
GPIOEX_BitWrite(PIN_RUNLED,); WrCmd(ht1621_BIAS);
WrCmd(ht1621_RC256);
WrCmd(ht1621_SYSEN);
WrCmd(ht1621_LCDON); HT1621Cls();
//
HC164_Init();
//
} void HT1621_ReInit()
{
GPIOEX_InitIOPin(PIN_HT1621_CS, GPIO_MODE_OUT_PP_LOW_FAST);
GPIOEX_InitIOPin(PIN_HT1621_WR, GPIO_MODE_OUT_PP_LOW_FAST);
GPIOEX_InitIOPin(PIN_HT1621_DAT, GPIO_MODE_OUT_PP_LOW_FAST);
WrCmd(ht1621_BIAS);
WrCmd(ht1621_RC256);
WrCmd(ht1621_SYSEN);
WrCmd(ht1621_LCDON);
} void HT1621_BackLight(u8 nStat)
{
if (nStat)
{
WrCmd(ht1621_BLON);
}
else
{
WrCmd(ht1621_BLOFF);
}
}

HT1621控制的段式液晶驱动程序的更多相关文章

  1. FRDM-KL43开发板驱动段式液晶SLCD的实现方法

    LCD的驱动不像LED那样,加上电压(LED实际上是电流驱动)就可以长期显示的. LCD驱动必须使用交流电压驱动才能保持稳定的显示,如果在LCD上加上稳定的直流电压, 不但不能正常显示,时间久了还会损 ...

  2. 所谓的液晶屏驱动IC是单独的IC还是在屏内就集成

    所谓的液晶屏驱动IC是单独的IC还是在屏内就集成 时间:2016-12-05    作者:admin   其实无论什么液晶屏,想要正常工作必须包括两个人:玻璃屏+驱动IC:但是现在有一些液晶厂商他们不 ...

  3. ALSA声卡12_从零编写之添加音量控制_学习笔记

    1.设置音量时应用程序的调用过程 (1)strace分析: amixer cset numid=1 30 (设置音量) /dev/snd/controlC0 open SNDRV_CTL_IOCTL_ ...

  4. Linux下PCI设备驱动程序开发 --- PCI驱动程序实现(三)

    三.PCI驱动程序实现 1. 关键数据结构 PCI设备上有三种地址空间:PCI的I/O空间.PCI的存储空间和PCI的配置空间.CPU可以访问PCI设备上的所有地址空间,其中I/O空间和存储空间提供给 ...

  5. 【DSP开发】【Linux开发】Linux下PCI设备驱动程序开发

    PCI是一种广泛采用的总线标准,它提供了许多优于其它总线标准(如EISA)的新特性,目前已经成为计算机系统中应用最为广泛,并且最为通用的总线标准.Linux的内核能较好地支持PCI总线,本文以Inte ...

  6. MSP430常见问题之LCD 显示驱动类

    Q1:晶体一般都是接32768,然后使用液晶很正常.我打算将晶体接6M的替换32768,那么液晶还能正常显示吗A1:看你所用的LCM 模块时序极限是多少HZ,然后看6M情况下,MSP430去驱动LCM ...

  7. LCD的背光及觸摸屏

    液晶的发现可追溯到19 世纪末,1888 年被奥地利植物学家发现.它是一种在一定温度范围内呈现既不同于固态.液态,又不同于气态的特殊物质态.既具有晶体所具有的各向异性造成的双折射性,又具有液体所特有的 ...

  8. 找工作---操作系统常考知识点总结【PB】

    1.进程是并发过程中程序的执行过程 2.进程的特征:结构特征.动态性.并发性.独立性.异步性 3.临界区指在每个进程中访问临界资源的那段代码 4,现在操作系统中申请资源的基本单位是进程,在CPU得到执 ...

  9. 基于basys2驱动LCDQC12864B的verilog设计图片显示

    话不多说先上图 前言 在做这个实验的时候在网上找了许多资料,都是关于使用单片机驱动LCD显示,确实用单片机驱动是要简单不少,记得在FPGA学习交流群里问问题的时候,被前辈指教,说给我最好的指教便是别在 ...

随机推荐

  1. 关于下载文件封装的两个类(Mars)

    首先是文件FileUtils.java package mars.utils; import java.io.File; import java.io.FileOutputStream; import ...

  2. where whereis locate find 的用法

    1.where :where ifconfig.用来搜索命令,显示命令是否存在以及路径在哪 2.whereis:whereis vim .用来搜索程序名,而且只搜索二进制文件(参数-b).man说明文 ...

  3. Redhat/CentOS 软件安装

    概述 软件包简介 rpm 包安装 yum 在线安装 源码包管理 软件包分类 源码包 二进制包(rpm包.系统默认包) rpm包安装 rpm包的依赖性 树形依赖: a -> b -> c 环 ...

  4. Kendo MVVM (一) 概述

    Kendo MVVM (一) 概述 Model View ViewModel (MVVM)  是开发人员经常使用的一种设计模式,以实现数据模型(Model)和视图(View)的分离.MVVM 中的 V ...

  5. MapReduce的编程思想(1)

    MapReduce的编程思想(1) MapReduce的过程(2) 1. MapReduce采用分而治之的思想,将数据处理拆分为主要的Map(映射)与Reduce(化简)两步,MapReduce操作数 ...

  6. git remote add 用法

    前一阵子,对于git remote add 的内容一直调错,现在明确一下: 这里是gitStack的用法:git remote add gitServerName http://ip/name(这里没 ...

  7. Nginx和Apache服务器上配置反向代理

    在实际项目过程中,由于网站要用到一个在线编辑器(个性化的在线编辑软件),需要跨域进行通信!由于跨域通信较多,所以当时就想到在网站服务器上代理编辑软件的请求! 这就是“反向代理”的实际需求! 一.Ngi ...

  8. 想系统化快速学习人工智能?上Azure School就够了!

    要说目前最热门的技术,非人工智能莫属了,让计算机程序能够看懂.听懂.读懂.理解我们的世界!想想就激动!! 上至高大上的个人数字化助理,下至P图软件,各种应用都开始增加AI相关的功能,试问又有哪个技术爱 ...

  9. Vector 容器简单介绍

    # Vector STL简要介绍 关于STL中的vector容器,以下做一些相关介绍. #### vector 简要概述 vector 称作向量类,属于容器类,实现了动态的数组,用于元素数量变化的对象 ...

  10. 关于tomcat的classloader的一点想法

    关于tomcat的classloader相关的帖子网上非常多,我觉得比较好的有: https://www.jianshu.com/p/d90e4430b0b9 https://blog.csdn.ne ...