zoukankan      html  css  js  c++  java
  • 在树莓派上使用 SSD1306 OLED 屏幕

    原文地址:https://shumeipai.nxez.com/2019/04/29/use-the-ssd1306-oled-display-on-the-raspberry-pi.html

    树莓派在许多使用场景下并不需要接一台专用显示器,如需要查看树莓派上的一些信息可以通过手机、电脑登录到树莓派上操作,但总归不够便利。
    下面介绍两款 OLED 小屏(均为 SSD1306 芯片驱动)可以直接插到树莓派 GPIO 上,配有 Python 源码让树莓派玩家可以轻松用它来显示任何图文或动画内容。

    1、Pi OLED 128×32 OLED 屏幕扩展(I2C)

    Pi OLED 配备 0.9 英寸迷你单色屏,128×32 分辨率,白光像素点。拥有极高的对比度,显示清晰极易辨识。OLED 仅使用树莓派的 I2C 和电源引脚,无需独立供电,即插即用。(查看详情购买链接

    2、“复古小电视” OLED 屏

    带有 3D 打印外壳的 OLED 小屏,分辨率 128×64。通过 I2C 连接到树莓派,无需独立供电。(购买链接

    一、启用树莓派的I2C功能

    1
    2
    3
    sudo apt-get install -y python-smbus
    sudo apt-get install -y i2c-tools
    sudo raspi-config

    按照下面的步骤设置开启 I2C 功能。

    重启树莓派。

    1
    sudo reboot

    二、安装 Adafruit-SSD1306 库

    Adafruit-SSD1306 是基于 Python 的 OLED 库,可以用于 128×64、128×32 像素 SSD1306 芯片控制的屏幕。
    使用下面的命令安装。

    1
    sudo python -m pip install --upgrade pip setuptools wheel

    注意,如果这一步出现错误提示“TypeError: unsupported operand type(s) for -=: ‘Retry’ and ‘int’”,可以尝试卸载后重新安装 pip 来解决。

    1
    2
    sudo apt-get remove python-pip python3-pip
    sudo apt-get install python-pip python3-pip

    安装 PIL 库,有一些图片处理的程序会用到这个。

    1
    sudo apt-get install python-pil python3-pil

    使用 pip 安装 Adafruit-SSD1306 库。

    1
    sudo pip install Adafruit-SSD1306

    再下载一份包含代码示例的库后面要用。

    1
    2
    cd ~
    git clone https://github.com/adafruit/Adafruit_Python_SSD1306.git

    这里顺便提一下,如果上面的 pip 安装 Adafruit-SSD1306 库遇到网络问题,那么也可以在下载完这份代码之后运行下面的命令安装(可选):

    1
    2
    cd Adafruit_Python_SSD1306
    sudo python setup.py install

    进到示例目录,可以看到有一些已经准备好了的代码,后面将屏幕接好之后可以直接运行看效果。

    1
    cd ~/Adafruit_Python_SSD1306/examples/

    三、连接屏幕

    对于 Pi OLED 屏幕扩展,直接安插在 GPIO 如图所示位置(物理引脚编号1-6号)。

    对于“小电视”屏幕,根据屏幕 PCB 上引脚的功能标注接到树莓派上对应的 GPIO 上即可。
    屏幕 GND 接树莓派 GND
    屏幕 VCC 接树莓派 3V3
    屏幕 SDA 接树莓派 SDA
    屏幕 SCL 接树莓派 SCL
    注意一定不要接反 VCC 和 GND,否则会烧坏屏幕。

    下面通过命令检测是否识别到 I2C 设备。

    1
    sudo i2cdetect -y 1

    将显示已连接设备的 I2C 地址,不同的屏幕地址可能会不一样,通过这个步骤可以确认一下。
    注意,如果你正在使用的是初代树莓派(256MB的树莓派1代B),那么需要用这个命令:

    1
    sudo i2cdetect -y 0

    四、编程和运行

    为了快速上手,我们可以直接使用示例代码。其中有一个文件名为 stats.py 的程序,用来显示树莓派的 IP、CPU Load、内存和磁盘使用情况。先拿这个来试试看。
    将之前下载的源码复制到用户目录,用编辑器打开。

    1
    2
    3
    cd ~
    sudo cp ~/Adafruit_Python_SSD1306/examples/stats.py ~/
    sudo nano stats.py

    可以看到这份示例已经包含了多种屏幕参数的初始化方法。

    1
    2
    3
    4
    5
    6
    7
    8
    # 128x32 display with hardware I2C:
    disp = Adafruit_SSD1306.SSD1306_128_32(rst=RST)
     
    # 128x64 display with hardware I2C:
    # disp = Adafruit_SSD1306.SSD1306_128_64(rst=RST)
     
    # Note you can change the I2C address by passing an i2c_address parameter like:
    # disp = Adafruit_SSD1306.SSD1306_128_64(rst=RST, i2c_address=0x3C)

    你可以根据实际所用的屏幕来修改这些参数,例如 SSD1306_128_32 代表 128×32 分辨率屏幕的初始化方法,适用于本篇介绍的 Pi OLED 128×32 OLED 屏幕扩展,SSD1306_128_64 适用于“复古小电视” OLED 屏。i2c_address 用于配置屏幕的地址,默认为 0x3C。

    运行示例代码,可看到运行效果。

    1
    sudo python stats.py

    同样的方法再试试 image.py 这个示例效果如下。

    通过修改 image.py 中的初始化参数,调整为 128×64 分辨率之后。

    1
    disp = Adafruit_SSD1306.SSD1306_128_64(rst=RST)


    屏幕上的图片、形状、文本和字体都是由 PIL(Python Imaging Library)的模块 Image, ImageDraw, and ImageFont 来实现的。如有兴趣可以试试其他代码示例,并学习自己设计图文来显示。

    五、设置开机运行

    为了让 stats.py 能够开机自动运行,我们可以做下面的配置,这样我们就可以不用通过工具或路由器去查找树莓派的 IP 地址等信息了。
    修改 /etc/rc.local 文件。

    1
    sudo nano /etc/rc.local

    在 exit 0 前面增加一行:

    1
    sudo python /home/pi/stats.py &


    编辑好之后按下 Ctrl+O 保存,再按下 Ctrl+X 退出。重启树莓派验证一下是否生效吧!

    1
    sudo reboot

    六、提高显示速率(可选,不推荐)

    为了更好的显示性能,例如显示动画时如对帧率有要求,可以通过修改下面的参数将 I2C 频率从默认的 100KHz 或 400KHz 提升到 1MHz。

    1
    sudo nano /boot/config.txt

    在文件末添加一行:

    dtparam=i2c_baudrate=1000000
  • 相关阅读:
    C#|android与c#之间scoket获取数据进行赋值显示的问题
    C#|窗体获取系统时间、回车触发按钮事件、实现验证码功能
    C#|Insert Into 语句的语法错误
    Android|单片机与android手机通信(控制LED小灯亮灭)
    《软件工程导论》考试复习题集锦
    计算机网络 中国大学MOOC 哈尔滨工业大学 习题答案
    (转)关于数学建模竞赛的一点思考、总结和建议
    答应我,安装chromedriver,按照版本号,v70就安装v2.42,
    (转)Python爬虫--通用框架
    你想转载博客,用这招就好了
  • 原文地址:https://www.cnblogs.com/guochaoxxl/p/13902432.html
Copyright © 2011-2022 走看看