สารบัญ:
2025 ผู้เขียน: John Day | [email protected]. แก้ไขล่าสุด: 2025-01-13 06:58
ในโครงการนี้ คุณจะต้องสร้างโคมไฟกลางคืนโดยใช้ ardruino, Adafruit neo rgb Strips และเครื่องพิมพ์ 3 มิติ
โปรดทราบว่าคำสั่งสอนนี้มีไว้สำหรับโครงการโรงเรียนของฉันเท่านั้น รหัสสำหรับโครงการนี้มาจากโครงการอื่น ด้วยที่กล่าวว่าฉันไม่ใช่ผู้เชี่ยวชาญเมื่อพูดถึง Ardruino
ขั้นตอนที่ 1: ข้อกำหนด
สำหรับโครงการนี้ คุณจะต้องมีฮาร์ดแวร์และเครื่องมือดังต่อไปนี้
ฮาร์ดแวร์:
1 - ardruino101 (ในสหรัฐอเมริกา) หรือ Genuino101 (สำหรับนอกสหรัฐอเมริกา)
2 - แถบนำ NeoPixel rgb จาก adafruit (5 โวลต์)
3 - ขั้วต่อ usb ardruino (ขั้วต่อชนิด B ถึง A)
4 - ซอฟต์แวร์จาก Ardruino, Ardruino IDE ในบทช่วยสอนนี้ เราจะใช้เวอร์ชัน 1.8.5 ข้อกำหนดของไลบรารีซอฟต์แวร์คือ: 101, Adafruit NeoPixel และ Madgwick
5 - และวัตถุสำหรับจัดเก็บฮาร์ดแวร์ของคุณ ในกรณีนี้ ฉันจะใช้เครื่องพิมพ์ 3 มิติ ไฟล์สำหรับการพิมพ์ 3 มิตินี้จะอยู่ในคำอธิบายที่เรียกว่า "Lamp Head" โปรดทราบว่ารูปแบบไฟล์นี้ไม่พร้อมสำหรับการพิมพ์ 3 มิติ คุณต้องเรียกใช้ซอฟต์แวร์การพิมพ์ 3 มิติที่กำหนดบนวัตถุ 3 มิติก่อน ทั้งนี้ขึ้นอยู่กับเครื่องพิมพ์ 3 มิติของคุณ บางครั้งขนาดของการพิมพ์ 3 มิติจะรีเซ็ต ดังนั้น ตรวจสอบให้แน่ใจว่าเส้นผ่านศูนย์กลางตั้งไว้ที่ 11 ซม. คูณ 11 ซม.
6 - ชุดบัดกรีพื้นฐาน
ขั้นตอนที่ 2: ทำความเข้าใจเกี่ยวกับฮาร์ดแวร์และซอฟต์แวร์
Ardruin/Genuino101
เพียงเพื่อชี้แจง Ardruino101 และ genuino101 นั้นเหมือนกันทุกประการข้างชื่อ ทั้งสองมีข้อกำหนดเดียวกันและใช้ซอฟต์แวร์เดียวกัน
Ardruino101 มีสเปกพื้นฐาน เช่น ardruino UNO และอื่นๆ คุณสมบัติหลักของ ardruino101 คือมาตรความเร่งและไจโรสโคปที่เราจะใช้ในโครงการของเรา นอกจากนี้ ardruino ประเภทนี้ยังมีไลบรารีโค้ดเฉพาะที่เรียกว่า CurrieIMU (Internal Measuring Units) ซึ่งรวมอยู่ในส่วนขยายไลบรารี 101
ด้วยที่กล่าวว่าเรามาพูดคุยเกี่ยวกับซอฟต์แวร์
ซอฟต์แวร์และไลบรารี
Ardruino IDE ใช้ python เนื่องจากเป็นซอร์สโค้ดหลัก นอกจากนี้ยังเป็น platvorm รหัสหลักที่ ardruino ส่วนใหญ่ทำงาน มีบทเรียนออนไลน์มากมายเกี่ยวกับวิธีการใช้ซอฟต์แวร์นี้ ดังนั้นฉันขอแนะนำให้คุณค้นคว้าข้อมูลเหล่านั้นก่อน หากคุณยังใหม่กับโปรแกรมนี้
โดยที่กล่าวว่าไลบรารีที่เราใช้อยู่มีดังต่อไปนี้:
จากเมนู Sketch > รวมไลบรารี > จัดการไลบรารี… ในช่องป้อนข้อความให้พิมพ์
- 101 ที่มาตรฐาน ardruino 101 จะไม่รวมอยู่ใน ardruino IDE โดยอัตโนมัติ เราต้องการส่วนขยายไลบรารีนี้เพื่อเข้ารหัสประเภท ardruino ของเรา
-Adafruit NeoPixel เพื่อเข้ารหัสแถบพิกเซล Neo ของเรา
-Madgwick เพื่ออ่านข้อมูลดิบและคำนวณข้อมูลนี้เป็นข้อมูลดิบ ขว้างและม้วน
แถบ Neo RGB
ประเภทที่ฉันจะใช้คือประเภท 5 แรงดันไฟฟ้าหรือประเภท 5v ด้วย 5v นี้ฉันไม่ต้องการแหล่งพลังงานเพิ่มเติมเพื่อควบคุมแถบของฉัน แต่ฉันจะใช้ ardruino เป็นแหล่งพลังงานในการควบคุมและทำให้แถบสว่างขึ้น
นี่คือเคล็ดลับบางอย่างที่คุณต้องรู้ก่อนเริ่มใช้งานแถบนี้
ก่อนอื่นคุณต้องมีแถบ LED Neodigital RGB จาก adafruit แถบชนิดนี้ควบคุมได้โดยใช้รหัส ต่อไปคุณต้องรู้ก่อนว่าแถบนี้มีด้านหลังและด้านหน้า ด้านหลังและด้านหน้านี้มีความสำคัญต่อการบัดกรี ตรวจสอบให้แน่ใจว่าคุณประสานด้านหน้าโดยที่ปุ่มลูกศรชี้ออกจากปลาย
นี่คือคำแนะนำเกี่ยวกับวิธีการใช้งาน
มีจุดบัดกรี 3 จุดที่คุณต้องคำนึงถึง การเชื่อมต่อกราวด์ (GND), การเชื่อมต่อแรงดันไฟฟ้า (V) และ การเชื่อมต่อพิน (DIN)
ขั้นตอนที่ 3: การตั้งค่าส่วนประกอบ
ขั้นแรก คุณจะต้องพิมพ์ส่วนประกอบ 3 มิติ ซึ่งคุณสามารถหาได้ในข้อกำหนด ในกรณีนี้ ฉันจะใช้ PLA ตรวจสอบให้แน่ใจว่าเส้นผ่านศูนย์กลางของวัตถุโดยรวมคือ 11 ซม. x 11 ซม. สิ่งนี้จะช่วยให้มั่นใจได้ว่า ardruino และแถบจะพอดีกับ shpere โปรดทราบว่าเครื่องพิมพ์ 3 มิติแต่ละเครื่องใช้ซอฟต์แวร์ที่แตกต่างกันในการคำนวณกระบวนการพิมพ์ ไฟล์ที่คุณใช้อาจมีการปรับขนาดต่างกัน ดังนั้นโปรดระลึกไว้เสมอว่า
วินาทีหลังการพิมพ์ ตรวจสอบให้แน่ใจว่าส่วนประกอบต่างๆ สามารถปิดได้ การพิมพ์ 3 มิติรวมกันเป็นทรงกลม พวกเขาควรจะพอดีอย่างดี หากส่วนประกอบสูญหาย ให้ติดเทปที่ด้านในเพื่อให้ฝาเต็ม และถ้าหนาให้ใช้กระดาษทราย
ประการที่สาม skematichs สำหรับ ardruino และแถบนั้นค่อนข้างง่าย คุณจะใช้สายไฟ 3 เส้นเพื่อเชื่อมต่อแถบกับ ardruino โปรดทราบว่าสถานที่เดียวที่ฉันบัดกรีอยู่บนแถบ ไม่ใช่บน Ardruino เอง
GND ไปที่ GND
DIN ไปที่พิน (ในกรณีของเรา pin6 บน ardruino)
5V ไปที่ 5V
ตรวจสอบให้แน่ใจว่าจำนวนแถบนำที่คุณใช้อยู่ที่ 30 อีกต่อไปแล้วและจะไม่สามารถรันโค้ดได้อย่างถูกต้อง คุณสามารถตัดแถบที่ไม่ได้ใช้ซึ่งแสดงเครื่องหมายกรรไกรได้ง่ายๆ
สิ่งที่สี่ Evrything ควรพอดีอย่างดีในทรงกลม คุณอาจเหมือนว่าฉันทำจุดตัดระหว่าง 1 ของการพิมพ์ 3 มิติเพื่อดูรางและวางพลาสติกรางน้ำที่ด้านบน
ขั้นตอนที่ 4: การเข้ารหัส
ตอนนี้คุณควรมีส่วนประกอบทั้งหมดที่จำเป็นในห้องสมุดของคุณ
นี่คือรหัสที่คุณต้องการเพื่อเรียกใช้โครงการ ผลลัพธ์ควรมีลักษณะเหมือนลิงก์วิดีโอที่ฉันส่งในหน้านี้
แหล่งที่มาของรหัสนี้สามารถพบได้ที่นี่ โปรเจ็กต์นี้ยังรวมถึงขั้นตอนที่จำเป็นเพื่อให้เข้าใจโค้ดและอัลกอริทึมที่อยู่เบื้องหลังการใช้งานได้ดียิ่งขึ้น
#รวม #รวม #รวม #รวม
#define PIN 6 // 11 พิกเซล NeoPixel Strip
#define PIN1 7 // 1 พิกเซล NeoPixel Strip #define NUMPIXELS 30 // จำนวนพิกเซล #define SAMPLE_RATE 25 // อัตราการสุ่มตัวอย่างสำหรับมาตรความเร่งและไจโรสโคป
// การกำหนดค่า Madgwick
ตัวกรองแมดจ์วิค; microsPerReading แบบยาวที่ไม่ได้ลงนาม, microsPrevious; ลอย accelScale, gyroScale;
// การกำหนดค่า NeoPixel
พิกเซล Adafruit_NeoPixel = Adafruit_NeoPixel (NUMPIXELS, PIN, NEO_GRB + NEO_KHZ800); Adafruit_NeoPixel พิกเซลสถานะ = Adafruit_NeoPixel (1, 7, NEO_GRB + NEO_KHZ800);
// ช่องว่างสี
RGBConverter rgbConverter; สองเท่า ชั่วโมง = 1; ดับเบิ้ล s = 1; ดับเบิล v = 1; ไบต์ rgb[3];
// สถานะหลอดไฟเคลื่อนไหว
// State 0 -> Select Hue - Pitch // State 1 -> Select Saturation - Roll // State 2 -> Select Value - Yaw // State 3 -> แก้ไขสี int statusLamp = 0;
การตั้งค่าเป็นโมฆะ () {
Serial.begin(9600);
// เริ่ม IMU และตัวกรอง
CurieIMU.begin(); CurieIMU.setGyroRate(SAMPLE_RATE); CurieIMU.setAccelerometerRate(SAMPLE_RATE); filter.begin(SAMPLE_RATE);
// ตั้งค่าช่วงมาตรความเร่งเป็น 2G
CurieIMU.setAccelerometerRange(2); // ตั้งค่าไจโรสโคปเป็น 250 องศา/วินาที CurieIMU.setGyroRange(250);
CurieIMU.autoCalibrateเครื่องวัดความเร่งออฟเซ็ต (X_AXIS, 0);
CurieIMU.autoCalibrateเครื่องวัดความเร่งออฟเซ็ต (Y_AXIS, 0); CurieIMU.autoCalibrateเครื่องวัดความเร่งออฟเซ็ต (Z_AXIS, 1); CurieIMU.autoCalibrateGyroOffset();
CurieIMU.attachInterrupt (เหตุการณ์Callback);
CurieIMU.setDetectionThreshold (CURIE_IMU_TAP, 950); CurieIMU.interrupts(CURIE_IMU_TAP);
// เริ่มต้นตัวแปรเพื่อเร่งการอัพเดตเพื่อแก้ไขอัตรา
microsPerReading = 1000000 / SAMPLE_RATE; microsPrevious = ไมโคร ();
// เริ่มต้น NeoPixel 11
พิกเซล.begin(); พิกเซล.show();
// เริ่มต้น NeoPixel 1
pixelStatus.begin(); พิกเซล.show();
// แสดงสถานะเป็น px
setStatusPixel (ไฟสถานะ); }
วงเป็นโมฆะ () {
int aix, aiy, aiz; //มาตรความเร่ง int gix, giy, giz; ขวานลอย, ay, az; ลอย gx, gy, gz; ม้วนลอย, ขว้าง, หันเห; microsNow แบบยาวที่ไม่ได้ลงนามแบบคงที่;
// ตรวจสอบว่าได้เวลาอ่านข้อมูลและอัปเดตตัวกรองหรือไม่
microsNow = ไมโคร (); ถ้า (microsNow - microsPrevious >= microsPerReading) {
// อ่านข้อมูลดิบจาก CurieIMU
CurieIMU.readMotionSensor (aix, aiy, aiz, gix, giy, giz);
// แปลงจากข้อมูลดิบเป็นหน่วยแรงโน้มถ่วงและหน่วยองศา/วินาที
ขวาน = convertRawAcceleration(aix); ay = convertRawAcceleration(aiy); az = แปลงRawAcceleration(aiz); gx = แปลงRawGyro(gix); gy = convertRawGyro(giy); gz = แปลงRawGyro(giz);
// อัปเดตตัวกรองซึ่งคำนวณการวางแนว
filter.updateIMU(gx, gy, gz, ax, ay, az);
// พิมพ์หัวเรื่อง ขว้างและม้วน
ม้วน = filter.getRoll(); ระยะห่าง = filter.getPitch(); หันเห = filter.getYaw();
// เพิ่มเวลาก่อนหน้านี้เพื่อให้เราก้าวอย่างเหมาะสม
microsPrevious = microsPrevious + microsPerReading;
// เฉพาะในกรณีที่เปลี่ยน Hue, Saturation หรือ Value
if (statusLamp เลือก Hue if (pitch >= -90 && pitch <= 90 && statusLamp == 0) { // เปลี่ยนมุม pitch = pitch + 90; // รับพิกัดสีจากมุม h = pitch / 180.0; }
// ข้อ จำกัด ของมุม
// ม้วนเท่านั้น -90ºถึง90º = 180º // สถานะ 1 -> เลือกความอิ่มตัวถ้า (ม้วน >= -90 && ม้วน <= 90 && statusLamp == 1) { // เปลี่ยนมุมม้วน = ม้วน + 90; // รับพิกัดสีจากมุม s = ม้วน / 180.0; }
// สถานะ 2 -> เลือกค่า
ถ้า (statusLamp == 2) { // yaw 0º ถึง 360º v = yaw / 360.0; }
// แปลงเป็น rgb
rgbConverter.hsvToRgb(h, s, v, rgb); /* Serial.print("สี: "); Serial.print(h); Serial.print(" - "); Serial.print(s); Serial.print(" - "); Serial.print(v); Serial.println(" ");
Serial.print("การวางแนว: ");
Serial.print(หันเห); Serial.print(" "); Serial.print(พิทช์); Serial.print(" "); Serial.println(ม้วน); */
// เปลี่ยนสีของพิกเซล
สำหรับ (int px = 0; px < NUMPIXELS; px++) { pixels.setPixelColor(px, pixels. Color(rgb[0], rgb[1], rgb[2])); พิกเซล.show(); } }
// แสดงสถานะเป็น px
setStatusPixel (ไฟสถานะ); } }
float convertRawAcceleration (int aRaw) {
// เนื่องจากเราใช้ช่วง 2G // -2g จับคู่กับค่าดิบที่ -32768 // +2g จับคู่กับค่าดิบ 32767
float a = (aRaw * 2.0) / 32768.0;
ส่งคืน a; }
float convertRawGyro (int gRaw) {
// เนื่องจากเราใช้ช่วง 250 องศา/วินาที // -250 จับคู่กับค่าดิบที่ -32768 // +250 จับคู่กับค่าดิบ 32767
float g = (gRaw * 250.0) / 32768.0;
กลับกรัม; }
โมฆะคงที่ eventCallback()
{ // ตรวจจับการแตะในแกนทั้งหมดหาก (CurieIMU.getInterruptStatus (CURIE_IMU_TAP)) { Serial.print ("ตรวจพบการแตะ statusLamp: "); Serial.println (ไฟสถานะ);
// เปลี่ยนสถานะ
สถานะLamp++;
// สถานะเริ่มต้น
ถ้า (statusLamp > 3) { statusLamp = 0; } } }
เป็นโมฆะ setStatusPixel (int statusPx)
{ สวิตช์ (statusPx) { กรณี 0: pixelsStatus.setPixelColor (0, pixelsStatus. Color (150, 0, 0)); pixelStatus.show(); หยุดพัก; กรณีที่ 1: pixelsStatus.setPixelColor(0, pixelsStatus. Color(0, 150, 0)); pixelStatus.show(); หยุดพัก; กรณีที่ 2: pixelsStatus.setPixelColor(0, pixelsStatus. Color(0, 0, 150)); pixelStatus.show(); หยุดพัก; กรณีที่ 3: pixelsStatus.setPixelColor(0, pixelsStatus. Color(0, 0, 0)); pixelStatus.show(); หยุดพัก;
}
}