在自動化分揀線上,一個不起眼的U型裝置精準捕捉每個包裹通過瞬間——這正是凹型光電開關在無聲工作,它的可靠源于精密的硬件與恰到好處的程序邏輯。
凹型光電開關憑借非接觸式檢測和卓越的環(huán)境適應性,在工業(yè)自動化、智能設備中應用廣泛。其U型槽結構,一側(cè)為紅外發(fā)射器,另一側(cè)為接收器,通過檢測物體是否阻斷光路實現(xiàn)位置、計數(shù)或安全防護。真正釋放其潛力,關鍵在于理解其工作原理并掌握核心編程方法。
凹型光電開關(Slot-Type或U-Type)的本質(zhì)是一個光路通斷傳感器:
輸出模式是編程的基礎:
無論使用何種控制器,處理凹型光電開關信號的核心編程邏輯高度一致:
sensorState = ReadDigitalPin(SENSOR_PIN); // 讀取傳感器引腳狀態(tài)
if (digitalRead(SENSOR_PIN) == LOW) { // 因NPN NO遮擋時輸出低電平
// 物體存在!執(zhí)行相應動作(如計數(shù)+1, 啟動電機, 點亮LED)
objectDetected = true;
// ... 執(zhí)行動作代碼 ...
} else {
// 無物體, 光路通暢
objectDetected = false;
}
if (digitalRead(SENSOR_PIN) == LOW) { // 初始檢測到低電平(遮擋)
delay(20); // 延時20ms
if (digitalRead(SENSOR_PIN) == LOW) { // 再次確認仍為低電平
// 確認物體穩(wěn)定遮擋,執(zhí)行動作
handleObjectDetected();
}
}
// 假設:
// - 傳感器: NO(常開)型 NPN輸出凹型光電開關
// - 連接到Arduino引腳2 (內(nèi)部已啟用上拉電阻)
const int sensorPin = 2; // 信號線接Arduino D2
bool lastState = HIGH; // 假設初始狀態(tài)(無遮擋,內(nèi)部上拉為HIGH)
bool currentState;
unsigned long lastDebounceTime = 0;
const unsigned long debounceDelay = 50; // 消抖延時50ms
void setup() {
pinMode(sensorPin, INPUT_PULLUP); // 配置為輸入,啟用內(nèi)部上拉電阻
Serial.begin(9600);
}
void loop() {
int reading = digitalRead(sensorPin); // 讀取當前狀態(tài)
// 檢查狀態(tài)是否有變化(有抖動或真實變化)
if (reading != lastState) {
lastDebounceTime = millis(); // 重置消抖計時器
}
// 等待足夠消抖時間后判斷
if ((millis() - lastDebounceTime) > debounceDelay) {
// 消抖期結束后的狀態(tài)是穩(wěn)定狀態(tài)
if (reading != currentState) {
currentState = reading;
// 當前狀態(tài)為LOW (NPN NO傳感器被遮擋時輸出低電平)
if (currentState == LOW) {
Serial.println("物體檢測到!");
// 這里執(zhí)行檢測到物體后的動作,例如計數(shù)器增加
// count++;
} else { // 當前狀態(tài)為HIGH (光路通暢)
Serial.println("物體離開。");
// 這里可以執(zhí)行物體離開后的動作
}
}
}
lastState = reading; // 更新"上一次"狀態(tài)
}
I0.0
連接一個PNP型、常開(NO) 凹型光電開關的輸出。