1. 程式人生 > >樹莓派01

樹莓派01

用處 port else 繼續 sed led 中斷 import 模式

raspbrerry pi

簡介:官方系統就是Raspbian

1.下載與安裝

NOOBS:new outofbox software 新版開箱即用軟件。有網絡版和非網絡版,非網絡版裏面包含了鏡像文件,就是右邊的那個,所有文件很大1個多G。而網絡版裏面只是一個下載工具,安裝時需要聯網下載鏡像。

raspbian:這個就是我們的系統鏡像文件。分為有圖形界面和無圖形界面

技術分享圖片

NOOBS使用

NOOBS下載下來是一個zip,解壓後有好多文件

技術分享圖片

把這個目錄下所有copy到sd卡,註意拷到根目錄

然後開啟樹莓派,選擇鏡像安裝即可,選英文的最好

Rapbian

就是鏡像文件,img文件,使用Win32DiskImage,點擊寫入即可。

2.加入中文輸入法

輸入法:如果裝英文的系統,它默認使用鍵盤是UK,咱們的鍵盤都是美式的,記得切換鍵盤。否則想要打“#”這些符號,可打不出來。。。

2.1

sudo apt-get install fcitx fcitx-googlepinyin fcitx-module-cloudpinyin fcitx-sunpinyin

這是給樹莓派安裝中文輸入法Fcitx及Google拼音輸入法

sudo是一個提升權限的命令,可以讓非root用戶暫時擁有root命令,即可以在你的系統裏面安裝,刪除文件

apt是一個包管理工具

2.2

安裝好還不能用,你要在開始菜單中找到prefeence,在preference那裏找到Fcitx Configuration,點開,然後點擊左下角的”+”號,找到你剛安裝的google pinyin.

把你的鍵盤添加進去,註意,把那個選擇本機語言去掉。

2.3

crtl+空格 切換輸入法

3.停止一個python腳本

當你使用GPIO時,總會遇到這樣的問題。因為代碼中間出錯了,而你有沒有捕獲,這就尷尬了,你的代碼一直運行。

所有註意在你所有的代碼運行的外面加上

KeyboardInterrupt

這樣,你就可以通過ctrl+c取消運行

3.1

ps -ef 顯示進程,然後找到py文件對應的進程的pid

3.2

寫一個簡單的GPIO腳本執行一下就可以了。

4.GPIO

4.1安裝

一般會自帶。。如果沒自帶就要pip安裝了

因為自帶了python2和python3,所有命令行裏面執行的時候:

python2就是使用python2 pip2

python3就是使用python3 pip3同理

4.2識圖

技術分享圖片

每一個針腳都有Pin#和NAME字段。Pin代表的是該針腳的編號,其中01和02針腳對應第一張圖中GPIO最右邊豎排的兩個針腳。而NAME代表的是該針腳的BCM名稱,當然NAME也可以直接看得出針腳的默認功能。比如 3.3v和5v代表著該針腳會輸出3.3v和5v的電壓,Ground代表著該針腳是接地的,GPIO0*則是一些待用戶開發的針腳。每個針腳都可以使用程序進行控制操作。

4.3快速入門

import RPi.GPIO as GPIO必須這樣寫,大小寫嚴格

針腳編號

GPIO.setmode(GPIO.BOARD)

或者

1 GPIO.setmode(GPIO.BCM)

在RPi.GPIO中,同時支持樹莓派上的兩種GPIO引腳編號。第一種編號是BOARD編號,這和樹莓派電路板上的物理引腳編號相對應。使用這種編號的好處是,你的硬件將是一直可以使用的,不用擔心樹莓派的版本問題。因此,在電路板升級後,你不需要重寫連接器或代碼。

第二種編號是BCM規則,是更底層的工作方式,它和Broadcom的片上系統中信道編號相對應。在使用一個引腳時,你需要查找信道號和物理引腳編號之間的對應規則。對於不同的樹莓派版本,編寫的腳本文件也可能是無法通用的。

下面代碼將返回被設置的編號規則

mode = GPIO.getmode()

警告(實際上沒有什麽用)

如果RPi.GRIO檢測到一個引腳已經被設置成了非默認值,那麽你將看到一個警告信息。你可以通過下列代碼禁用警告:

GPIO.setwarnings(False)


引腳設置

在使用一個引腳前,你需要設置這些引腳作為輸入還是輸出。配置一個引腳的代碼如下:

# 將引腳設置為輸入模式
GPIO.setup(channel, GPIO.IN)

# 將引腳設置為輸出模式
GPIO.setup(channel, GPIO.OUT)

# 為輸出的引腳設置默認值
GPIO.setup(channel, GPIO.OUT, initial=GPIO.HIGH)


釋放(最後必須)

一般來說,程序到達最後都需要釋放資源,這個好習慣可以避免偶然損壞樹莓派。釋放腳本中的使用的引腳:註意,GPIO.cleanup()只會釋放掉腳本中使用的GPIO引腳,並會清除設置的引腳編號規則。

GPIO.cleanup()

輸出

要想點亮一個LED燈,或者驅動某個設備,都需要給電流和電壓他們,這個步驟也很簡單,設置引腳的輸出狀態就可以了,代碼如下:

GPIO.output(channel, state)

狀態可以設置為0 / GPIO.LOW / False / 1 / GPIO.HIGH / True。如果編碼規則為,GPIO.BOARD,那麽channel就是對應引腳的數字。

如果想一次性設置多個引腳,可使用下面的代碼:

chan_list = [11,12]
GPIO.output(chan_list, GPIO.LOW)
GPIO.output(chan_list, (GPIO.HIGH, GPIO.LOW))   

你還可以使用Input()函數讀取一個輸出引腳的狀態並將其作為輸出值,例如:

GPIO.output(12, not GPIO.input(12))

讀取

我們也常常需要讀取引腳的輸入狀態,獲取引腳輸入狀態如下代碼:

GPIO.input(channel)

低電平返回0 / GPIO.LOW / False,高電平返回1 / GPIO.HIGH / True。

如果輸入引腳處於懸空狀態,引腳的值將是漂動的。換句話說,讀取到的值是未知的,因為它並沒有被連接到任何的信號上,直到按下一個按鈕或開關。由於幹擾的影響,輸入的值可能會反復的變化。
使用如下代碼可以解決問題:

GPIO.setup(channel, GPIO.IN, pull_up_down=GPIO.PUD_UP)
  # or
GPIO.setup(channel, GPIO.IN, pull_up_down=GPIO.PUD_DOWN)

需要註意的是,上面的讀取代碼只是獲取當前一瞬間的引腳輸入信號。

如果需要實時監控引腳的狀態變化,可以有兩種辦法。最簡單原始的方式是每隔一段時間檢查輸入的信號值,這種方式被稱為輪詢。如果你的程序讀取的時機錯誤,則很可能會丟失輸入信號。輪詢是在循環中執行的,這種方式比較占用處理器資源。另一種響應GPIO輸入的方式是使用中斷(邊緣檢測),這裏的邊緣是指信號從高到低的變換(下降沿)或從低到高的變換(上升沿)。

輪詢方式

while GPIO.input(channel) == GPIO.LOW:
    time.sleep(0.01)  # wait 10 ms to give CPU chance to do other things

邊緣檢測

邊緣是指信號狀態的改變,從低到高(上升沿)或從高到低(下降沿)。通常情況下,我們更關心於輸入狀態的該邊而不是輸入信號的值。這種狀態的該邊被稱為事件。
先介紹兩個函數:

  • wait_for_edge() 函數。
    wait_for_edge()被用於阻止程序的繼續執行,直到檢測到一個邊沿。也就是說,上文中等待按鈕按下的實例可以改寫為:
channel = GPIO.wait_for_edge(channel, GPIO_RISING, timeout=5000)
if channel is None:
    print(‘Timeout occurred‘)
else:
    print(‘Edge detected on channel‘, channel)
  • add_event_detect() 函數
    該函數對一個引腳進行監聽,一旦引腳輸入狀態發生了改變,調用event_detected()函數會返回true,如下代碼:
GPIO.add_event_detect(channel, GPIO.RISING)  # add rising edge detection on a channel
do_something()
// 下面的代碼放在一個線程循環執行。
if GPIO.event_detected(channel):
    print(‘Button pressed‘)

上面的代碼需要自己新建一個線程去循環檢測event_detected()的值,還算是比較麻煩的。

不過可采用另一種辦法輕松檢測狀態,這種方式是直接傳入一個回調函數:

def my_callback(channel):
    print(‘This is a edge event callback function!‘)
    print(‘Edge detected on channel %s‘%channel)
    print(‘This is run in a different thread to your main program‘)

GPIO.add_event_detect(channel, GPIO.RISING, callback=my_callback)

如果你想設置多個回調函數,可以這樣:

def my_callback_one(channel):
    print(‘Callback one‘)

def my_callback_two(channel):
    print(‘Callback two‘)

GPIO.add_event_detect(channel, GPIO.RISING)
GPIO.add_event_callback(channel, my_callback_one)
GPIO.add_event_callback(channel, my_callback_two)

註意:回調觸發時,並不會同時執行回調函數,而是根據設置的順序調用它們。

Raspberry Pi 修訂版本和 RPi.GPIO 版本

檢測 Raspberry Pi 主板的修訂版本:

1 GPIO.RPI_REVISION

檢測 RPi.GPIO 的版本:

1 GPIO.VERSION


 

5.linux命令

6.GPIO詳解

https://sourceforge.net/p/raspberry-gpio-python/wiki/Home/

Python下GPIO.add_event_detect(channel, GPIO.RISING, callback=my_callback) 這個函數的用法 用來做定時用

高電位與低點位:相對就可以通電

樹莓派01