找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 2554|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

MicroPython教程之TPYBoard開發(fā)板DIY小型家庭氣象站

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:130183 發(fā)表于 2017-10-30 14:29 | 只看該作者 |只看大圖 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
  眾所周知,iPhone6/6Plus內(nèi)置氣壓傳感器,不過(guò)大家對(duì)于氣壓傳感器還是很陌生。跟字面的意思一樣,氣壓傳感器就是用來(lái)測(cè)量氣壓的,但測(cè)量氣壓對(duì)于普通的手機(jī)用戶來(lái)說(shuō)又有什么作用呢?

  海拔高度測(cè)量

  對(duì)于喜歡登山的人來(lái)說(shuō),會(huì)非常關(guān)心自己所處的高度。海拔高度的測(cè)量方法,一般常用的有2種方式,一是通過(guò)GPS全球定位系統(tǒng),二是通過(guò)測(cè)出大氣壓,然后根據(jù)氣壓值計(jì)算出海拔高度。由于受到技術(shù)和其它方面原因的限制,GPS計(jì)算海拔高度一般誤差都會(huì)有十米左右,而如果在樹林里或者是在懸崖下面時(shí),有時(shí)候甚至接收不到GPS衛(wèi)星信號(hào)。而氣壓的方式可選擇的范圍會(huì)廣些,而且可以把成本控制的比較低。在手機(jī)原有GPS的基礎(chǔ)上再增加氣壓傳感器的功能,可讓三維定位更加精準(zhǔn)。

  最近發(fā)現(xiàn)一塊好玩的開發(fā)板——TPYBoardv702,這個(gè)板子可以定位、發(fā)短信、打電話,并且板載溫濕度傳感器、光敏傳感器以及蜂鳴器,可以DIY很多有趣的東西,下面我們可以用這個(gè)板子加一個(gè)氣壓傳感器來(lái)做一個(gè)小型氣象站,來(lái)張實(shí)物圖:



  TPYBoardv702

  定位功能我就不多說(shuō)了,如果需要的話可以參考


  那么我們利用這塊板子跟BMP180氣壓傳感器來(lái)做一個(gè)小型家庭氣象站,來(lái)檢測(cè)當(dāng)?shù)販囟纫约爱?dāng)?shù)貧鈮号c海拔,如果想做更好玩的東西,可以接其他傳感器或者加個(gè)繼電器來(lái)控制其他設(shè)備。

  BMP180是一直常見的氣壓傳感器,BMP180是一款高精度、小體積、超低能耗的壓力傳感器,可以應(yīng)用在移動(dòng)設(shè)備中,它的性能卓越,精度最低可以達(dá)到0.03hPa,并且耗電極低,只有3μA;BMP180采用強(qiáng)大的8-pin陶瓷無(wú)引線芯片承載(LCC)超薄封裝,可以通過(guò)I2C總線直接與各種微處理器相連。



  BMP180實(shí)物圖

  硬件接線圖

  
TPYBoard v702
  
        BMP180
3.3V
VIN
GND
GND
Y9
SCL
Y10
SDA

  效果展示圖



  連接完畢后,將font.py,upcd8544.py與bmp180的庫(kù)導(dǎo)入,就可以通過(guò)以下方法分別讀取溫度、氣壓、海拔高度了。

  源代碼

  foot.py,upcd8544.py庫(kù)的下載地址

  導(dǎo)入需要的類庫(kù),編輯好main.py,直接運(yùn)行就ok了,下面是main.py的程序源碼

  1. # main.py -- put your code here!
  2. import pyb
  3. import upcd8544
  4. from machine import SPI,Pin
  5. from ubinascii import hexlify
  6. from ubinascii import *
  7. from bmp180 import BMP180

  8. bmp=BMP180(2)
  9. SPI = pyb.SPI(1) #DIN=>X8-MOSI/CLK=>X6-SCK
  10. #DIN =>SPI(1).MOSI 'X8' data flow (Master out, Slave in)
  11. #CLK =>SPI(1).SCK  'X6' SPI clock
  12. RST    = pyb.Pin('X20')
  13. CE     = pyb.Pin('X19')
  14. DC     = pyb.Pin('X18')
  15. LIGHT  = pyb.Pin('X17')
  16. lcd_5110 = upcd8544.PCD8544(SPI, RST, CE, DC, LIGHT)

  17. while True:
  18.         tem=bmp.getTemp()
  19.         press=bmp.getPress()
  20.         altitude=bmp.getAltitude()
  21.         lcd_5110.lcd_write_string('Tem:',0,0)
  22.         lcd_5110.lcd_write_string(str(tem),0,1)
  23.         lcd_5110.lcd_write_string('C',65,1)
  24.         lcd_5110.lcd_write_string('Press:',0,2)
  25.         lcd_5110.lcd_write_string(str(press),0,3)
  26.         lcd_5110.lcd_write_string('Pa',65,3)        
  27.         lcd_5110.lcd_write_string('Hight:',0,4)
  28.         lcd_5110.lcd_write_string(str(altitude),0,5)
  29.         lcd_5110.lcd_write_string('M',65,5)

  30. bmp180.py庫(kù)的源碼

  31. import pyb
  32. from pyb import I2C

  33. BMP180_I2C_ADDR = const(0x77)
  34. class BMP180():
  35.     def __init__(self, i2c_num):
  36.         self.i2c = I2C(i2c_num, I2C.MASTER, baudrate = 100000)
  37.         self.AC1 = self.short(self.get2Reg(0xAA))
  38.         self.AC2 = self.short(self.get2Reg(0xAC))
  39.         self.AC3 = self.short(self.get2Reg(0xAE))
  40.         self.AC4 = self.get2Reg(0xB0)
  41.         self.AC5 = self.get2Reg(0xB2)
  42.         self.AC6 = self.get2Reg(0xB4)
  43.         self.B1 = self.short(self.get2Reg(0xB6))
  44.         self.B2 = self.short(self.get2Reg(0xB8))
  45.         self.MB = self.short(self.get2Reg(0xBA))
  46.         self.MC = self.short(self.get2Reg(0xBC))
  47.         self.MD = self.short(self.get2Reg(0xBE))
  48.         self.UT = 0
  49.         self.UP = 0
  50.         self.B3 = 0
  51.         self.B4 = 0
  52.         self.B5 = 0
  53.         self.B6 = 0
  54.         self.B7 = 0
  55.         self.X1 = 0
  56.         self.X2 = 0
  57.         self.X3 = 0

  58.     def short(self, dat):
  59.         if dat > 32767:
  60.             return dat - 65536
  61.         else:
  62.             return dat
  63.    
  64.     def setReg(self, dat, reg):
  65.         buf = bytearray(2)
  66.         buf[0] = reg
  67.         buf[1] = dat
  68.         self.i2c.send(buf, BMP180_I2C_ADDR)
  69.         
  70.     def getReg(self, reg):
  71.         buf = bytearray(1)
  72.         buf[0] = reg
  73.         self.i2c.send(buf, BMP180_I2C_ADDR)
  74.         t = self.i2c.recv(1, BMP180_I2C_ADDR)
  75.         return t[0]
  76.    
  77.     def get2Reg(self, reg):
  78.         a = self.getReg(reg)
  79.         b = self.getReg(reg + 1)
  80.         return a*256 + b

  81.     def measure(self):
  82.         self.setReg(0x2E, 0xF4)
  83.         pyb.delay(5)
  84.         self.UT = self.get2Reg(0xF6)
  85.         self.setReg(0x34, 0xF4)
  86.         pyb.delay(5)
  87.         self.UP = self.get2Reg(0xF6)

  88.     def getTemp(self):
  89.         self.measure()
  90.         self.X1 = (self.UT - self.AC6) * self.AC5/(1<<15)
  91.         self.X2 = self.MC * (1<<11) / (self.X1 + self.MD)
  92.         self.B5 = self.X1 + self.X2
  93.         return (self.B5 + 8)/160
  94.         
  95.     def getPress(self):
  96.         self.getTemp()
  97.         self.B6 = self.B5 - 4000
  98.         self.X1 = (self.B2 * (self.B6*self.B6/(1<<12))) / (1<<11)
  99.         self.X2 = (self.AC2 * self.B6)/(1<<11)
  100.         self.X3 = self.X1 + self.X2
  101.         self.B3 = ((self.AC1*4+self.X3) + 2)/4
  102.         self.X1 = self.AC3 * self.B6 / (1<<13)
  103.         self.X2 = (self.B1 * (self.B6*self.B6/(1<<12))) / (1<<16)
  104.         self.X3 = (self.X1 + self.X2 + 2)/4
  105.         self.B4 = self.AC4 * (self.X3 + 32768)/(1<<15)
  106.         self.B7 = (self.UP-self.B3) * 50000
  107.         if self.B7 < 0x80000000:
  108.             p = (self.B7*2)/self.B4
  109.         else:
  110.             p = (self.B7/self.B4) * 2
  111.         self.X1 = (p/(1<<8))*(p/(1<<8))
  112.         self.X1 = (self.X1 * 3038)/(1<<16)
  113.         self.X2 = (-7357*p)/(1<<16)
  114.         p = p + (self.X1 + self.X2 + 3791)/16
  115.         return p
  116.    
  117.     def getAltitude(self):
  118.         p = self.getPress()
  119.         return (44330*(1-(p/101325)**(1/5.255)))

  120.     def get(self):
  121.         t = []
  122.         t.append(self.getPress())
  123.         t.append(self.getAltitude())
  124.         t.append(self.getTemp())
  125.         return t
復(fù)制代碼


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表