Exemplo n.º 1
0
def human_check_init():
    global gpioirDev,gpioledDev,irDev

    gpioirDev = GPIO()
    gpioirDev.open("ir")
    irDev = ir.IR(gpioirDev)

    gpioledDev = GPIO()
    gpioledDev.open("led")
Exemplo n.º 2
0
def on_props(request):
    from driver import GPIO
    import ujson
    ON = 0
    OFF = 1
    #服务端返回的json 转换成dict
    payload = ujson.loads(request)
    #获取dict 中的led 状态字段
    stat = payload["LEDSwitch"]
    gpio = GPIO()
    # open 函数支持的参数列表如下:
    # led1;led2;led3;led4;led5
    gpio.open('led1')
    if stat == 1:
        gpio.write(ON)
    else:
        gpio.write(OFF)
    utime.sleep_ms(200)
    gpio.close()
Exemplo n.º 3
0
        # 上传温度和湿度信息到物联网平台
        device.postProps(upload_data)
        utime.sleep(2)


if __name__ == '__main__':
    # 硬件初始化
    i2cObj = I2C()

    i2cObj.open(
        "sht3x"
    )  # 按照board.json中名为"sht3x"的设备节点的配置参数(主设备I2C端口号,从设备地址,总线频率等)初始化I2C类型设备对象
    print("sht3x inited!")

    humitureDev = sht3x.SHT3X(i2cObj)  # 初始化SHT3X-DIS传感器
    # 初始化 GPIO
    airconditioner = GPIO()
    humidifier = GPIO()

    humidifier.open('led_g')  # 加湿器使用board.json中led_g节点定义的GPIO,对应esp32外接的的绿灯
    airconditioner.open(
        'led_b')  # 空调使用board.json中led_b节点定义的GPIO,对应esp32外接的上的蓝灯

    # 请替换物联网平台申请到的产品和设备信息,可以参考文章:https://blog.csdn.net/HaaSTech/article/details/114360517
    get_wifi_status()

    connect_lk(productKey, deviceName, deviceSecret)
    upload_temperature_and_Humidity()

    i2cObj.close()
Exemplo n.º 4
0
        # "alarmLight" - 代表报警灯的当前状态
        uploadData = {'params': data}
        # 上传燃气传感器检测电压信息和报警信息到物联网平台

        device.postProps(uploadData)

        # 每2秒钟上报一次
        utime.sleep(2)


if __name__ == '__main__':
    # 硬件初始化
    # 初始化 ADC
    adcObj = ADC()  # ADC通道对象
    adcObj.open("mq2")  # 按照board.json中名为"mq2"节点的配置初始化ADC设备对象
    mq2Dev = mq2.MQ2(adcObj)  # 初始化MQ2设备对象

    # 初始化LED所连接GPIO
    alarmLed = GPIO()
    alarmLed.open('led')  # 加湿器使用board.json中led_r节点定义的GPIO,对应LED灯
    led_control(alarmOn)  # 关闭报警灯

    # 请替换物联网平台申请到的产品和设备信息,可以参考文章:https://blog.csdn.net/HaaSTech/article/details/114360517
    # global productKey, deviceName, deviceSecret ,on_request, on_play
    get_wifi_status()

    connect_lk(productKey, deviceName, deviceSecret)
    upload_gas_detector_state()

    adcObj.close()
    alarmLed.close()
Exemplo n.º 5
0
        # 上传火焰传感器检测电压信息和报警信息到物联网平台
        device.postProps(upload_data)

        # 每2秒钟上报一次
        utime.sleep(2)

if __name__ == '__main__':
    global fireDev

    alarm_on = 0
    # 硬件初始化
    # 初始化 ADC
    adcDev = ADC()
    adcDev.open("fire")
    fireDev = fire.Fire(adcDev)

    # 初始化LED所连接GPIO
    ledDev = GPIO()
    ledDev.open("led")
    alarm_control(alarm_on)         # 关闭报警灯

    wlan = network.WLAN(network.STA_IF)    #创建WLAN对象
    # 请替换物联网平台申请到的产品和设备信息,可以参考文章:https://blog.csdn.net/HaaSTech/article/details/114360517
    get_wifi_status()

    connect_lk(productKey, deviceName, deviceSecret)
    upload_fire_detector_state()

    adcDev.close()
    ledDev.close()
Exemplo n.º 6
0
import sh1106
import utime
from driver import SPI
from driver import GPIO

spi0 = SPI()
spi0.open("oled_spi")

gpio_dc = GPIO()
gpio_dc.open("oled_dc")

gpio_res = GPIO()
gpio_res.open("oled_res")

display = sh1106.SH1106_SPI(width=132, height=64, spi=spi0, dc = gpio_dc, res = gpio_res)
# display.init_display()
display.fill(1)
display.show()
display.test()
Exemplo n.º 7
0
        # "gasVoltage" - 代表燃气传感器测量到的电压值
        # "alarmLight" - 代表报警灯的当前状态
        uploadData = {'params': data}
        # 上传燃气传感器检测电压信息和报警信息到物联网平台

        device.postProps(uploadData)

        # 每2秒钟上报一次
        utime.sleep(2)

if __name__ == '__main__':
    # 硬件初始化
    # 初始化 ADC
    adcObj = ADC()                 # ADC通道对象
    adcObj.open("mq2")             # 按照board.json中名为"mq2"节点的配置初始化ADC设备对象
    mq2Dev = mq2.MQ2(adcObj)       # 初始化MQ2设备对象

    # 初始化LED所连接GPIO
    alarmLed = GPIO()
    alarmLed.open('led')          # LED报警灯使用board.json中名为led的节点中定义的GPIO进行控制
    led_control(alarmOn)          # 关闭报警灯

    # 请替换物联网平台申请到的产品和设备信息,可以参考文章:https://blog.csdn.net/HaaSTech/article/details/114360517
    # global productKey, deviceName, deviceSecret ,on_request, on_play
    get_wifi_status()

    connect_lk(productKey, deviceName, deviceSecret)
    upload_gas_detector_state()

    adcObj.close()
    alarmLed.close()
Exemplo n.º 8
0
# coding=utf-8
# This is a sample Python script.
import utime
from driver import GPIO

def cb(obj):
    print("gpio callback test")
    print(obj)

print("start led test")
gpio = GPIO()
gpio.open("GPIO23")
gpio.enableIrq(cb)
utime.sleep_ms(200)
gpio.disableIrq(cb)
gpio.clearIrq(cb)
gpio.close()

print("end led test")
Exemplo n.º 9
0
from driver import GPIO
import utime as time
import audio
import radar

#创建并打开一个GPIO实例
gpiorDev=GPIO()
gpiorDev.open('radar')
#创建一个radar实例
radarDev=radar.RADAR(gpiorDev)

#创建并打开一个Audio实例
aud=audio.Audio()
#开启音频播放使能
aud.set_pa()
#设置音量
aud.setVolume(5)
#循环检测是否有人经过
while True:
    if radarDev.detect()==1:
        print("detect body")
        aud.play('/data/pyamp/detect_body.mp3')
    else:
        print("no body")
    time.sleep(2)        


Exemplo n.º 10
0
# coding=utf-8
# This is a sample Python script.
import utime
from driver import GPIO

print("start led test")
gpio = GPIO()
leds = ("led_r", "led_g", "led_b")
for i in range(5):
    for led in leds:
        gpio.open(led)
        gpio.write(1)
        utime.sleep_ms(200)
        gpio.write(0)
        utime.sleep_ms(200)
        gpio.close()

print("end led test")
Exemplo n.º 11
0
class MFRC522:

    OK = 0
    NOTAGERR = 1
    ERR = 2

    REQIDL = 0x26
    REQALL = 0x52
    AUTHENT1A = 0x60  #验证A密钥
    AUTHENT1B = 0x61  #验证B密钥

    def __init__(self):
        self.spi = SPI()
        self.spi.open('SPI0')
        self.rst = GPIO()
        self.rst.open('rst')
        self.rst.write(0)
        self.rst.write(1)
        self.init()

    def deinit(self):
        self.spi.close()

    def _wreg(self, reg, val):
        writeBuf = bytearray(
            [int(0xff & ((reg << 1) & 0x7e)),
             int(0xff & val)])
        self.spi.write(writeBuf)

    def _rreg(self, reg):
        readBuf = bytearray(1)
        writeBuf = bytearray([int(0xff & (((reg << 1) & 0x7e) | 0x80))])
        self.spi.write(writeBuf)
        self.spi.read(readBuf)
        return readBuf[0]

    def _sflags(self, reg, mask):
        self._wreg(reg, self._rreg(reg) | mask)

    def _cflags(self, reg, mask):
        self._wreg(reg, self._rreg(reg) & (~mask))

    def _tocard(self, cmd, send):

        recv = []
        bits = irq_en = wait_irq = n = 0
        stat = self.ERR

        if cmd == 0x0E:
            irq_en = 0x12
            wait_irq = 0x10
        elif cmd == 0x0C:
            irq_en = 0x77
            wait_irq = 0x30

        self._wreg(0x02, irq_en | 0x80)
        self._cflags(0x04, 0x80)
        self._sflags(0x0A, 0x80)
        self._wreg(0x01, 0x00)

        for c in send:
            self._wreg(0x09, c)
        self._wreg(0x01, cmd)

        if cmd == 0x0C:
            self._sflags(0x0D, 0x80)

        i = 2000
        while True:
            n = self._rreg(0x04)
            i -= 1
            if ~((i != 0) and ~(n & 0x01) and ~(n & wait_irq)):
                break

        self._cflags(0x0D, 0x80)

        if i:
            if (self._rreg(0x06) & 0x1B) == 0x00:
                stat = self.OK

                if n & irq_en & 0x01:
                    stat = self.NOTAGERR
                elif cmd == 0x0C:
                    n = self._rreg(0x0A)
                    lbits = self._rreg(0x0C) & 0x07
                    if lbits != 0:
                        bits = (n - 1) * 8 + lbits
                    else:
                        bits = n * 8

                    if n == 0:
                        n = 1
                    elif n > 16:
                        n = 16

                    for _ in range(n):
                        recv.append(self._rreg(0x09))
            else:
                stat = self.ERR

        return stat, recv, bits

    def _crc(self, data):
        self._cflags(0x05, 0x04)
        self._sflags(0x0A, 0x80)

        for c in data:
            self._wreg(0x09, c)

        self._wreg(0x01, 0x03)

        i = 0xFF
        while True:
            n = self._rreg(0x05)
            i -= 1
            if not ((i != 0) and not (n & 0x04)):
                break

        return [self._rreg(0x22), self._rreg(0x21)]

    def init(self):
        self.reset()
        self._wreg(0x2A, 0x8D)
        self._wreg(0x2B, 0x3E)
        self._wreg(0x2D, 30)
        self._wreg(0x2C, 0)
        self._wreg(0x15, 0x40)
        self._wreg(0x11, 0x3D)
        self.antenna_on()

    def reset(self):
        self._wreg(0x01, 0x0F)

    def antenna_on(self, on=True):
        if on and ~(self._rreg(0x14) & 0x03):
            self._sflags(0x14, 0x03)
        else:
            self._cflags(0x14, 0x03)

    def request(self, mode):
        self._wreg(0x0D, 0x07)
        (stat, recv, bits) = self._tocard(0x0C, [mode])
        if (stat != self.OK) | (bits != 0x10):
            stat = self.ERR

        return stat, bits

    def anticoll(self):
        ser_chk = 0
        ser = [0x93, 0x20]
        self._wreg(0x0D, 0x00)
        (stat, recv, bits) = self._tocard(0x0C, ser)
        if stat == self.OK:
            if len(recv) == 5:
                for i in range(4):
                    ser_chk = ser_chk ^ recv[i]
                if ser_chk != recv[4]:
                    stat = self.ERR
            else:
                stat = self.ERR
        return stat, recv

    def select_tag(self, ser):
        buf = [0x93, 0x70] + ser[:5]
        buf += self._crc(buf)
        (stat, recv, bits) = self._tocard(0x0C, buf)
        return self.OK if (stat == self.OK) and (bits == 0x18) else self.ERR

    def auth(self, mode, addr, sect, ser):
        return self._tocard(0x0E, [mode, addr] + sect + ser[:4])[0]

    def stop_crypto1(self):
        self._cflags(0x08, 0x08)

    def read(self, addr):  #读块数据

        data = [0x30, addr]
        data += self._crc(data)
        (stat, recv, _) = self._tocard(0x0C, data)
        return recv if stat == self.OK else None

    def write(self, addr, data):
        buf = [0xA0, addr]
        buf += self._crc(buf)
        (stat, recv, bits) = self._tocard(0x0C, buf)
        if not (stat == self.OK) or not (bits == 4) or not (
            (recv[0] & 0x0F) == 0x0A):
            stat = self.ERR
        else:
            buf = []
            for i in range(16):
                buf.append(data[i])
            buf += self._crc(buf)
            (stat, recv, bits) = self._tocard(0x0C, buf)
            if not (stat == self.OK) or not (bits == 4) or not (
                (recv[0] & 0x0F) == 0x0A):
                stat = self.ERR

        return stat
Exemplo n.º 12
0
def ledInit():
    global ledDev
    ledDev = GPIO()
    ledDev.open("led")