สารบัญ:
- ขั้นตอนที่ 1: แฟลช RaspberriPi Hard Disk / ติดตั้งซอฟต์แวร์ที่จำเป็น (โดยใช้ Ubuntu Linux)
- ขั้นตอนที่ 2: โคลนโครงการ / ติดตั้งไดรเวอร์ซอฟต์แวร์
- ขั้นตอนที่ 3: อุปกรณ์ที่จำเป็น
- ขั้นตอนที่ 4: ต่อสายอุปกรณ์
- ขั้นตอนที่ 5: สร้างอุปกรณ์
- ขั้นตอนที่ 6: สร้างอุปกรณ์ (ต่อ…)
- ขั้นตอนที่ 7: กำหนดค่าแอปพลิเคชันให้ทำงานอย่างถูกต้องใน Settings.py Config File
- ขั้นตอนที่ 8: ตั้งค่าสคริปต์ตามกำหนดการ
- ขั้นตอนที่ 9: ไม่บังคับ: สร้างภาพสภาพอากาศของคุณเองเพื่อแสดงบนจอแสดงผล
2025 ผู้เขียน: John Day | [email protected]. แก้ไขล่าสุด: 2025-01-13 06:58
เกจวัดอุณหภูมิความทนทานสูงและเครื่องมือบันทึกสภาพอากาศสำหรับโครงสร้างห้องใต้หลังคาหรือภายนอกอื่นๆ ของคุณ
ขั้นตอนที่ 1: แฟลช RaspberriPi Hard Disk / ติดตั้งซอฟต์แวร์ที่จำเป็น (โดยใช้ Ubuntu Linux)
ดาวน์โหลด "RASPBIAN JESSIE LITE"
สร้างฮาร์ดดิสก์ใหม่ของคุณสำหรับ DashboardPI
ใส่ microSD เข้ากับคอมพิวเตอร์ของคุณผ่านอะแดปเตอร์ USB และสร้างภาพดิสก์โดยใช้คำสั่ง dd
ค้นหาการ์ด microSD ที่ใส่ของคุณโดยใช้คำสั่ง df -h ยกเลิกการต่อเชื่อมและสร้างภาพดิสก์ด้วยคำสั่งคัดลอกดิสก์ dd
$ df -h /dev/sdb1 7.4G 32K 7.4G 1% /สื่อ/XXX/1234-5678
$ umount /dev/sdb1
ข้อควรระวัง: ตรวจสอบให้แน่ใจว่าคำสั่งนั้นถูกต้องอย่างสมบูรณ์ คุณสามารถทำให้ดิสก์อื่นเสียหายได้ด้วยคำสั่งนี้
if=ตำแหน่งของไฟล์รูปภาพ RASPBIAN JESSIE LITE ของ=ตำแหน่งของการ์ด microSD ของคุณ
$ sudo dd bs=4M if=/path/to/raspbian-jessie-lite.img of=/dev/sdb (หมายเหตุ: ในกรณีนี้ คือ /dev/sdb, /dev/sdb1 เป็นพาร์ติชั่นโรงงานที่มีอยู่บน ไมโครเอสดี)
การตั้งค่า RaspberriPi. ของคุณ
ใส่การ์ด microSD ใหม่ของคุณเข้ากับ raspberrypi และเปิดเครื่องด้วยจอภาพที่เชื่อมต่อกับพอร์ต HDMI
เข้าสู่ระบบ
ผู้ใช้: pi pass: raspberry
เปลี่ยนรหัสผ่านบัญชีของคุณเพื่อความปลอดภัย
sudo passwd pi
เปิดใช้งานตัวเลือกขั้นสูง RaspberriPi
sudo raspi-config
เลือก: 1 ขยายระบบไฟล์
9 ตัวเลือกขั้นสูง
ชื่อโฮสต์ A2 เปลี่ยนเป็น "AtticTemp"
A4 SSH เปิดใช้งานเซิร์ฟเวอร์ SSH
A7 I2C เปิดใช้งานอินเทอร์เฟซ i2c
เปิดใช้งานแป้นพิมพ์ภาษาอังกฤษ/สหรัฐอเมริกา
sudo nano /etc/default/keyboard
เปลี่ยนบรรทัดต่อไปนี้: XKBLAYOUT="us"
รีบูต PI สำหรับการเปลี่ยนแปลงรูปแบบแป้นพิมพ์ / การปรับขนาดระบบไฟล์เพื่อให้มีผล
$ sudo shutdown -r ตอนนี้
เชื่อมต่ออัตโนมัติกับ WiFi ของคุณ
sudo nano /etc/wpa_supplicant/wpa_supplicant.conf
เพิ่มบรรทัดต่อไปนี้เพื่อให้ raspberrypi ของคุณเชื่อมต่อกับ WiFi ที่บ้านของคุณโดยอัตโนมัติ (หากเครือข่ายไร้สายของคุณชื่อ "linksys" ในตัวอย่างต่อไปนี้)
network={ ssid="linksys" psk="WIRELESS PASSWORD HERE" } รีบูต PI เพื่อเชื่อมต่อกับเครือข่าย WiFi
$ sudo shutdown -r ตอนนี้
ตอนนี้ PI ของคุณอยู่ในเครือข่ายท้องถิ่นแล้ว คุณสามารถเข้าสู่ระบบจากระยะไกลผ่าน SSH ได้ แต่ก่อนอื่นคุณต้องได้รับที่อยู่ IP ที่มีอยู่ในปัจจุบัน
$ ifconfig ค้นหา "inet addr: 192.168. XXX. XXX" ในผลลัพธ์ของคำสั่งต่อไปนี้สำหรับที่อยู่ IP ของ PI ของคุณ
ไปที่เครื่องอื่นและลงชื่อเข้าใช้ raspberrypi ของคุณผ่าน ssh
$ ssh [email protected]. XXX. XXX
เริ่มการติดตั้งแพ็คเกจที่จำเป็น
$ sudo apt-get update
$ sudo apt-get upgrade
$ sudo apt-get install vim git python-requests python-smbus i2c-tools python-imaging python-smbus build-essential python-dev rpi.gpio python3 python3-pip libi2c-dev
อัปเดตการตั้งค่าเขตเวลาท้องถิ่น
$ sudo dpkg-reconfigure tzdata
เลือกเขตเวลาของคุณโดยใช้อินเทอร์เฟซ
ตั้งค่าคำสั่ง l ไดเร็กทอรีอย่างง่าย [ตัวเลือก]
$ vi ~/.bashrc
เพิ่มบรรทัดต่อไปนี้:
$ นามแฝง l='ls -lh'
$ source ~/.bashrc
แก้ไขการเน้นไวยากรณ์เริ่มต้นของ VIM [ตัวเลือก]
$ sudo vi /etc/vim/vimrc
uncomment บรรทัดต่อไปนี้:
ไวยากรณ์บน
ขั้นตอนที่ 2: โคลนโครงการ / ติดตั้งไดรเวอร์ซอฟต์แวร์
โคลนที่เก็บโปรเจ็กต์
$ cd ~
$ git clone
ติดตั้ง DHT22
$ cd ~
$ git clone
$ cd Adafruit_Python_DHT/
$ sudo python setup.py ติดตั้ง
$ sudo python ez_setup.py
$ ตัวอย่างซีดี /
$ vi simpletest.py
เปลี่ยนบรรทัดต่อไปนี้:
เซ็นเซอร์ = Adafruit_DHT. DHT22
แสดงความคิดเห็นบรรทัดออก
พิน = 'P8_11'
ยกเลิกหมายเหตุบรรทัดและเปลี่ยนหมายเลขพินเป็น16
พิน = 18
เรียกใช้การทดสอบ
หลาม simpletest.py
คุณควรเห็นการอ่านค่าเมตริกของอุณหภูมิและความชื้นที่แสดงบนบรรทัดคำสั่ง
ติดตั้ง SSD1306
แยกไดรเวอร์/SSD1306.zip ไปยังโฟลเดอร์โครงการ
ติดตั้งไดรเวอร์
$ cd ssd1306/ $ sudo python setup.py ติดตั้ง
ยืนยันการลงทะเบียนอุปกรณ์ของคุณ โดยปกติแล้วจะเป็น \0x3c บนบัส i2c
$ sudo i2cdetect -y 1
0 1 2 3 4 5 6 7 8 9 abcdef 00: -- -- -- -- -- -- -- -- -- -- -- -- -- 10: -- -- -- -- - - -- -- -- -- -- -- -- -- -- -- -- 20: -- -- -- -- -- -- -- -- -- -- -- -- - - -- -- -- 30: -- -- -- -- -- -- -- -- -- -- -- 3c -- -- -- 40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- 50: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- 60: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- 70: -- -- -- -- -- -- -- -- เรียกใช้การสาธิตเพื่อยืนยันว่าจอแสดงผลของคุณทำงานได้ดี
$ cd ตัวอย่าง/ $ python demo.py
ขั้นตอนที่ 3: อุปกรณ์ที่จำเป็น
RaspberriPi Zero
DHT22 เซ็นเซอร์อุณหภูมิ-ความชื้น
0.96 I2C IIC SPI Serial 12864 OLED LCD LED โมดูลแสดงผลสีขาว
2.4 400x240 16:9 Serial:UART/I2C/SPI TFT Touchscreen Display
ขั้นตอนที่ 4: ต่อสายอุปกรณ์
จอแสดงผล SSD1306
GND -> GND
ข้อมูล -> SDA
CLK -> SCL
VCC -> 3V
ดิโกล ดิสเพลย์
GND -> GND
ข้อมูล -> SDA
CLK -> SCL
VCC -> 3V
DHT22 เครื่องทำความชื้น
VCC -> 5V
GND -> GND
ข้อมูล -> GPIO 18 / PIN 12
ขั้นตอนที่ 5: สร้างอุปกรณ์
ตัดลูกแก้วให้พอดีกับด้านหน้าของอุปกรณ์ภายใต้กรอบพิมพ์ 3 มิติ
ยึดกระจกด้วยสกรูผ่านกรอบที่พิมพ์ 3 มิติ
ขั้นตอนที่ 6: สร้างอุปกรณ์ (ต่อ…)
ส่วนประกอบกาวร้อนที่แผงด้านหน้า
หน่วยลวดภายใน
ติดด้านหลังน่าจะพร้อมลุย
ขั้นตอนที่ 7: กำหนดค่าแอปพลิเคชันให้ทำงานอย่างถูกต้องใน Settings.py Config File
ค้นหาไฟล์ settings.py และปรับให้เข้ากับการตั้งค่าปัจจุบันของคุณ
# คีย์พยากรณ์อากาศ io API สำหรับข้อมูลสภาพอากาศในท้องถิ่น
weatherAPIURL = 'https://api.forecast.io/forecast/'
weatherAPIKey = 'คีย์ API ของคุณสำหรับ FORECAST. IO'
# ตัวเลือกสำหรับการเรียกใช้ตัวบันทึกอุณหภูมิ/ความชื้นระยะไกล
deviceLoggerAPI = 'mydevicelogger.com'
# ค้นหา google เพื่อรับละติจูด/ลองจิจูดสำหรับตำแหน่งบ้านของคุณ
ละติจูด = 41.4552578
ลองจิจูด = -72.1665444
ขั้นตอนที่ 8: ตั้งค่าสคริปต์ตามกำหนดการ
$ crontab -e
เพิ่มบรรทัดต่อไปนี้: */7 * * * * python /home/pi/AtticTemp/displays.py
ไม่บังคับ: ตัวบันทึกอุณหภูมิไปยังสคริปต์ API ทุกๆ 10 นาที
$ crontab -e
เพิ่มบรรทัดต่อไปนี้: */10 * * * * python /home/pi/EnvironmentClock/temp-check.py
ขั้นตอนที่ 9: ไม่บังคับ: สร้างภาพสภาพอากาศของคุณเองเพื่อแสดงบนจอแสดงผล
อัปโหลดไฟล์ 128x128 ของคุณเองไปยัง URL ต่อไปนี้:
www.digole.com/tools/PicturetoC_Hex_converter.php
เลือกไฟล์ภาพที่จะอัพโหลด ใส่ขนาดที่ต้องการลงบนหน้าจอ (กว้าง/สูง)
เลือก "256 สีสำหรับ OLED/LCD สี (1 ไบต์/พิกเซล)" ในเมนูแบบเลื่อนลง "ใช้สำหรับ"
รับเอาต์พุตฐานสิบหก
เพิ่มเอาต์พุตฐานสิบหกลงในไฟล์ display/build/ header (.h) ใช้ไฟล์อื่นเป็นแนวทางสำหรับไวยากรณ์
รวมไฟล์ใหม่ในไฟล์ digole.c #include myimage.h
รวมเบ็ดบรรทัดคำสั่งใหม่ให้กับไฟล์รูปภาพของคุณในไฟล์. หมายเหตุ: คำสั่งด้านล่างบอกว่าวาดภาพของคุณที่ตำแหน่ง 10 พิกเซลมากกว่า 10 พิกเซลลง คุณสามารถเปลี่ยนเป็นพิกัด X, Y อื่นได้ คุณยังสามารถเปลี่ยนค่า 128, 128 เป็นขนาดใดก็ได้ของรูปภาพใหม่ของคุณ
} อื่น if (strcmp (digoleCommand, "myimage") == 0) { drawBitmap256 (10, 10, 128, 128, &myimageVariableHere, 0); // myimageVariableHere ถูกกำหนดไว้ในไฟล์ (.h) ของคุณ }
ตอนนี้สร้างใหม่ (ละเว้นข้อผิดพลาด) ด้านล่างเพื่อให้ภาพใหม่ของคุณแสดงผลด้วยคำสั่งต่อไปนี้
$./digole myimage
สร้างใหม่ [รวม] Digole Display Driver สำหรับการเปลี่ยนแปลงเพิ่มเติมของคุณ
$ cd display/build
$ gcc diole.c
$ mv a.out../../digole
$ chmod +x../../digole