micropythonrp2040读取ds18b20温度传感器数据+0.96“i2coled显示(代码片段)

perseverance52 perseverance52     2022-12-08     791

关键词:

【MicroPython RP2040】读取DS18B20温度传感器数据+ 0.96“I2C oled显示


  • ✨本示例基于Thonny平台开发。
  • 📒RP2040开发板

  • 📘YD-RP2040开发板
  • 🎄DS18B20传感器
  • 🎄ssd1306 I2C 0.96寸 OLED屏幕

📌注意事项

⛳在运行代码前,需要先将ssd1306 0.96寸 I2C OLED连接到RP2040开发板对应的引脚上,否则会报错,找不到I2C设备。

📔所需库模块

  • 💎ssd1306…py
# MicroPython SSD1306 OLED driver, I2C and SPI interfaces
 
from micropython import const
import framebuf
 
# register definitions
SET_CONTRAST = const(0x81)
SET_ENTIRE_ON = const(0xA4)
SET_NORM_INV = const(0xA6)
SET_DISP = const(0xAE)
SET_MEM_ADDR = const(0x20)
SET_COL_ADDR = const(0x21)
SET_PAGE_ADDR = const(0x22)
SET_DISP_START_LINE = const(0x40)
SET_SEG_REMAP = const(0xA0)
SET_MUX_RATIO = const(0xA8)
SET_COM_OUT_DIR = const(0xC0)
SET_DISP_OFFSET = const(0xD3)
SET_COM_PIN_CFG = const(0xDA)
SET_DISP_CLK_DIV = const(0xD5)
SET_PRECHARGE = const(0xD9)
SET_VCOM_DESEL = const(0xDB)
SET_CHARGE_PUMP = const(0x8D)
 
# Subclassing FrameBuffer provides support for graphics primitives
# http://docs.micropython.org/en/latest/pyboard/library/framebuf.html
class SSD1306(framebuf.FrameBuffer):
    def __init__(self, width, height, external_vcc):
        self.width = width
        self.height = height
        self.external_vcc = external_vcc
        self.pages = self.height // 8
        self.buffer = bytearray(self.pages * self.width)
        super().__init__(self.buffer, self.width, self.height, framebuf.MONO_VLSB)
        self.init_display()
 
    def init_display(self):
        for cmd in (
            SET_DISP | 0x00,  # off
            # address setting
            SET_MEM_ADDR,
            0x00,  # horizontal
            # resolution and layout
            SET_DISP_START_LINE | 0x00,
            SET_SEG_REMAP | 0x01,  # column addr 127 mapped to SEG0
            SET_MUX_RATIO,
            self.height - 1,
            SET_COM_OUT_DIR | 0x08,  # scan from COM[N] to COM0
            SET_DISP_OFFSET,
            0x00,
            SET_COM_PIN_CFG,
            0x02 if self.width > 2 * self.height else 0x12,
            # timing and driving scheme
            SET_DISP_CLK_DIV,
            0x80,
            SET_PRECHARGE,
            0x22 if self.external_vcc else 0xF1,
            SET_VCOM_DESEL,
            0x30,  # 0.83*Vcc
            # display
            SET_CONTRAST,
            0xFF,  # maximum
            SET_ENTIRE_ON,  # output follows RAM contents
            SET_NORM_INV,  # not inverted
            # charge pump
            SET_CHARGE_PUMP,
            0x10 if self.external_vcc else 0x14,
            SET_DISP | 0x01,
        ):  # on
            self.write_cmd(cmd)
        self.fill(0)
        self.show()
 
    def poweroff(self):
        self.write_cmd(SET_DISP | 0x00)
 
    def poweron(self):
        self.write_cmd(SET_DISP | 0x01)
 
    def contrast(self, contrast):
        self.write_cmd(SET_CONTRAST)
        self.write_cmd(contrast)
 
    def invert(self, invert):
        self.write_cmd(SET_NORM_INV | (invert & 1))
 
    def show(self):
        x0 = 0
        x1 = self.width - 1
        if self.width == 64:
            # displays with width of 64 pixels are shifted by 32
            x0 += 32
            x1 += 32
        self.write_cmd(SET_COL_ADDR)
        self.write_cmd(x0)
        self.write_cmd(x1)
        self.write_cmd(SET_PAGE_ADDR)
        self.write_cmd(0)
        self.write_cmd(self.pages - 1)
        self.write_data(self.buffer)
 
 
class SSD1306_I2C(SSD1306):
    def __init__(self, width, height, i2c, addr=0x3C, external_vcc=False):
        self.i2c = i2c
        self.addr = addr
        self.temp = bytearray(2)
        self.write_list = [b"\\x40", None]  # Co=0, D/C#=1
        super().__init__(width, height, external_vcc)
 
    def write_cmd(self, cmd):
        self.temp[0] = 0x80  # Co=1, D/C#=0
        self.temp[1] = cmd
        self.i2c.writeto(self.addr, self.temp)
 
    def write_data(self, buf):
        self.write_list[1] = buf
        self.i2c.writevto(self.addr, self.write_list)
 
 
class SSD1306_SPI(SSD1306):
    def __init__(self, width, height, spi, dc, res, cs, external_vcc=False):
        self.rate = 10 * 1024 * 1024
        dc.init(dc.OUT, value=0)
        res.init(res.OUT, value=0)
        cs.init(cs.OUT, value=1)
        self.spi = spi
        self.dc = dc
        self.res = res
        self.cs = cs
        import time
 
        self.res(1)
        time.sleep_ms(1)
        self.res(0)
        time.sleep_ms(10)
        self.res(1)
        super().__init__(width, height, external_vcc)
 
    def write_cmd(self, cmd):
        self.spi.init(baudrate=self.rate, polarity=0, phase=0)
        self.cs(1)
        self.dc(0)
        self.cs(0)
        self.spi.write(bytearray([cmd]))
        self.cs(1)
 
    def write_data(self, buf):
        self.spi.init(baudrate=self.rate, polarity=0, phase=0)
        self.cs(1)
        self.dc(1)
        self.cs(0)
        self.spi.write(buf)
        self.cs(1)

🎯先将所需模块导入到micropython RP2040设备中

  • ⏳导入后,可以在设备信息文件栏看到。(如果Thonny软件没有将文件勾选上将看不到。)

📝主程序代码

# Display Image & text on I2C driven ssd1306 OLED display 
from machine import Pin, I2C
from ssd1306 import SSD1306_I2C
import machine
import utime
import onewire, ds18x20, time
 
ds_pin = machine.Pin(22)
 
ds_sensor = ds18x20.DS18X20(onewire.OneWire(ds_pin))
 
roms = ds_sensor.scan()
 
print('Found DS devices: ', roms)
 
WIDTH  = 128                                            # oled display width
HEIGHT = 64                                             # oled display height
 
i2c = I2C(0, scl=Pin(9), sda=Pin(8), freq=200000)       # Init I2C using pins GP8 & GP9 (default I2C0 pins)
print("I2C Address      : "+hex(i2c.scan()[0]).upper()) # Display device address
print("I2C Configuration: "+str(i2c))                   # Display I2C config
 
 
oled = SSD1306_I2C(WIDTH, HEIGHT, i2c)                  # Init oled display
 
 
while True:
    ds_sensor.convert_temp()
    time.sleep_ms(750)
 
    for rom in roms:        
        print(rom)
                 
    ds_str =ds_sensor.read_temp(rom)    
    print(ds_str)

  # Clear the oled display in case it has junk on it.
    oled.fill(0)       
    
    # Add some text
    oled.text("Temperature: ",20,8)
    oled.text(str(round(ds_sensor.read_temp(rom),2)),30,30)
    oled.text(b"\\x2a\\x43",75,30) # *C
#     oled.text("*C",75,30)
    utime.sleep(2)
 
 
    # Finally update the oled display so the image & text is displayed
    oled.show()

micropythonrp2040点灯实验(代码片段)

MicroPythonRP2040点灯实验本实验基于Thonny平台本示例所使用的版本;YD-RP2040版(源地YD-RP2040)源地YD-RP2040开发板资料:http://152.32.187.208:8080/yd-data/YD-RP2040/本实验YD-RP2040开发板所烧录的固件:PimoroniPicoLiPo固件下载地址:https 查看详情

micropythonrp2040通过adc调节pwm输出示例(代码片段)

【MicroPythonRP2040】通过ADC调节PWM输出示例🔖RaspberryPiPico引脚功能图🔖YD2040📖RP2040ADC介绍📝RP2040共有5个ADC通道,其中4个是基于12位SAR的ADC:GP26、GP27、GP28和GP29。ADC0、ADC1、ADC2、ADC3的输入信号分别可以连接到GP 查看详情

micropythonrp2040可编程ios(pio)示例介绍(代码片段)

【MicroPythonRP2040】可编程IOs(PIO)原文链接:https://www.cnx-software.com/2021/01/27/a-closer-look-at-raspberry-pi-rp2040-programmable-ios-pio/为什么用可编程I/O?所有的电路板通常都带有对数字通信协议(如I2C、SPI和UART)的硬 查看详情

micropythonrp2040micropython固件烧录以及thonny开发初探(代码片段)

【MicroPython】RP2040MicroPython固件烧录以及Thonny开发初探基于RP2040主控的的PIPICO官方的RaspberryPiPicoMicroPython固件烧写以RP2040为主控核心的RaspberryPiPico固件MicroPythonUF2烧录文件:https://micropython.org/download/rp2-pico/rp2-p 查看详情

micropythonrp2040/esp32/c3自编译4mb/8mb/16mb固件分享(代码片段)

micropythonRP2040/esp32/c3自编译4MB/8MB/16MB固件分享固件基于当前版本:MicroPythonv1.19.1自编译的,可以根据自己的PIPICO,esp32/c3开发板flash容量自行选择其对应的固件进行烧录。本文也提供了官方固件资源,例如:PIPIC... 查看详情

arduinoesp8266/esp32多路ds18b20温度采样读取(代码片段)

ArduinoESP32多路DS18B20温度采样读取DS18B20温度传感器使用单线协议进行通信,每个传感器都有一个独特的64位串行代码,因此您可以使用单个GPIO从多个传感器读取温度。DS18B20的数据引脚上拉电阻选择4.7K。在ESP8266上面接线示意图对... 查看详情

循环数据读取(如 1Wire DS18B20 温度),无需阻塞主程序

】循环数据读取(如1WireDS18B20温度),无需阻塞主程序【英文标题】:Cyclicdatareading(like1WireDS18B20temperature)withoutblockingmainprogram【发布时间】:2016-11-1719:14:08【问题描述】:我正在尝试使用RaspberryPi上的DS18B20传感器读取温度。我的... 查看详情

stc8单片机基于开源库读取ds18b20数据例程

STC8单片机基于开源库读取DS18B20数据例程 查看详情

求个温度采集的流程图

...大概说说就行参考技术A写好初始化、读字节、写字节、读取温度、温度值转换子程序然后开机初始化DS18B20,需要时调用读取温度子程序即可注意DS18B20的读写时序,延时时间,上拉电阻阻值,工作电压。否则无法工作、精度极低... 查看详情

16.stc15w408as单片机获取ds18b20温度(代码片段)

...。当时树莓派有1-wire接口,可以直接以读文件的形式读取到温度。18.树莓派3B+1-wire获取DS18B20温度现在在STC单片机里面没有这个接口,只能使用GPIO模拟单总线的时序来读取DS18B20的温度数据了。DS18B20的特点Unique1-Wireinterf... 查看详情

16.stc15w408as单片机获取ds18b20温度(代码片段)

...。当时树莓派有1-wire接口,可以直接以读文件的形式读取到温度。18.树莓派3B+1-wire获取DS18B20温度现在在STC单片机里面没有这个接口,只能使用GPIO模拟单总线的时序来读取DS18B20的温度数据了。DS18B20的特点Unique1-Wireinterf... 查看详情

16.stc15w408as单片机获取ds18b20温度(代码片段)

...。当时树莓派有1-wire接口,可以直接以读文件的形式读取到温度。18.树莓派3B+1-wire获取DS18B20温度现在在STC单片机里面没有这个接口,只能使用GPIO模拟单总线的时序来读取DS18B20的温度数据了。DS18B20的特点Unique1-Wireinterf... 查看详情

arduinods18b20传感器温度读取(代码片段)

ArduinoDS18B20传感器温度读取单个DS18B20接线方式:VDD接到电源,DQ接单片机引脚,同时外加上拉电阻,GND接地注意:这个上拉电阻是必须的,就是DQ引脚必须要一个上拉电阻。所需库onewireDallas也可以使用其他开发板,或引脚来连接ds1... 查看详情

关于51单片机读取ds18b20温度采集系统,并将读取到的数据传输到数码管上;我们书写的程序总是读取到-000.06的状况,给出以下解决办法。(代码片段)

关于51单片机读取DS18B20温度采集系统,并将读取到的数据传输到数码管上;我们书写的程序总是读取到-000.06的状况,给出以下解决办法。问题所在错误源代码为正确源代码程序源码temp.c文件的程序temp.h文件的数据main.... 查看详情

51单片机课程设计:基于ds18b20的温度报警器

...:基于DS18B20的温度报警器    本程序用于读取DS18B20温度,同时具备报警功能,工程分为3个文件,main.c、temp.c、temp.h,经本人修改部分代码,适用于吉林农业大学51开发板,其他朋友亦可移植到其他型号开发板。工... 查看详情

关于51单片机读取ds18b20温度采集系统,并将读取到的数据传输到数码管上;我们书写的程序总是读取到-000.06的状况,给出以下解决办法。(代码片段)

关于51单片机读取DS18B20温度采集系统,并将读取到的数据传输到数码管上;我们书写的程序总是读取到-000.06的状况,给出以下解决办法。问题所在错误源代码为正确源代码程序源码temp.c文件的程序temp.h文件的数据main.... 查看详情

16.stc15w408as单片机获取ds18b20温度(代码片段)

...。当时树莓派有1-wire接口,可以直接以读文件的形式读取到温度。18.树莓派3B+1-wire获取DS18B20温度现在在STC单片机里面没有这个接口,只能使用GPIO模拟单总线的时序来读取DS18B20的温度数据了。DS18B20的特点Unique1-Wireinterf... 查看详情

16.stc15w408as单片机获取ds18b20温度(代码片段)

...。当时树莓派有1-wire接口,可以直接以读文件的形式读取到温度。18.树莓派3B+1-wire获取DS18B20温度现在在STC单片机里面没有这个接口,只能使用GPIO模拟单总线的时序来读取DS18B20的温度数据了。DS18B20的特点Unique1-Wireinterf... 查看详情