前言:LiquidCrystal是一个1602的IIC库,使用IIC协议可以极大节约用线数量,十分方便。当然,前提是1602要使用LCD1602 I2C模块。

一、库函数快速查询

  1. LiquidCrystal()     //构造函数
  2. begin()                        //指定显示屏尺寸
  3. clear()                      //清屏并将光标置于左上角
  4. home()                    //将光标置于左上角(不清屏)
  5. setCursor()             //将光标置于指定位置
  6. write()                     //(在光标处)显示一个字符
  7. print()                     //显示字符串
  8. cursor()                  //显示光标(就是一个下划线)
  9. noCursor()             //不显示光标
  10. blink()                       //光标闪烁(和8,9一起使用时不保证效果)
  11. noBlink()                  //光标不闪烁
  12. noDisplay()              //关闭显示,但不会丢失内容
  13. display()                   //(使用noDisplay后)恢复显示
  14. scrollDisplayLeft()      //将显示的内容向左滚动一格
  15. scrollDisplayRight()    //将显示的内容向右滚动一格
  16. autoscroll()              //打开自动滚动
  17. noAutoscroll()         //关闭自动滚动
  18. leftToRight()           //从左向右显示内容(默认)
  19. rightToLeft()           //从右向左显示内容
  20. createChar()           //创造字符

二、库函数详细释义

2.1 LiquidCrystal()

内容:

  构造函数,创建一个LiquidCrystal的实例(LiquidCrystal是一个类)。可使用4线或8线方式作为数据线(请注意,还需要指令线).若采用四线方式,将d0-d3悬空不连接.RW引脚可接地而不用接在Arduino的某个引脚上;如果这样接,省略在函数中的rw参数.

语法:

    LiquidCrystal(rs, enable, d4, d5, d6, d7) 
    LiquidCrystal(rs, rw, enable, d4, d5, d6, d7) 
    LiquidCrystal(rs, enable, d0, d1, d2, d3, d4, d5, d6, d7) 
    LiquidCrystal(rs, rw, enable, d0, d1, d2, d3, d4, d5, d6, d7)

参数设置:

    rs: rs连接的Arduino的引脚编号 
    rw: rw连接的Arduino的引脚编号 
    enable:enable连接的Arduino的引脚编号 
    d0, d1, d2, d3, d4, d5, d6, d7: 连接的Arduino的引脚编号

例子:

#include <LiquidCrystal.h>

LiquidCrystal lcd(, , , , , , );    

void setup()
{
    lcd.print("hello, world!");
}

void loop() {}

2.2  begin ()

内容:

    指定显示屏的尺寸(宽度和高度)。

语句:

    lcd.begin(cols, rows)

参数设置:

    lcd: 液晶类型的名称变量 
    cols: 显示器可以显示的列数(1602是16列) 
    rows: 显示器可以显示的行数(1602是2行)

2.3  clear ()

简介:

    清除LCD屏幕上内容,并将光标置于左上角。

语法:

    lcd.clear()

参数:

    lcd:LiquidCrystal类的对象

2.4  home()

内容:

    将光标定位在屏幕左上角. 就是说,接下来的字符从屏幕左上角开始显示.如果同时要清除屏幕上的内容,请使用clear()函数代替.

语法:

    lcd.home()

参数设置:

    lcd: LiquidCrystal类的对象

2.5 setCursor()

简介:

    将光标定位在特定的位置。

语法:

    lcd.setCursor(col, row)

参数:

    lcd:LiquidCrystal类的对象
    col: 你要显示光标的列 (从0开始计数) 
    row: 你要显示光标的行 (从0开始计数)

2.6 write()

简介:

    向LCD写一个字符。

语法:

    lcd.write(data)

参数:

    lcd: LiquidCrystal类的对象 
    data: 你要显示的字符(仅限英文、数字和自定义字符)。

返回值:    

    byte     //write() 将返回写入的字节数,虽然读这个数字是可选

示例:

#include <LiquidCrystal.h>

LiquidCrystal lcd(, , , , , , );

void setup()
{
    Serial.begin();
}

void loop()
{
    if (Serial.available())
    {
        lcd.write(Serial.read());
    }
}

2.7  print()

内容:

    将文本显示在LCD上.

语法:

    lcd.print(data) 
    lcd.print(data, BASE)

参数:

    lcd: 液晶类型的名称变量 
    data:要显示的数据,可以是char, byte, int, long或者string类型的 
    BASE (optional): 数制(可选),BIN,DEC,OCT,HEX分别将数字以二进制,十进制,八进制,十六进制方式显示出来.

返回值:

    byte     //这个返回值通常是用不到的

示例:

#include <LiquidCrystal.h>

LiquidCrystal lcd(, , , , , , );

void setup()
{
    lcd.print("hello, world!");
}

void loop() {}

2.8  cursor()

内容:

    显示光标(光标所在的位置, 就是下一个字符将会被显示的位置)。

语法:

    lcd.cursor()

参数设置:

    lcd: 液晶类型的名称变量

2.9  noCursor()

内容:

    隐藏光标。

语法:

    lcd.noCursor()

参数:

    lcd: 液晶类型的名称变量

2.10 blink()

内容:

    显示闪烁的光标。如果和cursor()一起使用,最终结果将取决于您使用的LCD屏幕.

语法:

    lcd.blink()

参数设置:

    lcd: 液晶类型的名称变量

2.11 noBlink()

内容:

    关闭 光标闪烁功能.

语句:

    lcd.noBlink()

参数设置:

    lcd: 液晶类型的名称变量

2.12 noDisplay()

内容:

    关闭液晶显示,但原先显示的内容不会丢失. 可使用display()恢复显示.

语法:

    lcd.noDisplay()

参数:

    lcd: 液晶类型的名称变量

2.13 display()

简介:

    调用noDisplay()隐藏LCD上显示内容后,调用本函数恢复显示.

语法:

    lcd.display()

参数:

    lcd: 液晶类型的名称变量

2.14 scrollDisplayLeft()

简介:

    使屏幕上内容(光标及文字)向左滚动一个字符。

语法:

    lcd.scrollDisplayLeft()

参数:

    lcd: 一个LiquidCrystal类的对象

2.15 scrollDisplayRight()

简介:

    使屏幕上内容(光标及文字)向右滚动一个字符。

语法:

    lcd.scrollDisplayRight()

参数:

    lcd: 一个LiquidCrystal类的对象

2.16 autoscroll()

简介:

  打开液晶显示屏的自动滚动,将会使得当一个字符输出到LCD时,令先前的文本移动一个位置.如果当前写入方向为由左到右(默认方向),文本向左滚动.反之,文本向右滚动.它的功能可以理解为,当输出单个字符时,会使得字符总是输出在LCD上的同一个位置.

语法:

    lcd.autoscroll()

参数:

    lcd: a variable of type LiquidCrystal

2.17 noAutoscroll()

简介:

    关闭自动滚动功能。(后输入的字符可能无法显示)

语法:

    lcd.noAutoscroll()

参数:

    LCD:LiquidCrystal类的对象

2.18 leftToRight()

内容:

    默认的方向,将文本从左到右写入屏幕.这意味着,后续字符的显示将是从左向右的,但是这不会影响先前已经显示的字符.

语法:

    lcd.leftToRight()

参数设置:

    lcd: a variable of type LiquidCrystal

2.19 rightToLeft()

简介:

    设置文本写入LCD的方向为从右向左(默认是从左向右)。这意味着,后续字符将会由右至左写入,但不影响先前的文本的显示。

语法:

    lcd.rightToLeft()

参数:

    lcd: 一个LiquidCrystal类的对象

2.20 createChar()

内容:

  创建用户自定义的字符.共可创建8个用户自定义字符,编号从0到7.字符外观由一个8字节数组定义,每行占用一个字节.最低的5个有效位决定像素点所在的行.若要在屏幕显示自定义字符,请使用write()函数.(参数为字符的编号0-7)

语法:

    lcd.createChar(num, data)

参数设置:

    lcd: a variable of type LiquidCrystal 
    num: 所创建字符的编号(0-7) 
    data: 字符的像素数据

例子:

#include <LiquidCrystal.h>

LiquidCrystal lcd(, , , , , );

] = {    //1表示亮,0表示不亮,此例显示一个笑脸
    B00000,
    B10001,
    B00000,
    B00000,
    B10001,
    B01110,
    B00000,
};

void setup() {
    ;    //x可以为0~7的任何数字
    lcd.createChar(x , smiley);    //将x号字符设置为smiley数组表示的样子
    lcd.begin(, );
    lcd.write(x);
}

void loop() {}

参考自:https://www.cnblogs.com/Dumblidor/p/5394302.html

和https://wenku.baidu.com/view/f0551a3deefdc8d376ee327d.html

-END-

Arduino-1602-LiquidCrystal库的更多相关文章

  1. Arduino下LCD1602综合探究(下)——如何减少1602的连线,LiquidCrystal库,LiquidCrystal库中bug的解决方法

    一.前言: 上文中,笔者系统的阐述了1602的两种驱动方式,并简单的提到了Arduino的LiquidCrystal库.本文紧接上文,对以下两个问题进行更加深入的探讨:如何能够使1602对Arduin ...

  2. arduino中SCoop库的简单应用案例

    转载:https://www.csdn.net/gather_27/MtTaggzsMDExMS1ibG9n.html arduino中SCoop库的简单应用案例首先这篇文章来在视频https://v ...

  3. Arduino 1602液晶屏实验和程序

    在Arduino IDE中, 项目->加载库->管理库中搜索LiquidCrystal,然后安装即可 1.接线图 2.引脚图 3.最简单程序 #include <LiquidCrys ...

  4. arduino红外遥控库IRremote的IRsend类sendRaw函数溢出问题及其解决方法

    最近在调试红外遥控格力空调,在论坛中学到了不少东西.参考: (1)<解决问题系列(4)——红外编码分析利器使用> (2)<315Mhz模块传输替代315Mhz遥控器> 调试环境 ...

  5. 关于Arduino 步进电机Stepper库的一些想法

    官方提供了一些库,使Arduino入门起来更加快速,我们连原理都不用懂,就能通过函数控制终端.但是,这样也带来了很多的缺陷,比如,库函数的功能有限,有些无法实现.然后还有库函数因为要考虑其他的情况,你 ...

  6. 手把手教你看懂并理解Arduino PID控制库——引子

    介绍 本文主要依托于Brett Beauregard大神针对Arduino平台撰写的PID控制库Arduino PID Library及其对应的帮助博客Improving the Beginner’s ...

  7. Arduino学习——u8glib库资料整理

    第一部分,u8glib标准语法格式: 本文使用的是DFRobot出品的LCD12864 Shield V1.0 端口占用情况: SPI Com: SCK = 13, MOSI = 11, CS = 1 ...

  8. Arduino利用TimerOne库产生固定频率和占空比的方波

    TimerOne地址: https://code.google.com/archive/p/arduino-timerone/downloads ex: #include "TimerOne ...

  9. Arduino 使用舵机库时 其它引脚输出怪异 解决方案

    使用Servo.h时,不管你在初始化时用的是9还是10脚,都不要把这两个脚作为舵机以外的用途! 例: servo.attach(9); digitalWrite(10,1);//错,不能把第10脚用作 ...

  10. Arduino Micro USB库

    USBCore.cpp #define D_DEVICE(_class,_subClass,_proto,_packetSize0,_vid,_pid,_version,_im,_ip,_is,_co ...

随机推荐

  1. I2C controller core之Bit controller(04)

    4) detect start/stop condition START- falling edge on SDA while SCL is high;  STOP -  rising edge on ...

  2. Java_Web之状态管理

    回顾及作业点评: (1)JSP如何处理客户端的请求? 使用response对象处理响应 (2)请描述转发与重定向有何区别? 转发是在服务器端发挥作用,通过forward方法将提交信息在多个页面间进行传 ...

  3. linux route命令的使用详解(转)

    route命令用于显示和操作IP路由表.要实现两个不同的子网之间的通信,需要一台连接两个网络的路由器,或者同时位于两个网络的网关来实现.在Linux系统中,设置路由通常是 为了解决以下问题:该Linu ...

  4. 上传菜品数据&生成点餐二维码

    基础数据上传 在门店助手打开数据上传功能,点击上传到微餐厅3.0,,即将门店本地的基础数据上传到线上. 注意1:上传前,需要在线下系统维护好基础数据 注意2:线下基础数据发生更改时,需要手动在门店助手 ...

  5. python 疑难杂症

    1.getpass模块    :Pycharm不支持getpass模块,使用terminal可运行,但是getpass中文提示显示乱码?

  6. LA 4327

    Panagola, The Lord of city F likes to parade very much. He always inspects his city in his car and e ...

  7. lunix下的redis数据库操作——hash(哈希)

    哈希,形如:key : (field : value) 创建:(可以理解为users用户,name为xxx) hset users name xxx 查看: hget users name # &qu ...

  8. js获取URL参数的函数

    function GetQueryString(name) { var reg = new RegExp("(^|&)" + name + "=([^&] ...

  9. Spring Cloud-Bus(十二)

    说明 用于分布式上所有微服务都连接到消息总线上面.进行统一的通知 Config动态刷新 configClient configClient通过/actuator/bus-refresh端点通知消息总线 ...

  10. Spring Boot-springbootHelloword(一)

    什么是springboot sprng家族一个全新的框架  简化我们应用程序的创建和开发的过程,使用默认配置简化了我们以前传统的配置 springboot的特性     能够快速创建spring程序 ...