CocoPi.py 65 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793
  1. '''
  2. =========================================================
  3. ______ ______
  4. /\ _ \ /\ _ \ __
  5. \ \ \/\_\ ____ ____ ___\ \ \_\ \/\_\
  6. \ \ \/_/_ / __ \ / __ \ / __'\ \ __/\/_/_
  7. \ \ \_\ \/\ \_\ \/\ \__//\ \_\ \ \ \/ /\ \
  8. \ \____/\ \____/\ \____\ \____/\ \_\ \ \_\
  9. \/___/ \/___/ \/____/\/___/ \/_/ \/_/
  10. __
  11. /\ \ __ ----------------
  12. \ \ \ /\_\ ____ __ __ __ _ pi.cocorobo.cn
  13. \ \ \ \/_/_ / _ \/\ \/\ \/\ \/ \ ----------------
  14. \ \ \____ /\ \/\ \/\ \ \ \_\ \/> </ SYSTEM VERSION
  15. \ \_____\\ \_\ \_\ \_\ \____//\_/\_\ -- 24.07.05 ---
  16. \/_____/ \/_/\/_/\/_/\/___/ \//\/_/ ----------------
  17. =========================================================
  18. '''
  19. #########################################################
  20. # ------------------------------------------------------
  21. #| 封装包内容: | 类名称: |
  22. #|-------------------------------|----------------------|
  23. #| 2023.02.16: | |
  24. #| 【添加】 | |
  25. #| 1、AHT20温湿度传感器 | AHT20 |
  26. #| 2、MPU6050陀螺仪六轴传感器 | MPU6050 |
  27. #| 3、板载4颗按钮A、B、C、D | BUTTON |
  28. #| 4、光线强度传感器 | LIGHTINTENSITY |
  29. #| 5、板载LED灯! | LED |
  30. #| 6、直流电机 | DCMOTOR |
  31. #| 7、模拟舵机 | SERVO |
  32. #|------------------------------------------------------|
  33. #| 2023.02.27: | |
  34. #| 【修复完善】 | BUTTON、LED |
  35. #| 【添加】 | WIFI |
  36. #|------------------------------------------------------|
  37. #| 2023.03.09: | |
  38. #| 【修复完善】 | LED |
  39. #|------------------------------------------------------|
  40. #| 2023.03.14: | |
  41. #| 【修复完善】 | SERVO |
  42. #|-------------------------------------------------------
  43. #| 2023.06.01: | |
  44. #| 【替换】 | BUTTON |
  45. #| 【替换】 | LED |
  46. #| 【替换】 | DCMOTOR |
  47. #| 【替换】 | SERVO |
  48. #| 【添加】 | RGB |
  49. #| 【添加】 | ADC |
  50. #| 【添加】 | DAC |
  51. #| 【添加】 | INPUT |
  52. #| 【添加】 | OUT |
  53. #| 【添加】 | UvcVideo |
  54. #|-------------------------------------------------------
  55. #| 2023.06.15: | |
  56. #| 【更改】 | STM8S |
  57. #|-------------------------------------------------------
  58. #| 2023.08.17: | |
  59. #| 【更改】 | DCMOTOR |
  60. #|-------------------------------------------------------
  61. #| 2023.08.25: | |
  62. #| 【更改】 | BUZZER |
  63. #|-------------------------------------------------------
  64. #| 2023.09.28: | |
  65. #| 【更改】 | QMI8658 |
  66. #########################################################
  67. #|-------------------------------------------------------
  68. #| 2024.02.22: | |
  69. #| 【更改】 | QMI8658 |
  70. #########################################################
  71. #| 2024.02.28: | |
  72. #| 【更改】 | STM8S |
  73. #########################################################
  74. #| 2024.03.07: | |
  75. #| 【添加】 | GPTrequest |
  76. #########################################################
  77. #| 2024.03.11: | |
  78. #| 【修改】 | LED |
  79. #| 【修改】 | DCMOTOR |
  80. #########################################################
  81. #| 2024.03.22: | |
  82. #| 【增加】 | RTC |
  83. #| 【增加】 | PCA9685 |
  84. #########################################################
  85. #| 2024.04.10: | |
  86. #| 【修改】 | GPTrequest |
  87. #########################################################
  88. #| 2024.07.05: | |
  89. #| 【增加】 | LazyImport |
  90. #| 【针对】 | GPTrequest |
  91. #| 【针对】 | uuid |
  92. #| 【针对】 | json |
  93. #| 【针对】 | base64 |
  94. #| 【修改】 | STM8S |
  95. #| 【修改】 | DCMOTOR |
  96. #| 【修改】 | multiFuncGpio |
  97. #| 【增加】 | DS3231 |
  98. #| 【增加】 | SPI_WS2812 |
  99. #| 【增加】 | HCSR04 |
  100. #| 【增加】 | extDcMotor |
  101. #| 【增加】 | extServo |
  102. #| 【增加】 | extGpio |
  103. #| 【拆分】 | GPTrequest |
  104. #########################################################
  105. from smbus2 import SMBus, i2c_msg
  106. import time
  107. import math
  108. from maix import gpio
  109. import os
  110. import SUNXI_GPIO
  111. from maix import camera
  112. import time
  113. import sys
  114. #20240715
  115. import threading
  116. sys.path.append('/root/preset/server')
  117. ##################################
  118. # 1、AHT20温湿度传感器 #
  119. ##################################
  120. # 20250715
  121. AHT20_I2CADDR = 0x38
  122. AHT20_CMD_SOFTRESET = [0xBA]
  123. AHT20_CMD_INITIALIZE = [0xBE, 0x08, 0x00]
  124. AHT20_CMD_MEASURE = [0xAC, 0x33, 0x00]
  125. AHT20_STATUSBIT_BUSY = 7 # The 7th bit is the Busy indication bit. 1 = Busy, 0 = not.
  126. AHT20_STATUSBIT_CALIBRATED = 3 # The 3rd bit is the CAL (calibration) Enable bit. 1 = Calibrated, 0 = not
  127. class AHT20:
  128. def __init__(self, bus_num=2):
  129. self.bus_num = bus_num
  130. self.bus = SMBus(bus_num)
  131. # self._initialize_sensor()
  132. def _initialize_sensor(self):
  133. self._write_command([0xBA])
  134. time.sleep(0.04)
  135. self._write_command([0xBE, 0x08, 0x00])
  136. time.sleep(0.01)
  137. while not self._is_calibrated():
  138. time.sleep(0.01)
  139. def _write_command(self, command):
  140. msg = i2c_msg.write(0x38, command)
  141. self.bus.i2c_rdwr(msg)
  142. def _read_data(self, length):
  143. msg = i2c_msg.read(0x38, length)
  144. self.bus.i2c_rdwr(msg)
  145. return list(msg)
  146. def _is_calibrated(self):
  147. status = self._read_data(1)[0]
  148. return (status >> 3) & 1
  149. def _trigger_measurement(self):
  150. self._write_command([0xAC, 0x33, 0x00])
  151. start_time = time.time()
  152. time.sleep(85 * 10**-3)
  153. while True:
  154. data = self._read_data(7)
  155. if not (data[0] >> 7) & 1: # Check busy bit
  156. return data
  157. if time.time() - start_time > 0.08:
  158. raise TimeoutError("AHT20 measurement timeout")
  159. time.sleep(0.01)
  160. def _crc8(self, data):
  161. crc = 0xFF
  162. for byte in data:
  163. crc ^= byte
  164. for _ in range(8):
  165. if crc & 0x80:
  166. crc = (crc << 1) ^ 0x31
  167. else:
  168. crc <<= 1
  169. crc &= 0xFF
  170. return crc
  171. def read_raw_data(self):
  172. data = self._trigger_measurement()
  173. crc = self._crc8(data[:6])
  174. if crc != data[6]:
  175. raise ValueError("CRC check failed")
  176. return data
  177. def get_humidity(self):
  178. data = self.read_raw_data()
  179. raw_humidity = ((data[1] << 16) | (data[2] << 8) | data[3]) >> 4
  180. return (raw_humidity * 100.0) / (2**20)
  181. def get_temperature(self):
  182. data = self.read_raw_data()
  183. raw_temp = ((data[3] & 0x0F) << 16) | (data[4] << 8) | data[5]
  184. return (raw_temp * 200.0) / (2**20) - 50.0
  185. ##################################
  186. # 2、MPU6050陀螺仪六轴传感器 #
  187. ##################################
  188. SLAVE_ADDR = 0x68
  189. PWR_MGMT_1 = 0x6B
  190. PWR_MGMT_2 = 0x6C
  191. WHO_AM_I = 0x75
  192. GYRO_X = 0x43
  193. GYRO_Y = 0x45
  194. GYRO_Z = 0x47
  195. ACCL_X = 0x3B
  196. ACCL_Y = 0x3D
  197. ACCL_Z = 0x3F
  198. class MPU6050:
  199. def __init__(self, BusNum=2):
  200. # Initialize mpu6050
  201. self.BusNum = BusNum
  202. self.cmd_soft_reset()
  203. def cmd_soft_reset(self):
  204. # Send the command to soft reset
  205. with SMBus(self.BusNum) as bus:
  206. bus.write_byte_data(SLAVE_ADDR, PWR_MGMT_1, 0)
  207. time.sleep(0.04) # Wait 40 ms after poweron
  208. def read_byte(self,addr):
  209. with SMBus(self.BusNum) as bus:
  210. return bus.read_byte_data(SLAVE_ADDR,addr)
  211. def read_word(self,addr):
  212. with SMBus(self.BusNum) as bus:
  213. h = bus.read_byte_data(SLAVE_ADDR, addr)
  214. l = bus.read_byte_data(SLAVE_ADDR, addr+1)
  215. val = (h << 8) + l
  216. return val
  217. def read_word_i2c(self,addr):
  218. val = self.read_word(addr)
  219. if (val >= 0x8000):
  220. return -((65535 - val) + 1)
  221. else:
  222. return val
  223. def dist(self,x, y):
  224. return math.sqrt((x*x) + (y*y))
  225. def get_x_rotat(self,x,y, z):
  226. rad = math.atan2(y,self.dist(x, z))
  227. return math.degrees(rad)
  228. def get_y_rotat(self,x, y, z):
  229. rad = math.atan2(x,self.dist(y, z))
  230. return -math.degrees(rad)
  231. def read_gyro(self):
  232. GYR_X = self.read_word_i2c(GYRO_X)
  233. GYR_Y = self.read_word_i2c(GYRO_Y)
  234. GYR_Z = self.read_word_i2c(GYRO_Z)
  235. #print ("GYRO -> X:{:04.2f} Y:{:04.2f} Z:{:04.2f}".format((GYR_X/131), (GYR_Y/131), (GYR_Z/131)))
  236. return (GYR_X/131), (GYR_Y/131), (GYR_Z/131)
  237. def read_acc(self):
  238. ACC_X = self.read_word_i2c(ACCL_X)
  239. ACC_Y = self.read_word_i2c(ACCL_Y)
  240. ACC_Z = self.read_word_i2c(ACCL_Z)
  241. CALC_ACC_X = ACC_X/16384.0
  242. CALC_ACC_Y = ACC_Y/16384.0
  243. CALC_ACC_Z = ACC_Z/16384.0
  244. #print ("ACCL -> X:{:04.2f} Y:{:04.2f} Z:{:04.2f}".format(CALC_ACC_X, CALC_ACC_Y, CALC_ACC_Z))
  245. #print("ROTATE -> X:{:04.2f} Y:{:04.2f}\n".format(get_x_rotat(CALC_ACC_X, CALC_ACC_Y, CALC_ACC_Z), get_y_rotat(CALC_ACC_X, CALC_ACC_Y, CALC_ACC_Z)))
  246. return CALC_ACC_X, CALC_ACC_Y, CALC_ACC_Z,self.get_x_rotat(CALC_ACC_X, CALC_ACC_Y, CALC_ACC_Z),self.get_y_rotat(CALC_ACC_X, CALC_ACC_Y, CALC_ACC_Z)
  247. def get_gyro_x(self):
  248. return self.read_gyro()[0]
  249. def get_gyro_y(self):
  250. return self.read_gyro()[1]
  251. def get_gyro_z(self):
  252. return self.read_gyro()[2]
  253. def get_acc_x(self):
  254. return self.read_acc()[0]
  255. def get_acc_y(self):
  256. return self.read_acc()[1]
  257. def get_acc_z(self):
  258. return self.read_acc()[2]
  259. def get_angle_x(self):
  260. return self.read_acc()[3]
  261. def get_angle_y(self):
  262. return self.read_acc()[4]
  263. ##################################
  264. # 3、板载4颗按钮A、B、C、D #
  265. ##################################
  266. class BUTTON:
  267. def __init__(self, gpioId):
  268. self.gpio=224+gpioId
  269. SUNXI_GPIO.setcfg(self.gpio, SUNXI_GPIO.IN)
  270. def is_pressed(self):
  271. self.getValue=SUNXI_GPIO.input(self.gpio)
  272. if self.getValue != 1:
  273. return True
  274. else:
  275. return False
  276. ##################################
  277. # 4、光线强度传感器 #
  278. ##################################
  279. class LIGHTINTENSITY:
  280. def __init__(self, addr=b"0x05070080") -> None:
  281. self.addr = addr
  282. self.path = "/sys/class/sunxi_dump/dump"
  283. self.file = open(self.path, "wb+")
  284. self.last = self.value()
  285. def value(self):
  286. self.file.write(b"0x05070080")
  287. self.file.seek(0)
  288. return int(self.file.read()[:-1], 16)
  289. def __del__(self):
  290. try:
  291. if self.file:
  292. self.file.close()
  293. del self.file
  294. except Exception as e:
  295. pass
  296. ##################################
  297. # 5、板载LED灯 #
  298. ##################################
  299. class LED:
  300. def __init__(self, gpioId=69):
  301. self.gpioId=gpioId
  302. SUNXI_GPIO.setcfg(self.gpioId, SUNXI_GPIO.OUT)
  303. SUNXI_GPIO.setcfg(259, SUNXI_GPIO.OUT)
  304. def out(self,value):
  305. if value==0 or value==1:
  306. self.value=1-value
  307. else:
  308. self.value=0
  309. SUNXI_GPIO.output(self.gpioId,self.value)
  310. SUNXI_GPIO.output(259,self.value)
  311. ##################################
  312. # 6、QMI8658 #
  313. ##################################
  314. class QMI8658(object):
  315. def __init__(self, smbus=2, address=0X6B):
  316. self._address = address
  317. import smbus2
  318. self._bus = smbus2.SMBus(smbus)
  319. bRet = self.WhoAmI()
  320. if bRet:
  321. self.Read_Revision()
  322. else:
  323. return None
  324. self.Config_apply()
  325. def _read_byte(self, cmd):
  326. rec = self._bus.read_i2c_block_data(int(self._address), int(cmd), 1)
  327. return rec[0]
  328. def _read_block(self, reg, length=1):
  329. rec = self._bus.read_i2c_block_data(int(self._address), int(reg), length)
  330. return rec
  331. def _read_u16(self, cmd):
  332. LSB = self._bus.read_i2c_block_data(int(self._address), int(cmd), 1)
  333. MSB = self._bus.read_i2c_block_data(int(self._address), int(cmd)+1, 1)
  334. return (MSB[0] << 8) + LSB[0]
  335. def _write_byte(self, cmd, val):
  336. self._bus.write_i2c_block_data(int(self._address), int(cmd), bytes([int(val)]))
  337. def WhoAmI(self):
  338. bRet = False
  339. if (0x05) == self._read_byte(0x00):
  340. bRet = True
  341. return bRet
  342. def Read_Revision(self):
  343. return self._read_byte(0x01)
  344. def Config_apply(self):
  345. self._write_byte(0x02, 0x40)
  346. self._write_byte(0x08, 0x03)
  347. self._write_byte(0x03, 0x04)
  348. self._write_byte(0x04, 0x64)
  349. self._write_byte(0x06, 0x11)
  350. def Read_Raw_XYZ(self):
  351. xyz = [0, 0, 0, 0, 0, 0]
  352. vals={}
  353. raw_timestamp = self._read_block(0x30, 3)
  354. raw_acc_xyz = self._read_block(0x35, 6)
  355. raw_gyro_xyz = self._read_block(0x3b, 6)
  356. raw_xyz = self._read_block(0x35, 12)
  357. timestamp = (raw_timestamp[2] << 16) | (
  358. raw_timestamp[1] << 8) | (raw_timestamp[0])
  359. for i in range(6):
  360. xyz[i] = (raw_xyz[(i*2)+1] << 8) | (raw_xyz[i*2])
  361. if xyz[i] >= 32767:
  362. xyz[i] = xyz[i]-65535
  363. vals["AcX"]=xyz[0]
  364. vals["AcY"]=xyz[1]
  365. vals["AcZ"]=xyz[2]
  366. vals["GyX"]=xyz[3]
  367. vals["GyY"]=xyz[4]
  368. vals["GyZ"]=xyz[5]
  369. return vals
  370. def Read_XYZ(self):
  371. xyz = [0, 0, 0, 0, 0, 0]
  372. raw_xyz = self.Read_Raw_XYZ()
  373. #QMI8658AccRange_8g
  374. acc_lsb_div = (1 << 12)
  375. #QMI8658GyrRange_512dps
  376. gyro_lsb_div = 64
  377. for i in range(3):
  378. xyz[i] = raw_xyz[i]/acc_lsb_div # (acc_lsb_div/1000.0)
  379. xyz[i+3] = raw_xyz[i+3]*1.0/gyro_lsb_div
  380. return xyz
  381. def get_accel(self, samples=10, calibration=None):
  382. result = {}
  383. for _ in range(samples):
  384. v = self.Read_Raw_XYZ()
  385. for m in v.keys():
  386. result[m] = result.get(m, 0) + v[m] / samples
  387. if calibration:
  388. for m in calibration.keys():
  389. if m == "AcZ":
  390. pass
  391. else:
  392. result[m] -= calibration[m]
  393. return result
  394. def calibrate(self, threshold=50):
  395. print('Calibrating QMI8658... ', end='')
  396. while True:
  397. v1 = self.get_accel(100)
  398. v2 = self.get_accel(100)
  399. if all(abs(v1[m] - v2[m]) < threshold for m in v1.keys()):
  400. print('Done.')
  401. return v1
  402. def getPitchYawRollGxGyGz(self,calibration):
  403. caliData=self.get_accel(10, calibration)
  404. pitch=caliData["AcX"]/182.04
  405. yaw=caliData["AcY"]/182.04
  406. roll=caliData["AcZ"]/182.04
  407. groX=caliData["GyX"]
  408. groY=caliData["GyY"]
  409. groZ=caliData["GyZ"]
  410. if roll<0:
  411. if pitch >=0:
  412. pitch=180-pitch
  413. elif pitch <0:
  414. pitch=(180+pitch)*(-1)
  415. if yaw >=0:
  416. yaw=180-yaw
  417. elif pitch <0:
  418. yaw=(180+yaw)*(-1)
  419. return [pitch,yaw,roll,groX,groY,groZ]
  420. ##################################
  421. # 7、STM8S #
  422. ##################################
  423. import smbus2
  424. import time
  425. class stm8s(object):
  426. bus = smbus2.SMBus(2) # 2 indicates /dev/i2c-2
  427. address = 0x50
  428. # 0x00 # 触发配置
  429. # 0x01 # 重置配置
  430. # 0x02 # pwm0 历史配置
  431. # 0x03 # pwm1 历史配置
  432. # 引脚配置模式有 1. pwm 2. gpio ouput gpio input 3. adc 4.ws2812_singe 5 ws2812_multi
  433. def __init__(self):
  434. self.reset()
  435. time.sleep(0.05)
  436. pass
  437. def clear(self):
  438. self.write(1, 1)
  439. self.reset()
  440. time.sleep(0.05)
  441. def write(self, addr, val):
  442. for i in range(0, 3):
  443. try:
  444. self.bus.write_byte_data(self.address, addr, val)
  445. time.sleep(0.001) # 1ms
  446. # print(addr, val) # debug
  447. return True
  448. except Exception:
  449. time.sleep(0.01)
  450. continue
  451. return False
  452. def fastWrite(self,addr,valBlock):
  453. try:
  454. self.bus.write_i2c_block_data(self.address,addr,valBlock)
  455. return True
  456. except Exception:
  457. return False
  458. def read(self, addr):
  459. for i in range(0, 3):
  460. try:
  461. tmp = self.bus.read_byte_data(self.address, addr)
  462. time.sleep(0.001) # 1ms
  463. # print(addr, tmp) # debug
  464. return tmp
  465. except Exception:
  466. time.sleep(0.01)
  467. continue
  468. return None
  469. def reset(self):
  470. self.write(0, 1)
  471. time.sleep(0.05) # 重启并配置需要时间
  472. def dump(self):
  473. for i in range(0, 32):
  474. print(i, self.read(i))
  475. class singleRgb(stm8s):
  476. def __init__(self):
  477. self.valR=0
  478. self.valG=0
  479. self.valB=0
  480. self.brightness=255
  481. self.show()
  482. def setColor(self,r,g,b):
  483. if(r>=0 and r<=255):
  484. self.valR=int(r*self.brightness/255)
  485. else:
  486. self.valR=0
  487. if(g>=0 and g<=255):
  488. self.valG=int(g*self.brightness/255)
  489. else:
  490. self.valG=0
  491. if(b>=0 and b<=255):
  492. self.valB=int(b*self.brightness/255)
  493. else:
  494. self.valB=0
  495. def setBrightness(self,brightness):
  496. if(brightness>=0 and brightness<=255):
  497. self.brightness=brightness
  498. else:
  499. self.brightness=0
  500. def show(self):
  501. self.write(31, self.valB)
  502. self.write(30, self.valG)
  503. self.write(29, self.valR)
  504. self.write(28, 6)
  505. class dcMotor(stm8s):
  506. def __init__(self,id):
  507. self.id=id
  508. def m1a(self,val=0):
  509. self.write(4,5) #M1A
  510. #self.write(5,0)
  511. #self.write(6,0)
  512. self.write(7,val)
  513. def m1b(self,val=0):
  514. self.write(8,5) #M1B
  515. #self.write(9,0)
  516. #self.write(10,0)
  517. self.write(11,val)
  518. def m2a(self,val=0):
  519. self.write(12,5) #M2A
  520. #self.write(13,0)
  521. #self.write(14,0)
  522. self.write(15,val)
  523. def m2b(self,val=0):
  524. self.write(16,5) #M2B
  525. #self.write(17,0)
  526. #self.write(18,0)
  527. self.write(19,val)
  528. def dcMotorCtrl(self,dir,speed):
  529. dir=1-dir
  530. if(0<speed and speed<255):
  531. if(self.id ==1): #Motor1
  532. if(dir==0):
  533. self.m1a(speed)
  534. self.m1b(255)
  535. else:
  536. self.m1a(255)
  537. self.m1b(speed)
  538. elif(self.id ==2):
  539. if(dir==0):
  540. self.m2a(speed)
  541. self.m2b(255)
  542. else:
  543. self.m2a(255)
  544. self.m2b(speed)
  545. elif(0==speed):
  546. if(self.id ==1): #Motor1
  547. if(dir==0):
  548. self.m1a(255)
  549. self.m1b(255)
  550. else:
  551. self.m1a(255)
  552. self.m1b(255)
  553. elif(self.id ==2):
  554. if(dir==0):
  555. self.m2a(255)
  556. self.m2b(255)
  557. else:
  558. self.m2a(255)
  559. self.m2b(255)
  560. elif(speed==255):
  561. if(self.id ==1): #Motor1
  562. if(dir==0):
  563. self.m1a(0)
  564. self.m1b(255)
  565. else:
  566. self.m1a(255)
  567. self.m1b(0)
  568. elif(self.id ==2):
  569. if(dir==0):
  570. self.m2a(0)
  571. self.m2b(255)
  572. else:
  573. self.m2a(255)
  574. self.m2b(0)
  575. else:
  576. pass
  577. class multiFuncGpio(stm8s):
  578. def __init__(self,id=0,mode=0):
  579. self.id=id
  580. self.rgbId=0
  581. self.brightness=255
  582. self.mode=mode
  583. self.write(20+self.id*4,self.mode)
  584. self.rgbSerial=[0,0,0]*10
  585. time.sleep(0.05)
  586. ##################################################
  587. # mode | 0 | 1 | 2 | 3 | 4 | 5 | 6 |
  588. #-------------------------------------------------
  589. # Func |free |servo|INPUT| OUT | ADC | PWM | BEEP|
  590. ##################################################
  591. # mode=0,为空闲状态,引脚不执行任何功能
  592. # mode=1,为控制舵机模式,值控制范围为0°~180°
  593. # mode=2,为数字输入模式,返回值0或1
  594. # mode=3,为数字输出模式,输出值为0或1
  595. # mode=4,为ADC采样模式,返回值为0~1023
  596. # mode=5,为PWM输出模式,输出值范围为0~255
  597. # mode=6,为控制蜂鸣器模式,控制范围为20hz~12000hz
  598. # mode=7,为控制灯带模式,暂未实现
  599. # id=0,控制多功能引脚1,向20号寄存器写入模式数据
  600. # id=1,控制多功能引脚2,向24号寄存器写入模式数据
  601. def servoCtrl(self,angle):
  602. if ((angle>=0) and (angle<=180)):
  603. self.write(23+self.id*4,angle)
  604. else:
  605. pass
  606. def digitalRead(self):
  607. try:
  608. self.gpioVal= self.read(23+ self.id*4)
  609. if(self.gpioVal != None):
  610. return self.gpioVal
  611. except:
  612. print("ERROR 233")
  613. def digitalWrite(self,val):
  614. if ((val>=0) and (val<=1)):
  615. self.write(23+self.id*4,val)
  616. else:
  617. pass
  618. def analogRead(self):
  619. try:
  620. self.adcValH= self.read(22+ self.id*4)
  621. self.adcValL= self.read(23+ self.id*4)
  622. if (self.adcValH != None and self.adcValL != None):
  623. # adcValH adcValL 大小端合并 16bit
  624. self.adcVal = self.adcValL + (self.adcValH << 8)
  625. return self.adcVal
  626. except:
  627. print("ERROR 2333")
  628. def analogWrite(self,val):
  629. if ((val>=0) and (val<=255)):
  630. self.write(23+self.id*4,val)
  631. else:
  632. pass
  633. def beep(self,frequency):
  634. if ((frequency>=20) and (frequency<=12000)):
  635. self.write(22+self.id*4,frequency>>8)
  636. self.write(23+self.id*4,frequency&0b11111111)
  637. else:
  638. pass
  639. def pixelInit_(self):
  640. for i in range(16):
  641. self.setPixelColor(i,0,0,0)
  642. self.pixelShow()
  643. self.write(23+self.id*4,1)
  644. def setBrightness(self,brightness):
  645. if(brightness>=0 and brightness<=255):
  646. self.brightness=brightness
  647. else:
  648. self.brightness=0
  649. def setPixelColor(self,rgbId,r,g,b):
  650. if(rgbId >=0 and rgbId <=15):
  651. self.rgbId=rgbId #rgbId范围:0~15
  652. else:
  653. self.rgbId=0
  654. if(r>=0 and r<=255):
  655. self.valR=int(r*self.brightness/255)
  656. else:
  657. self.valR=0
  658. if(g>=0 and g<=255):
  659. self.valG=int(g*self.brightness/255)
  660. else:
  661. self.valG=0
  662. if(b>=0 and b<=255):
  663. self.valB=int(b*self.brightness/255)
  664. else:
  665. self.valB=0
  666. #self.id的值为0或1,用于控制灯带缓冲区(S1或者S2引脚)
  667. def pixelShow(self):
  668. self.write(32+ self.id*48+self.rgbId*3, self.valR)
  669. self.write(33+ self.id*48+self.rgbId*3, self.valG)
  670. self.write(34+ self.id*48+self.rgbId*3, self.valB)
  671. def setRgbSerialColor(self,rgbId,r,g,b):
  672. if(rgbId >=0 and rgbId <=15):
  673. self.rgbId=rgbId #rgbId范围:0~15
  674. else:
  675. self.rgbId=0
  676. if(r>=0 and r<=255):
  677. self.valR=int(r*self.brightness/255)
  678. else:
  679. self.valR=0
  680. if(g>=0 and g<=255):
  681. self.valG=int(g*self.brightness/255)
  682. else:
  683. self.valG=0
  684. if(b>=0 and b<=255):
  685. self.valB=int(b*self.brightness/255)
  686. else:
  687. self.valB=0
  688. self.rgbSerial[self.rgbId*3]=self.valR
  689. self.rgbSerial[self.rgbId*3+1]=self.valG
  690. self.rgbSerial[self.rgbId*3+2]=self.valB
  691. def rgbSerialShow(self):
  692. self.fastWrite(32+self.id*48,self.rgbSerial)
  693. self.write(23+self.id*4,1)
  694. ##################################
  695. # 8、UvcVideo #
  696. ##################################
  697. class UvcVideo(camera.MaixVideo):
  698. def __init__(self, source="/dev/videoX"):
  699. self.source = source
  700. super(UvcVideo, self).__init__()
  701. import os, time
  702. usb_path = '/sys/devices/platform/soc/usbc0/otg_role'
  703. # 确认 usb_path 内容为 usb_host 如果不是,自动设置为 usb_host
  704. if os.popen('cat %s' % usb_path).read().strip() != 'usb_host':
  705. os.system('echo "usb_host" > %s' % usb_path)
  706. time.sleep(2) # 要设置 2s 左右才能初始化工作,否则会报 VIDIOC_S_FMT 失败。
  707. def config(self, size=None, video=2, horizontal=0, vertical=0):
  708. if size == None:
  709. size = (320, 240)
  710. super(UvcVideo, self).config(size)
  711. print('[camera] config input size(%d, %d, %d)' %
  712. (self.width(), self.height(), video))
  713. if self.cam:
  714. self.cam = None
  715. try:
  716. import _coco_camera
  717. self.cam = _coco_camera.Camera(self.width(), self.height(), video, horizontal, vertical)
  718. except Exception as e:
  719. print(e)
  720. self.cam = None
  721. def read(self):
  722. if self.cam == None:
  723. self.config()
  724. if self.cam:
  725. ret, frame = self.cam.read()
  726. if ret:
  727. return frame # bytes
  728. else:
  729. try:
  730. self.config()
  731. except Exception as e:
  732. print(e)
  733. return None
  734. def __del__(self):
  735. if self.cam:
  736. self.cam = None
  737. ##################################
  738. # 9、DS3231 #
  739. ##################################
  740. from math import floor
  741. class DS3231(object):
  742. # create RTC instance
  743. def __init__(self):
  744. self.bus = smbus2.SMBus(2) # 2 indicates /dev/i2c-2
  745. self.address = 0x68
  746. def bcd_to_int(self,bcd, n=2):
  747. """Decode n least significant packed binary coded decimal digits to binary.
  748. Return binary result.
  749. n defaults to 2 (BCD digits).
  750. n=0 decodes all digits.
  751. """
  752. return int(('%x' % bcd)[-n:])
  753. def int_to_bcd(self,x, n=2):
  754. """
  755. Encode the n least significant decimal digits of x
  756. to packed binary coded decimal (BCD).
  757. Return packed BCD value.
  758. n defaults to 2 (digits).
  759. n=0 encodes all digits.
  760. """
  761. return int(str(x)[-n:], 0x10)
  762. def read(self, addr):
  763. for i in range(0, 3):
  764. try:
  765. tmp = self.bus.read_byte_data(self.address, addr)
  766. time.sleep(0.001) # 1ms
  767. # print(addr, tmp) # debug
  768. return tmp
  769. except Exception:
  770. time.sleep(0.01)
  771. continue
  772. return None
  773. def write(self, addr, val):
  774. for i in range(0, 3):
  775. try:
  776. self.bus.write_byte_data(self.address, addr, val)
  777. #time.sleep(0.001) # 1ms
  778. # print(addr, val) # debug
  779. return True
  780. except Exception:
  781. time.sleep(0.001)
  782. continue
  783. return False
  784. # set times functions ----------------------------------------
  785. def setYear(self, year):
  786. # only last two digits (last two digits are used if longer)
  787. self.write(0x06, self.int_to_bcd(year%100))
  788. def setMonth(self, month):
  789. if not 1 <= month <= 12:
  790. raise ValueError('Month is out of range [1,12].')
  791. self.write(0x05,self.int_to_bcd(month))
  792. def setDay(self, day):
  793. if not 1 <= day <= 31:
  794. raise ValueError('Day is out of range [1,31].')
  795. self.write(0x04,self.int_to_bcd(day))
  796. def setDayOfWeek(self, dayOfWeek):
  797. if not 1 <= dayOfWeek <= 7:
  798. raise ValueError('Day of week is out of range [1,7].')
  799. self.write(0x03,self.int_to_bcd(dayOfWeek))
  800. def setHour(self, hour):
  801. if not 0 <= hours < 24:
  802. raise ValueError('Hours is out of range [0,23].')
  803. self.write(0x02,self.int_to_bcd(hour)& 0x3F)
  804. def setMinutes(self, minutes):
  805. if not 0 <= minutes < 59:
  806. raise ValueError('Minutes is out of range [0,59].')
  807. self.write(0x01,self.int_to_bcd(minutes))
  808. def setSeconds(self, seconds):
  809. if not 0 <= seconds < 60:
  810. raise ValueError('Seconds is out of range [0,59].')
  811. self.write(0x00,self.int_to_bcd(seconds))
  812. def setDateTime(self, year, month, day, dayOfWeek, hour, minutes, seconds):
  813. # set all the date and times (year is last two digits of year)
  814. self.setYear(year)
  815. self.setMonth(month)
  816. self.setDay(day)
  817. self.setDayOfWeek(dayOfWeek)
  818. self.setHour(hour)
  819. self.setMinutes(minutes)
  820. self.setSeconds(seconds)
  821. # get times functions -------------------------------------------------
  822. def getYear(self):
  823. return self.bcd_to_int(self.read(0x06))
  824. def getMonth(self):
  825. temp = self.read(0x05)
  826. return self.bcd_to_int((temp<<4>>4) &0x7F)
  827. #return temp[0] & 0x7F
  828. def getDay(self):
  829. # 0 - 31
  830. return self.bcd_to_int(self.read(0x04))
  831. def getDayOfWeek(self):
  832. # 1 - 7
  833. return self.bcd_to_int(self.read(0x03))
  834. def getHour(self):
  835. temp = self.read(0x02)
  836. if temp==0x64: #if hour is 24:00,convert it to 00:00
  837. temp=0x40
  838. return self.bcd_to_int((temp<< 4 >>4)& 0x3F)
  839. #return temp[0] & 0x3F
  840. def getMinutes(self):
  841. return self.bcd_to_int(self.read(0x01))
  842. def getSeconds(self):
  843. return self.bcd_to_int(self.read(0x00))
  844. def getDateTime(self):
  845. # returns whole date and time as list
  846. # (last two digits of year, month, day, day of week, hour, minutes, seconds)
  847. dateTime = [0, 0, 0, 0, 0, 0, 0]
  848. dateTime[0] = self.getYear()
  849. dateTime[1] = self.getMonth()
  850. dateTime[2] = self.getDay()
  851. dateTime[3] = self.getDayOfWeek()
  852. dateTime[4] = self.getHour()
  853. dateTime[5] = self.getMinutes()
  854. dateTime[6] = self.getSeconds()
  855. return dateTime
  856. def convertToByteType(self,number):
  857. return bytes([number])
  858. def decodeToDec(self,byte):
  859. return ((byte[0] >> 4) * 10) + (byte[0] & 0x0F)
  860. def encodeToByte(self,dec):
  861. tens = floor(dec / 10)
  862. ones = dec - tens*10
  863. return (tens << 4) + ones
  864. def decodeAlarmType(self,alarmTime):
  865. if(len(alarmTime) > 4):
  866. m1Bit = (alarmTime[3] & 0x80) >> 7
  867. else:
  868. m1Bit = False
  869. m2Bit = (alarmTime[2] & 0x80) >> 7
  870. m3Bit = (alarmTime[1] & 0x80) >> 7
  871. m4Bit = (alarmTime[0] & 0x80) >> 7
  872. dayBit = (alarmTime[0] & 0x40) >> 6
  873. if(m1Bit and m2Bit and m3Bit and m4Bit):
  874. return "everySecond"
  875. elif(not m1Bit and m2Bit and m3Bit and m4Bit):
  876. return "everyMinute"
  877. elif(not m1Bit and not m2Bit and m3Bit and m4Bit):
  878. return "everyHour"
  879. elif(not m1Bit and not m2Bit and not m3Bit and m4Bit):
  880. return "everyDay"
  881. elif(not dayBit and not m1Bit and not m2Bit and not m3Bit and not m4Bit):
  882. return "everyMonth"
  883. elif(dayBit and not m1Bit and not m2Bit and not m3Bit and not m4Bit):
  884. return "everyWeek"
  885. else:
  886. return "noValidAlarmType"
  887. def decodeAlarmTime(self,alarmTime):
  888. alarmTime[0] = decodeToDec(convertToByteType(alarmTime[0] & 0x3F))
  889. alarmTime[1] = decodeToDec(convertToByteType(alarmTime[1] & 0x3F))
  890. alarmTime[2] = decodeToDec(convertToByteType(alarmTime[2] & 0x7F))
  891. if(len(alarmTime) > 4):
  892. alarmTime[3] = decodeToDec(convertToByteType(alarmTime[3] & 0x7F))
  893. return alarmTime
  894. def encodeAlarmType(self,alarmType):
  895. if(alarmType == "everySecond"):
  896. return 15 #0b01111
  897. elif(alarmType == "everyMinute"):
  898. return 14 #0b01110
  899. elif(alarmType == "everyHour"):
  900. return 12 #0b01100
  901. elif(alarmType == "everyDay"):
  902. return 8 #0b01000
  903. elif(alarmType == "everyMonth"):
  904. return 0 #0b00000
  905. elif(alarmType == "everyWeek"):
  906. return 16 #0b10000
  907. else:
  908. raise ValueError("""Not a supported alarmType. Options are:
  909. 'everySecond' (only Alarm 1), 'everyMinute', 'everyHour', 'everyDay', 'everyMonth', 'everyWeek'""")
  910. def encodeDateTime(self,day, hour, minutes, seconds, alarmType):
  911. alarmBits = encodeAlarmType(alarmType)
  912. alarmTime = [0, 0, 0, 0]
  913. alarmTime[0] = (encodeToByte(day) & 0x3F) | ((alarmBits & 0x10) << 2) | ((alarmBits & 0x08) << 4)
  914. alarmTime[1] = (encodeToByte(hour) & 0x3F) | ((alarmBits & 0x04) << 5)
  915. alarmTime[2] = (encodeToByte(minutes) & 0x7F) | ((alarmBits & 0x02) << 6)
  916. alarmTime[3] = (encodeToByte(seconds) & 0x7F) | ((alarmBits & 0x01) << 7)
  917. return alarmTime
  918. ##################################
  919. # 10、SPI_WS2812 #
  920. ##################################
  921. class SPI_WS2812(object):
  922. from maix import spi
  923. spi = spi.SpiDev()
  924. def __init__(self,num):
  925. self.num=num
  926. self.spi.open(0, 0)
  927. self.spi.mode = 3
  928. self.spi.bits_per_word = 8
  929. self.spi.max_speed_hz = 20000000
  930. self.data=[[0,0,0]]*self.num
  931. self.brightness=255
  932. def setRgbColor(self,id,r,g,b):
  933. if id>(self.num-1):
  934. raise ValueError("Out of range!")
  935. else:
  936. self.data[id]=[int(g*self.brightness/255),int(r*self.brightness/255),int(b*self.brightness/255)]
  937. #print("set complete!")
  938. def setBrightness(self,brightness):
  939. if brightness>255 or brightness<0:
  940. raise ValueError("Out of range!")
  941. self.brightness=brightness
  942. def rgbShow(self):
  943. tx=[]
  944. for rgb in self.data:
  945. for byte in rgb:
  946. for ibit in range(3,-1,-1):
  947. tx.append(((byte>>(2*ibit+1))&1)*0x60 +
  948. ((byte>>(2*ibit+0))&1)*0x06 +
  949. 0x88)
  950. print([hex(v) for v in tx])
  951. tx[0]=0b1000000
  952. tx.append(0b1000000)
  953. self.spi.xfer(tx,int(4/1.05e-6))
  954. def __del__(self):
  955. self.data=[[0,0,0]]*self.num
  956. self.rgbShow()
  957. ##################################
  958. # 11、HCSR04 #
  959. ##################################
  960. class HCSR04:
  961. def __init__(self,Trig,Echo):
  962. pinNum={"TXD":"198","RXD":"199","CLK":"224","MOSI":"225","MISO":"226","CS":"227"}
  963. os.system("insmod /home/drivers/hcsr04.ko")
  964. pinCmd=pinNum.get(Trig)+","+pinNum.get(Echo)+",23200,0"
  965. os.system('echo "'+pinCmd+'" > /sys/class/hcsr04/value')
  966. def getDistance(self):
  967. startTime=round(time.time(),3)
  968. #print("startTime:"+str(startTime))
  969. while True:
  970. dis=os.popen("cat /sys/class/hcsr04/value").read()
  971. #print("dis:"+str(dis)+" len:"+str(len(dis)))
  972. if "-1" in dis:
  973. pass
  974. else:
  975. dis=round(int(dis)/58,2)
  976. if dis<250:
  977. return dis
  978. else:
  979. pass
  980. if((round(time.time(),3)-startTime)>=1.200):#超时时间
  981. return -1
  982. def __del__(self):
  983. os.system("rmmod /home/drivers/hcsr04.ko")
  984. import struct
  985. import math
  986. import os
  987. ##################################
  988. # 12、MCP23017 #
  989. ##################################
  990. class MCP23017(object):
  991. bus = smbus2.SMBus(2) # 2 indicates /dev/i2c-2
  992. address = 0x20
  993. iodira=0x00 #A引脚方向寄存器地址。初始值为0xFF,输入模式
  994. iodirb=0x01 #B引脚方向寄存器地址。初始值为0xFF,输入模式
  995. gppua=0x0c #A引脚上拉电阻配置寄存器地址。初始值为0x00,无上拉
  996. gppub=0x0d #B引脚上拉电阻配置寄存器地址,初始值为0x00,无上拉
  997. gpioa=0x12 #A端口寄存器,初始值为0x00,低电平
  998. gpiob=0x13 #B端口寄存器,初始值为0x00,低电平
  999. DIR_A_V=0xff #A引脚方向初始值
  1000. DIR_B_V=0xff #B引脚方向初始值
  1001. GPPU_A_V=0x00 #A引脚上拉设定初始值
  1002. GPPU_B_V=0x00 #B引脚上拉设定初始值
  1003. GPIO_A_V=0x00 #A引脚电平初始值
  1004. GPIO_B_V=0x00 #B引脚电平初始值
  1005. def __init__(self):
  1006. self.reset()
  1007. def reset(self):
  1008. self.DIR_A=self.DIR_A_V
  1009. self.DIR_B=self.DIR_B_V
  1010. self.GPPU_A=self.GPPU_A_V
  1011. self.GPPU_B=self.GPPU_B_V
  1012. self.GPIO_A=self.GPIO_A_V
  1013. self.GPIO_B=self.GPIO_B_V
  1014. self.byteWrite(self.iodira,self.DIR_A_V)
  1015. self.byteWrite(self.iodirb,self.DIR_B_V)
  1016. self.byteWrite(self.gppua,self.GPPU_A_V)
  1017. self.byteWrite(self.gppub,self.GPPU_B_V)
  1018. self.byteWrite(self.gpioa,self.GPIO_A_V)
  1019. self.byteWrite(self.gpiob,self.GPIO_B_V)
  1020. print("mcp23017 reset completed!")
  1021. def byteWrite(self, addr, val):
  1022. try:
  1023. self.bus.write_byte_data(self.address, addr, val)
  1024. return True
  1025. except Exception:
  1026. pass
  1027. def byteRead(self,addr):
  1028. tmp = self.bus.read_byte_data(self.address, addr)
  1029. return tmp
  1030. def bitWrite(self,reg,num,val): #寄存器值(byte类型),寄存器第...位(0-7),该位的值(0/1)
  1031. return (reg>>(num+1)<<(num+1))|(val << num)|(reg<<(8-num)&0xFF)>>(8-num)
  1032. def bitRead(self,reg,num): #寄存器值(byte类型),寄存器第...位(0-7)
  1033. return ((reg<<(7-num)&0xFF)>>7)
  1034. def setGpioDir(self,channel,pinId,direction): #set gpio direction
  1035. #channel:"A" or "B"
  1036. #pinId:0~7
  1037. #direction:[0:output],[1:input(default)]
  1038. if channel=="A":
  1039. self.DIR_A=self.bitWrite(self.DIR_A,pinId,direction)
  1040. print("Dir_A="+str(self.DIR_A))
  1041. self.byteWrite(self.iodira,self.DIR_A)
  1042. elif channel=="B":
  1043. self.DIR_B=self.bitWrite(self.DIR_B,pinId,direction)
  1044. self.byteWrite(self.iodirb,self.DIR_B)
  1045. else:
  1046. raise ValueError("Error Channel!")
  1047. def setGppuEnable(self,channel,pinId,pullup): #set gpio pullup on or off
  1048. #channel:"A" or "B"
  1049. #pinId:0~7
  1050. #pullup:[0:disable],[1:enable(default)]
  1051. if channel=="A":
  1052. self.GPPU_A=self.bitWrite(self.GPPU_A,pinId,pullup)
  1053. self.byteWrite(self.gppua,self.GPPU_A)
  1054. elif channel=="B":
  1055. self.GPPU_B=self.bitWrite(self.GPPU_B,pinId,pullup)
  1056. self.byteWrite(self.gppub,self.GPPU_B)
  1057. else:
  1058. raise ValueError("Error Channel!")
  1059. def setGpioLevel(self,channel,pinId,level): #set gpio volt level
  1060. #channel:"A" or "B"
  1061. #pinId:0~7
  1062. #level:[0:low(default)],[1:high]
  1063. if channel=="A":
  1064. self.GPIO_A=self.bitWrite(self.GPIO_A,pinId,level)
  1065. self.byteWrite(self.gpioa,self.GPIO_A)
  1066. elif channel=="B":
  1067. self.GPIO_B=self.bitWrite(self.GPIO_B,pinId,level)
  1068. self.byteWrite(self.gpiob,self.GPIO_B)
  1069. else:
  1070. raise ValueError("Error Channel!")
  1071. def getGpioLevel(self,channel,pinId): #get gpio volt level
  1072. #channel:"A" or "B"
  1073. #pinId:0~7
  1074. #level:[0:low(default)],[1:high]
  1075. if channel=="A":
  1076. return self.bitRead(self.byteRead(self.gpioa),pinId)
  1077. elif channel=="B":
  1078. return self.bitRead(self.byteRead(self.gpiob),pinId)
  1079. else:
  1080. raise ValueError("Error Channel!")
  1081. def __del__(self):
  1082. self.reset()
  1083. time.sleep(0.001)
  1084. print("del mcp23017")
  1085. class ADS1115(object):
  1086. bus = smbus2.SMBus(2) # 2 indicates /dev/i2c-2
  1087. # Registers in the ADS1115,设备的4个寄存器
  1088. DEVICE_REG_CONVERSION = 0x00 #转换寄存器
  1089. DEVICE_REG_CONFIG = 0x01 #配置寄存器
  1090. DEVICE_REG_LO_THRESH = 0x02 #最低阈值寄存器
  1091. DEVICE_REG_HI_THRESH = 0x03 #最高阈值寄存器
  1092. # Configuration register fields #配置寄存器展开,共16bit
  1093. # Operational Status #操作状态,在第15位
  1094. CONFIG_OS = 0X8000 #无效
  1095. CONFIG_OS_START = 0X8000 #开始单次转换(处于掉电状态)
  1096. CONFIG_OS_PERFORMING_CONVERSION = 0X0000 #转换进行中
  1097. CONFIG_OS_NOT_PERFORMING_OPERATION = 0X8000 #转换闲置
  1098. # Differential measurements #测量模式设置,在第12-14位
  1099. CONFIG_MUX_AIN0P_AIN1N = 0X0000 # (default) #AIN0差分输入,AIN1作为参考
  1100. CONFIG_MUX_AIN1P_AIN3N = 0X1000 #AIN1差分输入,AIN3作为参考
  1101. CONFIG_MUX_AIN2P_AIN3N = 0X2000 #AIN2差分输入,AIN3作为参考
  1102. CONFIG_MUX_AIN3P_AIN3N = 0X3000 #AIN3差分输入,AIN3作为参考
  1103. # Single ended measurements #单端测量
  1104. CONFIG_MUX_AIN0P_GNDN = 0X4000 #AIN0单端输入
  1105. CONFIG_MUX_AIN1P_GNDN = 0X5000 #AIN1单端输入
  1106. CONFIG_MUX_AIN2P_GNDN = 0X6000 #AIN2单端输入
  1107. CONFIG_MUX_AIN3P_GNDN = 0X7000 #AIN3单端输入
  1108. # Programmable gain amplifier configuration #可编程增益放大器(量程选择)FSR:Feedback Shift Register,反馈移位寄存器,在第9-11位
  1109. CONFIG_FSR_6V144 = 0X0000 #CocoPi 需选择
  1110. CONFIG_FSR_4V096 = 0X0200
  1111. CONFIG_FSR_2V048 = 0X0400 # (default)
  1112. CONFIG_FSR_1V024 = 0X0600
  1113. CONFIG_FSR_0V512 = 0X0800
  1114. CONFIG_FSR_0V256 = 0X0A00
  1115. CONFIG_FSR_0V256 = 0X0C00
  1116. CONFIG_FSR_0V256 = 0X0E00
  1117. # Continuous or single shot mode #设备运行模式:持续转换或者单次转换,在第8位
  1118. CONFIG_MODE_CONTINUOUS = 0X0000 #持续转换
  1119. CONFIG_MODE_SINGLE_SHOT = 0X0100 # (default) #单次转换
  1120. # Data rate #转换速率,第5-7位
  1121. CONFIG_DATA_RATE_8SPS = 0X0000 #SPS:Samples Per Second,每秒8次采样
  1122. CONFIG_DATA_RATE_16SPS = 0X0020
  1123. CONFIG_DATA_RATE_32SPS = 0X0040
  1124. CONFIG_DATA_RATE_64SPS = 0X0060
  1125. CONFIG_DATA_RATE_128SPS = 0X0080 #(default)
  1126. CONFIG_DATA_RATE_2508SPS = 0X00A0
  1127. CONFIG_DATA_RATE_475SPS = 0X00C0
  1128. CONFIG_DATA_RATE_860SPS = 0X00E0
  1129. # Comparitor mode #比较器模式,第4位
  1130. CONFIG_COMP_MODE_TRADITIONAL = 0X0000 #(default) #传统比较器
  1131. CONFIG_COMP_MODE_WINDOW = 0X0010 #窗口模式
  1132. # Comparitor polarity #比较器集型,第3位,控制ALRET/RDY引脚极性
  1133. CONFIG_COMP_POL_ACTIVE_LOW = 0X0000 #(default) #低电平有效(默认)
  1134. CONFIG_COMP_POL_ACTIVE_HIGH = 0X0008 #高电平有效
  1135. # Comparitor latching #锁存比较器,第2位,该位控制ALERT/RDY引脚在被置为有效后锁存,还是在转换后处于上限和下限阈值范围内清零
  1136. CONFIG_COMP_LAT = 0X0004
  1137. CONFIG_COMP_LAT_NON_LATCHING = 0X0000 #(default) #默认不锁存
  1138. CONFIG_COMP_LAT_LATCHING = 0X0004
  1139. # comparitor queue and disable #比较器置位和禁用
  1140. CONFIG_COMP_QUE = 0X0003 #默认禁用比较器并将ALERT/RDY引脚设置为高阻抗
  1141. CONFIG_COMP_QUE_1_CONV = 0X0000 #一次转换后断言
  1142. CONFIG_COMP_QUE_2_CONV = 0X0001 #两次转换后置位
  1143. CONFIG_COMP_QUE_4_CONV = 0X0002 #四次转换后置位
  1144. CONFIG_COMP_QUE_DISABLE = 0X0003 #(default) #默认禁用比较器并将ALERT/RDY引脚设置为高阻抗
  1145. # Address for the device ,设备地址选择
  1146. #addr=0x48 # ADDR tied to GND
  1147. addr=0x49 # ADDR tied to VDD
  1148. #addr=0x4A # ADDR tied to SDA
  1149. #addr=0x4B # ADDR tied to SCL
  1150. def __init__(self):
  1151. self.address=0x49
  1152. self.config=0x0000
  1153. #time.sleep(0.05)
  1154. pass
  1155. def swap(self,val):
  1156. return (((val&0xff00)>>8)|((val&0x00ff)<<8)) #交换高8位与低8位
  1157. ###
  1158. def readAdc(self,channel):
  1159. if (channel>3) or (channel<0):
  1160. return False
  1161. self.config=(self.CONFIG_OS_START + # start conversion
  1162. #self.CONFIG_MUX_AIN0P_GNDN + # single ended conversion
  1163. ((channel+4)<<12) + # select channel
  1164. self.CONFIG_FSR_6V144 + # (5v signal)
  1165. self.CONFIG_MODE_SINGLE_SHOT + # single conversion and shutdown
  1166. self.CONFIG_DATA_RATE_128SPS + # data rate
  1167. self.CONFIG_COMP_MODE_TRADITIONAL + # comp conventional
  1168. self.CONFIG_COMP_POL_ACTIVE_LOW + # comp active low
  1169. self.CONFIG_COMP_LAT_NON_LATCHING + # comp non latching
  1170. self.CONFIG_COMP_QUE_DISABLE ) # comp disabled
  1171. ###
  1172. self.bus.write_word_data(self.address, self.DEVICE_REG_CONFIG, self.swap(self.config))
  1173. while True:
  1174. # read status (note byte swap)
  1175. status=self.swap(self.bus.read_word_data(self.address,self.DEVICE_REG_CONFIG))
  1176. #print("status:"+str(status))
  1177. # when the Operational Status is no longer performing a conversion
  1178. # we can break out of this wait loop
  1179. if (status & self.CONFIG_OS) != self.CONFIG_OS_PERFORMING_CONVERSION:
  1180. break
  1181. # read result (note byte swap)
  1182. result=self.swap(self.bus.read_word_data(self.address,self.DEVICE_REG_CONVERSION))
  1183. # return 16 bit integer A2D result for the specified channel
  1184. volt=round((result*6.144/32768),3)
  1185. return [result,volt]
  1186. class PCA9685(object):
  1187. bus=smbus2.SMBus(2)
  1188. def __init__(self,freq=400,min_us=460,max_us=2400,address=0x40,degrees=180):
  1189. self.address=address
  1190. self.period=1000000/freq
  1191. self.min_duty = self._us2duty(min_us)
  1192. self.max_duty = self._us2duty(max_us)
  1193. self.freq(freq)
  1194. self.reset()
  1195. #for i in range(0,16):
  1196. #self.duty(i,0)
  1197. print("Pca9685 init")
  1198. def write(self, addr, val):
  1199. for i in range(0, 2):
  1200. try:
  1201. self.bus.write_byte_data(self.address, addr, val)
  1202. #time.sleep(0.001) # 1ms
  1203. # print(addr, val) # debug
  1204. return True
  1205. except Exception:
  1206. time.sleep(0.001)
  1207. continue
  1208. return False
  1209. def read(self,addr):
  1210. for i in range(0, 3):
  1211. try:
  1212. tmp = self.bus.read_byte_data(self.address, addr)
  1213. #time.sleep(0.001) # 1ms
  1214. # print(addr, tmp) # debug
  1215. return tmp
  1216. except Exception:
  1217. time.sleep(0.01)
  1218. continue
  1219. return None
  1220. def reset(self):
  1221. self.write(0x00,0x00) #初始化
  1222. def freq(self,freq=None):
  1223. if freq is None:
  1224. return int(25000000.0/4096/(self.read(0xfe)-0.5))
  1225. #设定频率freq,预分频prescale=int(25000000.0 / (4096.0 * freq) + 0.5)
  1226. prescale=int(25000000.0/4096/freq+0.5)
  1227. self.write(0x00,0x10) #设定pca9685为睡眠模式
  1228. self.write(0xfe,prescale) #设定频率
  1229. self.reset()
  1230. time.sleep(0.01)
  1231. self.write(0x00,0xa1) #设定pca9685为活跃模式
  1232. def pwm(self,index,on=None,off=None): #on和off来调节PWM的占空比
  1233. if not 0<= index <=15:
  1234. raise ValueError("Pin ID out of range!")
  1235. if on is None or off is None:
  1236. data = self.bus.read_i2c_block_data(self.address,0x06+index*4,4)
  1237. return data
  1238. data= [0]*4
  1239. data[0]=int(hex(on & 0xff),16)
  1240. data[1]=int(hex((on >> 8) & 0xff),16)
  1241. data[2]=int(hex(off & 0xff),16)
  1242. data[3]=int(hex((off >> 8) & 0xff),16)
  1243. # print(data)
  1244. for i in range(0,4):
  1245. self.write(0x06+i+index*4,data[i])
  1246. def duty(self,index,value=None):
  1247. if value == None:
  1248. return self.pwm(index)
  1249. elif not 0 <= value <=4095:
  1250. raise ValueError("Out of range!")
  1251. elif value==0:
  1252. self.pwm(index,0,4096)
  1253. elif value == 4095:
  1254. self.pwm(index,4096,0)
  1255. else:
  1256. self.pwm(index,0,value)
  1257. def _us2duty(self,value):
  1258. return 4095*value/self.period
  1259. def __del__(self):
  1260. print("del pac9685")
  1261. time.sleep(1)
  1262. for i in range(0,16):
  1263. self.duty(i,0)
  1264. time.sleep(0.001)
  1265. class extDcMotor(PCA9685):
  1266. def __init__(self,motorId):
  1267. PCA9685.__init__(self)
  1268. self.motorPin=[11,12,13,10,9,8,5,6,7,4,3,2]
  1269. self.motorId=motorId
  1270. pass
  1271. def speedControl(self,speed):
  1272. self.speed=abs(speed)
  1273. if not -255<= speed<=255:
  1274. raise ValueError("Out of range!")
  1275. if self.motorId == "C":
  1276. if speed<0:
  1277. self.duty(self.motorPin[0],4095)
  1278. self.duty(self.motorPin[1],0)
  1279. self.duty(self.motorPin[2],int(self.speed*16))
  1280. else:
  1281. self.duty(self.motorPin[0],0)
  1282. self.duty(self.motorPin[1],4095)
  1283. self.duty(self.motorPin[2],int(self.speed*16))
  1284. elif self.motorId == "D":
  1285. if speed<0:
  1286. self.duty(self.motorPin[3],4095)
  1287. self.duty(self.motorPin[4],0)
  1288. self.duty(self.motorPin[5],int(self.speed*16))
  1289. else:
  1290. self.duty(self.motorPin[3],0)
  1291. self.duty(self.motorPin[4],4095)
  1292. self.duty(self.motorPin[5],int(self.speed*16))
  1293. elif self.motorId == "E":
  1294. if speed<0:
  1295. self.duty(self.motorPin[6],4095)
  1296. self.duty(self.motorPin[7],0)
  1297. self.duty(self.motorPin[8],int(self.speed*16))
  1298. else:
  1299. self.duty(self.motorPin[6],0)
  1300. self.duty(self.motorPin[7],4095)
  1301. self.duty(self.motorPin[8],int(self.speed*16))
  1302. elif self.motorId == "F":
  1303. if speed<0:
  1304. self.duty(self.motorPin[9],4095)
  1305. self.duty(self.motorPin[10],0)
  1306. self.duty(self.motorPin[11],int(self.speed*16))
  1307. else:
  1308. self.duty(self.motorPin[9],0)
  1309. self.duty(self.motorPin[10],4095)
  1310. self.duty(self.motorPin[11],int(self.speed*16))
  1311. else:
  1312. pass
  1313. def __del__(self):
  1314. if self.motorId == "C":
  1315. self.duty(self.motorPin[0],0)
  1316. self.duty(self.motorPin[1],0)
  1317. self.duty(self.motorPin[2],0)
  1318. elif self.motorId == "D":
  1319. self.duty(self.motorPin[3],0)
  1320. self.duty(self.motorPin[4],0)
  1321. self.duty(self.motorPin[5],0)
  1322. elif self.motorId == "E":
  1323. self.duty(self.motorPin[6],0)
  1324. self.duty(self.motorPin[7],0)
  1325. self.duty(self.motorPin[8],0)
  1326. elif self.motorId == "F":
  1327. self.duty(self.motorPin[9],0)
  1328. self.duty(self.motorPin[10],0)
  1329. self.duty(self.motorPin[11],0)
  1330. else:
  1331. pass
  1332. time.sleep(0.001)
  1333. class extServo(PCA9685):
  1334. def __init__(self,servoId):
  1335. PCA9685.__init__(self)
  1336. self.servoId=servoId
  1337. self.servoPin=[14,15,1,0]
  1338. self.degrees=180
  1339. pass
  1340. def position(self,degrees=None): #index:0,1,2,3
  1341. span = self.max_duty - self.min_duty
  1342. duty = self.min_duty + span * degrees / self.degrees
  1343. duty = int(min(self.max_duty, max(self.min_duty, int(duty))))
  1344. self.duty(self.servoPin[self.servoId], duty)
  1345. def release(self):
  1346. self.duty(self.servoPin[self.servoId],0)
  1347. def __del__(self):
  1348. self.duty(self.servoPin[self.servoId],0)
  1349. class extOutputPin(PCA9685):
  1350. def __init__(self):
  1351. PCA9685.__init__(self)
  1352. self.pin=[14,15,1,0]
  1353. self.pinId=0
  1354. pass
  1355. def digitalSet(self,pinId,val): #val:0/1
  1356. self.pinId=pinId
  1357. if val==0:
  1358. self.duty(self.pin[self.pinId],0)
  1359. else:
  1360. self.duty(self.pin[self.pinId],4095)
  1361. def pwmWrite(self,pinId,val): #val:0~255
  1362. self.pinId=pinId
  1363. # print("pinid"+str(self.pin[self.pinId]))
  1364. self.duty(self.pin[self.pinId],val*16)
  1365. def __del__(self):
  1366. self.duty(self.pin[self.pinId],0)
  1367. # print("del extPin")
  1368. class extGpio(MCP23017,ADS1115,extOutputPin):
  1369. def __init__(self):
  1370. MCP23017.__init__(self)
  1371. ADS1115.__init__(self)
  1372. extOutputPin.__init__(self)
  1373. self.address=0x20 #初始默认为mcp23017的地址
  1374. def pinMode(self,pinId,mode): #控制mcp23017
  1375. self.address=0x20
  1376. #----------
  1377. #pinId:
  1378. #p0~p3:0~3
  1379. #a0~a3:4~7
  1380. #---------
  1381. #mode:
  1382. #output:1
  1383. #input:0
  1384. if pinId>=0 and pinId<=3:
  1385. if mode==0:
  1386. if pinId==0: #p0
  1387. self.setGpioDir("B",2,0) #output
  1388. self.setGpioLevel("B",2,1) #high
  1389. self.setGpioDir("B",3,1) #input
  1390. elif pinId==1: #p1
  1391. self.setGpioDir("B",1,0)
  1392. self.setGpioLevel("B",1,1)
  1393. self.setGpioDir("B",0,1)
  1394. elif pinId==2: #p2
  1395. self.setGpioDir("B",6,0)
  1396. self.setGpioLevel("B",6,1)
  1397. self.setGpioDir("A",1,1)
  1398. elif pinId==3: #p3
  1399. self.setGpioDir("B",5,0)
  1400. self.setGpioLevel("B",5,1)
  1401. self.setGpioDir("B",4,1)
  1402. else:
  1403. pass
  1404. elif mode==1:
  1405. if pinId==0:
  1406. self.setGpioDir("B",2,0) #output
  1407. self.setGpioLevel("B",2,1) #high
  1408. self.setGpioDir("B",3,0) #output
  1409. elif pinId==1:
  1410. self.setGpioDir("B",1,0)
  1411. self.setGpioLevel("B",1,1)
  1412. self.setGpioDir("B",0,0)
  1413. elif pinId==2:
  1414. self.setGpioDir("B",6,0)
  1415. self.setGpioLevel("B",6,1)
  1416. self.setGpioDir("A",1,0)
  1417. elif pinId==3:
  1418. self.setGpioDir("B",5,0)
  1419. self.setGpioLevel("B",5,1)
  1420. self.setGpioDir("B",4,0)
  1421. # print("a")
  1422. time.sleep(1)
  1423. else:
  1424. pass
  1425. else:
  1426. pass
  1427. elif pinId>=4 and pinId<=7:
  1428. if mode==0:
  1429. if pinId==4: #a0
  1430. self.setGpioDir("A",4,0) #output
  1431. self.setGpioLevel("A",4,1) #high
  1432. self.setGpioDir("A",5,1) #input
  1433. elif pinId==5: #a1
  1434. self.setGpioDir("A",3,0)
  1435. self.setGpioLevel("A",3,1)
  1436. self.setGpioDir("A",7,1)
  1437. elif pinId==6: #a2
  1438. self.setGpioDir("A",2,0)
  1439. self.setGpioLevel("A",2,1)
  1440. self.setGpioDir("A",6,1)
  1441. elif pinId==7: #a3
  1442. self.setGpioDir("B",7,0)
  1443. self.setGpioLevel("B",7,1)
  1444. self.setGpioDir("A",0,1)
  1445. else:
  1446. pass
  1447. elif mode==1:
  1448. if pinId==4: #a0
  1449. self.setGpioDir("A",4,0) #output
  1450. self.setGpioLevel("A",4,1) #high
  1451. self.setGpioDir("A",5,0) #output
  1452. elif pinId==5: #a1
  1453. self.setGpioDir("A",3,0)
  1454. self.setGpioLevel("A",3,1)
  1455. self.setGpioDir("A",7,0)
  1456. elif pinId==6: #a2
  1457. self.setGpioDir("A",2,0)
  1458. self.setGpioLevel("A",2,1)
  1459. self.setGpioDir("A",6,0)
  1460. elif pinId==7: #a3
  1461. self.setGpioDir("B",7,0)
  1462. self.setGpioLevel("B",7,1)
  1463. self.setGpioDir("A",0,0)
  1464. else:
  1465. pass
  1466. else:
  1467. pass
  1468. def digitalWrite(self,pinId,level): #控制mcp23017
  1469. #----------
  1470. #pinId:
  1471. #p0~p3:0~3
  1472. #a0~a3:4~7
  1473. #---------
  1474. #level:
  1475. #5v:1
  1476. #0v:0
  1477. self.address=0x20
  1478. if pinId>=0 and pinId<=3:
  1479. if pinId==0:
  1480. # print("digital write level")
  1481. self.setGpioLevel("B",3,level)
  1482. elif pinId==1:
  1483. self.setGpioLevel("B",0,level)
  1484. elif pinId==2:
  1485. self.setGpioLevel("A",1,level)
  1486. elif pinId==3:
  1487. self.setGpioLevel("B",4,level)
  1488. else:
  1489. pass
  1490. elif pinId>=4 and pinId<=7:
  1491. if pinId==4: #a0
  1492. self.setGpioLevel("A",5,level)
  1493. elif pinId==5: #a1
  1494. self.setGpioLevel("A",7,level)
  1495. elif pinId==6: #a2
  1496. self.setGpioLevel("A",6,level)
  1497. elif pinId==7: #a3
  1498. self.setGpioLevel("A",0,level)
  1499. else:
  1500. pass
  1501. else:
  1502. pass
  1503. def digitalRead(self,pinId): #控制mcp23017
  1504. self.address=0x20
  1505. #----------
  1506. #pinId:
  1507. #p0~p3:0~3
  1508. #a0~a3:4~7
  1509. if pinId>=0 and pinId<=3:
  1510. if pinId==0:
  1511. # print("get digital write level")
  1512. return self.getGpioLevel("B",3)
  1513. elif pinId==1:
  1514. return self.getGpioLevel("B",0)
  1515. elif pinId==2:
  1516. return self.getGpioLevel("A",1)
  1517. elif pinId==3:
  1518. return self.getGpioLevel("B",4)
  1519. else:
  1520. pass
  1521. elif pinId>=4 and pinId<=7:
  1522. if pinId==4: #a0
  1523. return self.getGpioLevel("A",5)
  1524. elif pinId==5: #a1
  1525. return self.getGpioLevel("A",7)
  1526. elif pinId==6: #a2
  1527. return self.getGpioLevel("A",6)
  1528. elif pinId==7: #a3
  1529. return self.getGpioLevel("A",0)
  1530. else:
  1531. pass
  1532. else:
  1533. pass
  1534. def analogWrite(self,pinId,pwm): #控制PCA9685,但是需要Mcp23017进行通道选择
  1535. self.address=0x20 #先用mcp23017进行通道选择
  1536. #select X channel
  1537. if pinId==0: #p0
  1538. self.setGpioDir("B",2,1) #output
  1539. self.setGpioLevel("B",2,0) #low
  1540. elif pinId==1: #p1
  1541. self.setGpioDir("B",1,1)
  1542. self.setGpioLevel("B",1,0)
  1543. elif pinId==2: #p2
  1544. self.setGpioDir("B",6,1)
  1545. self.setGpioLevel("B",6,0)
  1546. elif pinId==3: #p3
  1547. self.setGpioDir("B",5,1)
  1548. self.setGpioLevel("B",5,0)
  1549. else:
  1550. pass
  1551. self.address=0x40 #再用PCA9685进行控制
  1552. self.pwmWrite(pinId,pwm)
  1553. def analogRead(self,pinId): #控制ADS1115,但是需要Mcp23017进行通道选择
  1554. self.adcPin=[3,1,0,2]
  1555. self.address=0x20 #先用mcp23017进行通道选择
  1556. #select X channel
  1557. if pinId==4: #a0
  1558. self.setGpioDir("A",4,1) #input
  1559. self.setGpioLevel("A",4,0) #low
  1560. elif pinId==5: #a1
  1561. self.setGpioDir("A",3,1)
  1562. self.setGpioLevel("A",3,0)
  1563. elif pinId==6: #a2
  1564. self.setGpioDir("A",2,1)
  1565. self.setGpioLevel("A",2,0)
  1566. elif pinId==7: #a3
  1567. self.setGpioDir("B",7,0)
  1568. self.setGpioLevel("B",7,0)
  1569. else:
  1570. pass
  1571. self.address=0x49 #再用Ads1115进行ADC读取
  1572. return self.readAdc(self.adcPin[pinId-4])
  1573. def __del__(self):
  1574. self.address=0x40
  1575. extOutputPin.__del__(self)
  1576. self.address=0x20
  1577. MCP23017.__del__(self) #最先init的配置最后再del
  1578. print("del finished!")