Mục lục:
2025 Tác giả: John Day | [email protected]. Sửa đổi lần cuối: 2025-01-23 15:15
Đây là một phần mở rộng của Có thể hướng dẫn
IOT123 - THIẾT BỊ THEO DÕI MẶT TRỜI - TILT / PAN, PANEL FRAME, LDR MOUNTS RIG. Ở đây chúng tôi tập trung vào bộ điều khiển của các servo và các cảm biến về vị trí của mặt trời. Điều quan trọng cần chỉ ra là thiết kế này giả định 2 MCU sẽ được sử dụng: một (3.3V 8mHz Arduino Pro Mini) cho bộ theo dõi năng lượng mặt trời và một MCU độc lập cho cảm biến / tác nhân của bạn.
Đây là Phiên bản 0.3
Thay vì xuất bản tất cả các dự án sau khi hoàn toàn hài lòng, tôi sẽ thực hành tích hợp liên tục và cung cấp một cái gì đó thường xuyên hơn, sửa đổi những gì tôi đã giao khi tôi cần. Tôi sẽ viết một hướng dẫn khác cho bộ sạc pin, _khi_ việc tối ưu hóa phần mềm / phần cứng bộ điều khiển đã hoàn tất. Tôi sẽ chỉ ra nơi cần tối ưu hóa khi chúng ta thực hiện bước này.
Một phần lý do cho cách tiếp cận này là phản hồi của khách hàng. Nếu các bạn thấy có nhu cầu hoặc có cách tiếp cận tốt hơn, xin vui lòng góp ý, nhưng lưu ý rằng tôi không thể giao hết mọi thứ và có thể không theo khung thời gian phù hợp với các bạn. Vì những giải thích này có vẻ ít liên quan hơn nên chúng sẽ bị xóa khỏi bài viết này.
Điều này bao gồm những gì:
- Sử dụng LDR từ Bản gốc có thể hướng dẫn để cảm nhận vị trí gần đúng của mặt trời.
- Di chuyển các Servos đối mặt với mặt trời.
- Các tùy chọn về độ nhạy của các chuyển động.
- Các tùy chọn cho kích thước bước khi di chuyển ra mặt trời.
- Các tùy chọn cho các ràng buộc góc được sử dụng trên servos.
- Các tùy chọn cho sự chậm trễ của các chuyển động.
- Giao diện I2C để cài đặt / nhận giá trị giữa các MCU.
- Ngủ sâu giữa các động tác.
Điều này không bao gồm những gì (và sẽ được giải quyết khi thời gian cho phép):
- Chỉ sử dụng điện vào ban ngày.
- Ghi nhớ vị trí bình minh và đến đó vào lúc hoàng hôn tắt.
- Tháo bộ điều chỉnh khỏi MCU.
- Tắt (các) đèn LED trên MCU.
- Định tuyến lại nguồn thông qua VCC thay vì RAW.
- Cung cấp các giải pháp thay thế cho việc nhấp nháy mà không cần nguồn điện được điều chỉnh từ bộ chuyển đổi USB sang Serial TTL.
- Màn hình điện áp pin.
MÔN LỊCH SỬ
Ngày 20 tháng 12 năm 2017 MÃ V0.1
Phiên bản ban đầu theo dõi nguồn sáng, luôn bật, không sạc
Ngày 7 tháng 1 năm 2018 MÃ V0.2
-
THAY ĐỔI PHẦN CỨNG
- Thêm chân I2C
- Thêm công tắc vào GND servo
- Nhãn in trên hộp điều khiển
-
THAY ĐỔI PHẦN MỀM
- Đọc cấu hình từ EEPROM
- Hỗ trợ bus I2C như một nô lệ cho MCU khác (3.3V)
- Đặt cấu hình qua I2C
- Đặt Đã bật qua I2C
- Nhận cấu hình qua I2C
- Nhận thuộc tính thời gian chạy thông qua I2C (Hiện đã bật và Cường độ ánh sáng hiện tại)
- Loại bỏ ghi nhật ký nối tiếp (nó ảnh hưởng đến giá trị I2C)
19 thg 1, 2018 MÃ V0.3
-
PHẦN CỨNG
Đã cập nhật nhãn. Công tắc hiện được sử dụng để chọn chế độ CẤU HÌNH hoặc THEO DÕI
-
PHẦN MỀM
- I2C chỉ được sử dụng để cấu hình
- Bộ điều khiển đợi 5 giây trước khi bắt đầu theo dõi, cho phép di chuyển tay
- Để sử dụng cấu hình I2C, SPDT phải ở trạng thái CONFIG khi khởi động đơn vị
- Trong khi theo dõi chuyển động, thiết bị đang ở chế độ ngủ sâu cho giá trị cấu hình SLEEP MINUTES (mặc định là 20 phút).
Bước 1: Vật liệu và công cụ
Hiện đã có đầy đủ danh sách Hóa đơn Nguyên vật liệu và Nguồn.
- Các bộ phận được in 3D.
- Arduino Pro Mini 3.3V 8mHz
- 1 của Bảng mạch in đa năng PCB hai mặt nguyên mẫu 4x6cm (được cắt làm đôi)
- 1 đầu tắt 40P đực (được cắt theo kích thước).
- 1 tiêu đề nữ 40P tắt (được cắt theo kích thước).
- 4 tắt 10K 1 / 4W điện trở lại.
- Trèo lên dây.
- Hàn và Sắt.
- 20 vít tự khai thác đầu chảo không gỉ 4G x 6mm.
- 4 vít tự khai thác chìm không gỉ 4G x 6mm.
- 1 tắt pin LiPo 3.7V và giá đỡ (kết thúc bằng đầu nối dupont 2P).
- 1 tắt tiêu đề góc bên phải của 2P nam
- 1 công tắc SPDT tắt 3 chân 2,54mm
- Keo Cyanoacrylate mạnh
- Đầu nối 1P cái của đầu nối Dupont (1 màu xanh lam, 1 màu xanh lục).
Bước 2: Lắp ráp mạch
Hiện tại mạch không có Mạch phân áp (vôn kế).
- Cắt Bảng mạch in đa năng PCB hai mặt nguyên mẫu 4x6cm làm đôi theo trục dài.
-
Cắt tiêu đề nam 40P thành nhiều mảnh:
- 2 giảm 12P
- 3 tắt 3P
- 6 tắt 2P.
-
Cắt tiêu đề nữ 40P thành nhiều mảnh:
- 2 giảm 12P
- 1 giảm 6P
- Hàn 2 tắt tiêu đề 12Pfemale như hình.
- Dán miếng đệm đã loại bỏ khỏi đầu cắm 3P đực (bổ sung) vào mặt dưới của SPDT Switch bằng keo Cyanoacrylate
- Ở phía bên kia, sau đó hàn 6 đầu 2P, 2 đầu 3Pmale và công tắc SPDT như hình minh họa.
- Hàn 4 khỏi điện trở 10K (A, B, C, D màu đen) qua dây dẫn đến đầu cắm chân GND (# 2 màu đen) và đến chân tiêu đề A0 - A3 (# 5, # 6, # 7, # 8) sau đó qua lỗ (màu vàng) như hình (3 ảnh + 1 sơ đồ).
- Theo dõi 3.3V từ PIN hàn LDR PINS # 4, # 6, # 8, # 10 và luồn qua lỗ đến chân VCC của tiêu đề feamale (màu xanh lá cây).
- Theo dõi 3,3V ở phía đầu cái như hình (màu đỏ) hàn vào PINS # 1, # 12, # 15.
- Lỗ xuyên qua 3,3V trên đầu cắm RAW PIN # 1 được hàn qua mặt (màu đỏ).
- Theo dõi móc nối màu cam từ mã PIN số 11 qua lỗ đến mối hàn Chân cắm nữ ở phía bên kia như hình minh họa.
- Theo dõi và hàn dây móc màu xanh lam từ # 20 đến # 30 và từ # 31 đến # 13 và # 16.
- Hàn mã PIN đầu nữ # 11 đến mã PIN đầu nam # 11 xuyên qua lỗ.
- Chuẩn bị 2 đầu nối dupont dài 30mm với đầu cắm 1P cái (1 màu xanh lam, 1 đầu màu xanh lá cây). Dải và thiếc đầu kia.
- Hàn dây Dupont màu xanh lam đến # 28; hàn dây Dupont màu xanh lục đến # 29.
- Trên mặt trên của Arduino, hãy sửa đầu cắm cái 6P sau đó hàn.
- Ở mặt trên của Arduino, hãy sửa tiêu đề cái góc vuông 2P int # 29 và # 30 sau đó hàn.
- Ở mặt dưới của Arduino, cố định 2 trong số các chân nam 12P và 1 ngoài 3P sau đó hàn.
- Chèn các chân 12P đực của Arduino vào các đầu cái của PCB 12P.
Bước 3: Nhấp nháy MCU
Arduino Pro Mini được flash thuận tiện bằng cách sử dụng bộ chuyển đổi FTDI232 USB sang TTL sử dụng đầu cắm cái 6P. Xem ảnh trên để biết sự liên kết của 2 bảng.
Đảm bảo cài đặt 3.3V được chọn trên FTDI232 của bạn. Làm theo hướng dẫn tại đây bằng cách sử dụng mã bên dưới (sử dụng liên kết tới GIST).
Thư viện năng lượng thấp (đính kèm và https://github.com/rocketscream/Low-Power) cần được cài đặt.
Sau khi Arduino Pro Mini + PCB được lắp vào vỏ, nó vẫn có thể nhấp nháy khi các chân tiêu đề tiếp xúc. Chỉ cần ngắt kết nối Bộ điều khiển khỏi Khung bảng để lộ tiêu đề.
Máy theo dõi năng lượng mặt trời nghiêng với cấu hình I2C / EEPROM và chu kỳ ngủ giữa các chuyển động. Độ chính xác của thời lượng chu kỳ ngủ giảm khi thời lượng tăng lên, nhưng đủ cho mục đích này
/* |
* sửa đổi từ mã |
* bởi Mathias Leroy |
* |
* SỬA ĐỔI V0.2 |
** I2C CÀI ĐẶT |
** CÀI ĐẶT EEPROM |
** LOẠI BỎ ĐẦU RA SERIAL - I2C ẢNH HƯỞNG |
** BẬT / TẮT THEO DÕI |
** CHUYỂN SERVOS ĐẾN GIỚI HẠN QUA I2C |
** ĐỌC CƯỜNG ĐỘ AVG HIỆN TẠI VIA I2C |
* V0.3 SỬA ĐỔI |
** CHUYỂN ĐỔI 2 CHẾ ĐỘ - THEO DÕI (KHÔNG I2C) và CẤU HÌNH (SỬ DỤNG I2C) |
** NGỦ Ở CHẾ ĐỘ THEO DÕI (CHÍNH XÁC RẤT THẤP DO ĐẾN 8 CHUN THỨ HAI) |
** DETACH / ATTACH SERVOS ON SLEEP / WAKE (TRANSISTOR ĐƯỢC SỬ DỤNG HÀNG NGÀY) |
** LOẠI BỎ VỊ TRÍ BAN ĐẦU CÓ THỂ CẤU HÌNH (GIẢM CÒN) |
** LOẠI BỎ DÉP CÓ THỂ CẤU HÌNH GIÂY (GIẢM CÒN) |
** LOẠI BỎ / BẬT / TẮT CÓ THỂ CẤU HÌNH (REDUNDANT) |
** BỎ QUA TRÌNH THEO DÕI CÓ CẤU HÌNH ĐƯỢC BẬT (SỬ DỤNG CÔNG TẮC PHẦN CỨNG) |
** LOẠI BỎ THIẾT BỊ ÁP - SẼ SỬ DỤNG THÀNH PHẦN I2C RIÊNG |
** THÊM ĐĂNG NHẬP SERIAL KHI KHÔNG SỬ DỤNG I2C |
*/ |
#bao gồm |
#bao gồm |
#bao gồm |
#bao gồm |
#bao gồm |
# xác địnhEEPROM_VERSION1 |
# defineI2C_MSG_IN_SIZE3 |
#definePIN_LDR_TL A0 |
#definePIN_LDR_TR A1 |
#definePIN_LDR_BR A3 |
#definePIN_LDR_BL A2 |
# xác địnhPIN_SERVO_V11 |
# xác địnhPIN_SERVO_H5 |
# defineIDX_I2C_ADDR0 |
# xác địnhIDX_V_ANGLE_MIN1 |
# defineIDX_V_ANGLE_MAX2 |
# defineIDX_V_SENSITIVITY3 |
# defineIDX_V_STEP4 |
# xác địnhIDX_H_ANGLE_MIN5 |
# defineIDX_H_ANGLE_MAX6 |
# defineIDX_H_SENSITIVITY7 |
# defineIDX_H_STEP8 |
# defineIDX_SLEEP_MINUTES9 |
# defineIDX_V_DAWN_ANGLE10 |
# xác địnhIDX_H_DAWN_ANGLE11 |
# defineIDX_DAWN_INTENSITY12 // mức trung bình của tất cả LDRS |
# defineIDX_DUSK_INTENSITY13 // mức trung bình của tất cả LDRS |
# defineIDX_END_EEPROM_SET14 |
# defineIDX_CURRENT_INTENSITY15 // mức trung bình của tất cả LDRS - được sử dụng để tính IDX_DAWN_INTENSITY ánh sáng xung quanh không trực tiếp |
# defineIDX_END_VALUES_GET16 |
# defineIDX_SIGN_117 |
# defineIDX_SIGN_218 |
# defineIDX_SIGN_319 |
Servo _servoH; |
Servo _servoV; |
byte _i2cVals [20] = {10, 10, 170, 20, 5, 10, 170, 20, 5, 20, 40, 10, 30, 40, 0, 0, 0, 0, 0, 0}; |
int _servoLoopDelay = 10; |
int _slowingDelay = 0; |
int _angleH = 90; |
int _angleV = 90; |
int _averageTop = 0; |
int _averageRight = 0; |
int _averageBottom = 0; |
int _averageLeft = 0; |
byte _i2cResponse = 0; |
bool _inConfigMode = false; |
voidsetup () |
{ |
Serial.begin (115200); |
getFromEeprom (); |
if (inConfigMode ()) { |
Serial.println ("Chế độ cấu hình"); |
Serial.print ("Địa chỉ I2C:"); |
Serial.println (_i2cVals [IDX_I2C_ADDR]); |
Wire.begin (_i2cVals [IDX_I2C_ADDR]); |
Wire.onReceive (nhậnEvent); |
Wire.onRequest (requestEvent); |
}khác{ |
Serial.println ("Chế độ theo dõi"); |
delay (5000); // thời gian để sử dụng nếu kết nối pin, v.v. |
} |
} |
voidloop () |
{ |
getLightValues (); |
if (! _inConfigMode) { |
// Việc cần làm: BẬT CÔNG TẮC TRANSISTOR |
_servoH.attach (PIN_SERVO_H); |
_servoV.attach (PIN_SERVO_V); |
for (int i = 0; i <20; i ++) { |
nếu (i! = 0) { |
getLightValues (); |
} |
moveServos (); |
} |
chậm trễ (500); |
_servoH.detach (); |
_servoV.detach (); |
// Việc cần làm: TẮT CÔNG TẮC TRANSISTOR |
chậm trễ (500); |
SleepFor ((_ i2cVals [IDX_SLEEP_MINUTES] * 60) / 8); |
} |
} |
//---------------------------------CHẾ ĐỘ HIỆN HÀNH |
boolinConfigMode () { |
mã pin (PIN_SERVO_H, INPUT); |
_inConfigMode = digitalRead (PIN_SERVO_H) == 1; |
return _inConfigMode; |
} |
// --------------------------------- EEPROM |
voidgetFromEeprom () { |
nếu như( |
EEPROM.read (IDX_SIGN_1)! = 'S' || |
EEPROM.read (IDX_SIGN_2)! = 'T' || |
EEPROM.read (IDX_SIGN_3)! = EEPROM_VERSION |
) EEPROM_write_default_configuration (); |
EEPROM_read_configuration (); |
} |
voidEEPROM_write_default_configuration () { |
Serial.println ("EEPROM_write_default_configuration"); |
for (int i = 0; i <IDX_END_EEPROM_SET; i ++) { |
EEPROM.update (i, _i2cVals ); |
} |
EEPROM.update (IDX_SIGN_1, 'S'); |
EEPROM.update (IDX_SIGN_2, 'T'); |
EEPROM.update (IDX_SIGN_3, EEPROM_VERSION); |
} |
voidEEPROM_read_configuration () { |
Serial.println ("EEPROM_read_configuration"); |
for (int i = 0; i <IDX_END_EEPROM_SET; i ++) { |
_i2cVals = EEPROM.read (i); |
//Serial.println(String(i) + "=" + _i2cVals ); |
} |
} |
// --------------------------------- I2C |
voidreceiveEvent (int count) { |
nếu (đếm == I2C_MSG_IN_SIZE) |
{ |
char cmd = Wire.read (); |
chỉ mục byte = Wire.read (); |
giá trị byte = Wire.read (); |
chuyển đổi (cmd) { |
case'G ': |
nếu (chỉ mục <IDX_END_VALUES_GET) { |
_i2cResponse = _i2cVals [chỉ mục]; |
} |
nghỉ; |
các trường hợp': |
nếu (chỉ mục <IDX_END_EEPROM_SET) { |
_i2cVals [index] = giá trị; |
EEPROM.update (index, _i2cVals [index]); |
} |
nghỉ; |
vỡ nợ: |
trở lại; |
} |
} |
} |
voidrequestEvent () |
{ |
Wire.write (_i2cResponse); |
} |
// --------------------------------- LDR |
voidgetLightValues () { |
int valueTopLeft = analogRead (PIN_LDR_TL); |
int valueTopRight = analogRead (PIN_LDR_TR); |
int valueBottomRight = analogRead (PIN_LDR_BR); |
int valueBottomLeft = analogRead (PIN_LDR_BL); |
_averageTop = (valueTopLeft + valueTopRight) / 2; |
_averageRight = (valueTopRight + valueBottomRight) / 2; |
_averageBottom = (valueBottomRight + valueBottomLeft) / 2; |
_averageLeft = (valueBottomLeft + valueTopLeft) / 2; |
int avgIntensity = (valueTopLeft + valueTopRight + valueBottomRight + valueBottomLeft) / 4; |
_i2cVals [IDX_CURRENT_INTENSITY] = map (avgIntensity, 0, 1024, 0, 255); |
} |
// --------------------------------- SERVOS |
voidmoveServos () { |
Serial.println ("moveServos"); |
if ((_averageLeft-_averageRight)> _ i2cVals [IDX_H_SENSITIVITY] && (_angleH-_i2cVals [IDX_H_STEP])> _ i2cVals [IDX_H_ANGLE_MIN]) { |
// đi sang trái |
Serial.println ("moveServos đi sang trái"); |
trì hoãn (_slowingDelay); |
for (int i = 0; i <_i2cVals [IDX_H_STEP]; i ++) { |
_servoH.write (_angleH--); |
trì hoãn (_servoLoopDelay); |
} |
} |
elseif ((_averageRight-_averageLeft)> _ i2cVals [IDX_H_SENSITIVITY] && (_angleH + _i2cVals [IDX_H_STEP]) <_ i2cVals [IDX_H_ANGLE_MAX]) { |
// đi đúng |
Serial.println ("moveServos đi sang trái"); |
trì hoãn (_slowingDelay); |
for (int i = 0; i <_i2cVals [IDX_H_STEP]; i ++) { |
_servoH.write (_angleH ++); |
trì hoãn (_servoLoopDelay); |
} |
} |
khác { |
// Không làm gì cả |
Serial.println ("moveServos không làm gì cả"); |
trì hoãn (_slowingDelay); |
} |
if ((_averageTop-_averageBottom)> _ i2cVals [IDX_V_SENSITIVITY] && (_angleV + _i2cVals [IDX_V_STEP]) <_ i2cVals [IDX_V_ANGLE_MAX]) { |
// đi lên |
Serial.println ("moveServos đang đi lên"); |
trì hoãn (_slowingDelay); |
for (int i = 0; i <_i2cVals [IDX_V_STEP]; i ++) { |
_servoV.write (_angleV ++); |
trì hoãn (_servoLoopDelay); |
} |
} |
elseif ((_averageBottom-_averageTop)> _ i2cVals [IDX_V_SENSITIVITY] && (_angleV-_i2cVals [IDX_V_STEP])> _ i2cVals [IDX_V_ANGLE_MIN]) { |
// đi xuống |
Serial.println ("moveServos đang đi xuống"); |
trì hoãn (_slowingDelay); |
for (int i = 0; i <_i2cVals [IDX_V_STEP]; i ++) { |
_servoV.write (_angleV--); |
trì hoãn (_servoLoopDelay); |
} |
} |
khác { |
Serial.println ("moveServos không làm gì cả"); |
trì hoãn (_slowingDelay); |
} |
} |
//---------------------------------NGỦ |
voidasleepFor (unsignedint EightSecondSe mảnh) { |
Serial.println ("SleepFor"); |
cho (unsignedint sleepCounter = EightSecondSe mảnh; sleepCounter> 0; sleepCounter--) |
{ |
LowPower.powerDown (SLEEP_8S, ADC_OFF, BOD_OFF); |
} |
} |
xem rawtilt_pan_tracker_0.3.ino được lưu trữ bằng ❤ bởi GitHub
Bước 4: Lắp ráp vỏ mạch
- Đảm bảo Ardiuno Pro Mini được lắp vào các tiêu đề trên PCB.
- Chèn đế hộp bộ điều khiển SOLAR TRACKER vào thành hộp bộ điều khiển SOLAR TRACKER và gắn 2 vít tự khai thác chìm không gỉ 4G x 6mm.
- Chèn Ardiuno Pro Mini + PCB với Tiêu đề 6P khía vào khoảng trống trong đế hộp bộ điều khiển SOLAR TRACKER.
- Chèn nắp hộp bộ điều khiển SOLAR TRACKER vào thành hộp bộ điều khiển SOLAR TRACKER và gắn 2 vít tự khai thác chìm không gỉ 4G x 6mm.
- Gắn cụm trên vào đế của Khung bảng bằng 4 vít tự khai thác chìm không gỉ 4G x 6mm.
Bước 5: Kết nối giàn khoan với bộ điều khiển
Các kết nối thích hợp đã sẵn sàng từ Bản hướng dẫn trước, là 4 kết nối 2P tắt 2P LDR và 2 kết nối 3P tắt từ servos. Điều gì là tạm thời cho đến khi sạc lại sẵn sàng là pin. Sử dụng LiPo 3.7V kết thúc trong kết nối DuPont 2P ngay bây giờ.
-
Chèn các kết nối LDR (không phân cực) từ trên xuống:
- Trên cùng bên phải
- Trên cùng bên trái
- Góc phải ở phía dưới
- Dưới cùng bên trái
-
Chèn các kết nối Servo (với dây tín hiệu ở bên trái) từ trên xuống:
- Nằm ngang
- Thẳng đứng
- CHỜ ĐẾN KHI SN SÀNG ĐỂ KIỂM TRA SAU ĐÓ: Chèn dây dẫn Nguồn DC 3.7V + ve lên trên cùng, -ve xuống dưới cùng.
Bước 6: Kiểm tra bộ điều khiển
Như đã nêu trước đây, phần mềm chưa được tối ưu hóa cho quy trình công việc Sạc bằng năng lượng mặt trời. Tuy nhiên, nó có thể được kiểm tra và điều chỉnh bằng cách sử dụng các nguồn sáng tự nhiên (mặt trời) và không tự nhiên.
Để kiểm tra theo dõi trong môi trường được kiểm soát, có thể thuận tiện để đặt PHÚT NGỦ thành giá trị thấp hơn (xem bước tiếp theo).
Bước 7: Định cấu hình Qua I2C bằng Đầu vào Bảng điều khiển
Điều này giải thích việc định cấu hình bộ điều khiển thông qua MCU thứ hai, nhập cài đặt vào cửa sổ bảng điều khiển.
- Tải tập lệnh sau lên D1M WIFI BLOCK (hoặc Wemos D1 Mini).
- Ngắt kết nối USB khỏi PC
-
KẾT NỐI PIN: -ve (Bộ điều khiển) => GND (D1M) + ve (Bộ điều khiển) => 3V3 (D1M) SCL (Bộ điều khiển) => D1 (D1M)
SDA (Bộ điều khiển) => D2 (D1M)
- Chuyển công tắc SPDT sang CONFIG
- Kết nối USB với PC
- Từ Arduino IDE, bắt đầu một cửa sổ bảng điều khiển với đúng Cổng COM
- Đảm bảo rằng "Dòng mới" và "9600 baud" được chọn
- Các lệnh được nhập vào Hộp văn bản gửi, sau đó là phím Enter
- Các lệnh có định dạng byte Ký tự byte
- Nếu byte thứ hai (phân đoạn thứ ba) không được bao gồm thì 0 (không) được gửi bởi tập lệnh
- Hãy cẩn thận khi sử dụng đầu vào nối tiếp; xem lại những gì bạn đã nhập trước khi nhấn phím "Enter". Nếu bạn bị khóa (ví dụ: thay đổi địa chỉ I2C thành một giá trị mà bạn đã quên), bạn sẽ cần phải flash lại chương trình cơ sở điều khiển.
Các biến thể được hỗ trợ trong ký tự đầu tiên của lệnh là:
- E (Bật theo dõi servo) hữu ích để dừng chuyển động trong quá trình cấu hình. Đây là đầu vào sử dụng: E 0
- D (Tắt theo dõi servo) hữu ích để bắt đầu theo dõi tự động nếu không khởi động lại thiết bị. Đây là đầu vào sử dụng: D 0
- G (Nhận giá trị cấu hình) đọc các giá trị từ EEPROM và IN-MEMORY: Đây là đầu vào sử dụng: G (chỉ mục là các giá trị byte hợp lệ 0 - 13 và 15)
- S (Đặt giá trị EEPROM) đặt các giá trị thành EEPROM khả dụng sau khi khởi động lại. Đây là đầu vào sử dụng: S (chỉ mục là các giá trị byte hợp lệ 0 - 13, giá trị là các giá trị byte hợp lệ và thay đổi theo từng thuộc tính)
Mã là điểm trung thực cho các chỉ mục nhưng phần sau được sử dụng để làm hướng dẫn cho các giá trị / nhận xét hợp lệ:
- I2C ADDRESS 0 - địa chỉ phụ của bộ điều khiển, chủ cần địa chỉ này để giao tiếp với bộ điều khiển (mặc định 10)
- TỐI THIỂU CHỨNG NHẬN TỐI THIỂU 1 - giới hạn dưới góc nghiêng của servo dọc (mặc định 10, phạm vi 0 - 180)
- MAXIMUM VERTICAL ANGLE 2 - giới hạn trên của servo dọc góc (mặc định 170, phạm vi 0 - 180)
- SENSITIVITY VERTICAL LDR 3 - Biên độ đọc LDR theo chiều dọc (mặc định 20, phạm vi 0 - 1024)
- VERTICAL ANGLE BƯỚC 4 - các bước servo dọc theo góc trên mỗi điều chỉnh (mặc định 5, phạm vi 1 - 20)
- NGANG NGANG TỐI THIỂU 5 - giới hạn dưới góc nghiêng của servo ngang (mặc định 10, phạm vi 0 - 180)
- TỐI ĐA NGANG ANGLE 6 - giới hạn trên của servo ngang góc (mặc định 170, phạm vi 0 - 180)
- SENSITIVITY HORIZONTAL LDR 7 - Lề đọc LDR ngang (mặc định 20, phạm vi 0 - 1024)
- NGANG ANGLE BƯỚC 8 - bước servo ngang góc trên mỗi điều chỉnh (mặc định 5, phạm vi 1 - 20)
- SLEEP MINUTES 9 - khoảng thời gian ngủ gần đúng giữa các lần theo dõi (mặc định 20, phạm vi 1 - 255)
- VERTICAL DAWN ANGLE 10 - SỬ DỤNG TRONG TƯƠNG LAI - góc thẳng đứng để quay lại khi mặt trời lặn
- MẶT BẰNG NGÀY NGANG CÂU 11 - SỬ DỤNG TRONG TƯƠNG LAI - góc nằm ngang để quay lại khi mặt trời lặn
- DAWN INTENSITY 12 - SỬ DỤNG TRONG TƯƠNG LAI - mức trung bình tối thiểu của tất cả các LDRs kích hoạt bắt đầu theo dõi ánh nắng mặt trời hàng ngày
- DUSK INTENSITY 13 - SỬ DỤNG TRONG TƯƠNG LAI - mức trung bình tối thiểu của tất cả các LDRs kích hoạt kết thúc theo dõi ánh nắng hàng ngày
- EEPROM VALUES MARKER 14 KẾT THÚC - GIÁ TRỊ KHÔNG ĐƯỢC SỬ DỤNG
- CURRENT INTENSITY 15 - tỷ lệ phần trăm trung bình hiện tại của cường độ ánh sáng
- END OF IN-MEMORY VALUES MARKER 16 - GIÁ TRỊ KHÔNG ĐƯỢC SỬ DỤNG.
Chụp đầu vào nối tiếp (đầu vào bàn phím trong cửa sổ giao diện điều khiển) và chuyển tiếp nó tới I2C slave ở định dạng char, byte, byte
#bao gồm |
# defineI2C_MSG_IN_SIZE2 |
# xác địnhI2C_MSG_OUT_SIZE3 |
# defineI2C_SLAVE_ADDRESS10 |
boolean _newData = false; |
const byte _numChars = 32; |
char _receiveChars [_numChars]; // một mảng để lưu trữ dữ liệu đã nhận |
voidsetup () { |
Serial.begin (9600); |
Wire.begin (D2, D1); |
chậm trễ (5000); |
} |
voidloop () { |
recvWithEndMarker (); |
parseSendCommands (); |
} |
voidrecvWithEndMarker () { |
byte tĩnh ndx = 0; |
char endMarker = '\ n'; |
char rc; |
while (Serial.available ()> 0 && _newData == false) { |
rc = Serial.read (); |
if (rc! = endMarker) { |
_receiveChars [ndx] = rc; |
ndx ++; |
if (ndx> = _numChars) { |
ndx = _numChars - 1; |
} |
} khác { |
_reiledChars [ndx] = '\ 0'; // kết thúc chuỗi |
ndx = 0; |
_newData = true; |
} |
} |
} |
voidparseSendCommands () { |
if (_newData == true) { |
constchar delim [2] = ""; |
mã thông báo char *; |
mã thông báo = strtok (_receiveChars, delim); |
char cmd = _receiveChars [0]; |
chỉ số byte = 0; |
giá trị byte = 0; |
int i = 0; |
while (mã thông báo! = NULL) { |
//Serial.println(token); |
i ++; |
chuyển đổi (i) { |
trường hợp 1: |
mã thông báo = strtok (NULL, delim); |
index = atoi (mã thông báo); |
nghỉ; |
case2: |
mã thông báo = strtok (NULL, delim); |
if (mã thông báo! = NULL) { |
value = atoi (mã thông báo); |
} |
nghỉ; |
vỡ nợ: |
mã thông báo = NULL; |
} |
} |
sendCmd (cmd, chỉ mục, giá trị); |
_newData = false; |
} |
} |
voidsendCmd (char cmd, chỉ số byte, giá trị byte) { |
Serial.println ("-----"); |
Serial.println ("Đang gửi lệnh:"); |
Serial.println ("\ t" + String (cmd) + "" + String (chỉ mục) + "" + String (giá trị)); |
Serial.println ("-----"); |
Wire.beginTransmission (I2C_SLAVE_ADDRESS); // truyền tới thiết bị |
Wire.write (cmd); // gửi một ký tự |
Wire.write (chỉ mục); // gửi một byte |
Wire.write (giá trị); // gửi một byte |
Wire.endTransmission (); |
phản hồi byte = 0; |
bool hadResponse = false; |
if (cmd == 'G') { |
Wire.requestFrom (I2C_SLAVE_ADDRESS, 1); |
while (Wire.available ()) // slave có thể gửi ít hơn yêu cầu |
{ |
hadResponse = true; |
response = Wire.read (); |
} |
if (hadResponse == true) { |
Serial.println ("Đang nhận phản hồi:"); |
Serial.println (phản hồi); |
}khác{ |
Serial.println ("Không có phản hồi, hãy kiểm tra địa chỉ / kết nối"); |
} |
} |
} |
xem rawd1m_serial_input_i2c_char_byte_byte_v0.1.ino được lưu trữ bằng ❤ bởi GitHub
Bước 8: Các bước tiếp theo
Kiểm tra lại định kỳ để kiểm tra các thay đổi trong phần mềm / phần cứng.
Sửa đổi phần mềm / phần cứng theo yêu cầu của bạn.
Nhận xét về bất kỳ yêu cầu / tối ưu hóa nào.
Đề xuất:
MẶT TRỜI MẶT TRỜI LÀM BỘ THEO DÕI TẦM NHÌN: 7 bước (có hình ảnh)
MẶT TRỜI MẶT TRỜI NHƯ MÁY THEO DÕI TẦM NHÌN: Độ lớn cơ bản được sử dụng trong Vật lý và các ngành khoa học khác để mô tả chuyển động cơ học là tốc độ. Đo lường nó đã là một hoạt động thường xuyên trong các lớp thực nghiệm. Tôi thường sử dụng máy quay video và phần mềm TRACKER để nghiên cứu chuyển động của certa
ESP8266 RGB LED STRIP Điều khiển WIFI - NODEMCU làm điều khiển từ xa hồng ngoại cho dải đèn Led được điều khiển qua Wi-Fi - Điều khiển điện thoại thông minh RGB LED STRIP: 4 bước
ESP8266 RGB LED STRIP Điều khiển WIFI | NODEMCU làm điều khiển từ xa hồng ngoại cho dải đèn Led được điều khiển qua Wi-Fi | Điều khiển bằng điện thoại thông minh RGB LED STRIP: Xin chào các bạn trong hướng dẫn này, chúng ta sẽ học cách sử dụng gật đầu hoặc esp8266 làm điều khiển từ xa IR để điều khiển dải LED RGB và Nodemcu sẽ được điều khiển bằng điện thoại thông minh qua wifi. Vì vậy, về cơ bản bạn có thể điều khiển DÂY CHUYỀN LED RGB bằng điện thoại thông minh của mình
UCL-lloT-Ánh sáng ngoài trời được kích hoạt bởi Mặt trời mọc / mặt trời lặn.: 6 bước
UCL-lloT-Outdoor-light do Sunrise / sundown kích hoạt.: Xin chào mọi người! Ý tưởng bắt nguồn từ cha tôi, người mà suốt mùa hè đã phải tự tay đi ra ngoài
Robot ăn xin với tính năng theo dõi và điều khiển khuôn mặt bằng bộ điều khiển Xbox - Arduino: 9 bước (có hình ảnh)
Robot ăn xin với tính năng theo dõi và điều khiển khuôn mặt bằng bộ điều khiển Xbox - Arduino: Chúng tôi sẽ tạo ra một robot ăn xin. Robot này sẽ cố gắng chọc tức hoặc thu hút sự chú ý của những người đi qua. Nó sẽ phát hiện khuôn mặt của họ và cố gắng bắn tia laze vào họ. Nếu bạn cho robot một đồng xu, nó sẽ hát một bài hát và nhảy. Robot sẽ cần một
IOT123 - MIỀN THEO DÕI MẶT TRỜI: 7 bước (có hình ảnh)
IOT123 - MẶT TRỜI THEO DÕI MẶT TRỜI: Có rất nhiều thiết kế tự làm cho bộ sạc theo dõi năng lượng mặt trời, nhưng hầu hết chúng đều không chống được thời tiết. Đây là một vấn đề lớn vì hầu hết thời gian, ở dưới ánh sáng mặt trời, có nghĩa là ở trong thời tiết. Đây là các bước hướng dẫn bạn trong quá trình xây dựng