كود البحث

تحكم في محركات سيرفو باستخدام جهاز تحكم عن بُعد بالأشعة تحت الحمراء مع أردوينو

تحكم في محركات سيرفو باستخدام جهاز تحكم عن بُعد بالأشعة تحت الحمراء مع أردوينو

```html

تحكم في محركات السيرفو باستخدام جهاز تحكم عن بُعد بالأشعة تحت الحمراء وArduino

يظهر هذا المشروع كيفية التحكم في محرك سيرفو باستخدام جهاز تحكم عن بعد بالأشعة تحت الحمراء (IR) ولوحة أردوينو. يتيح هذا الإعداد التحكم اللاسلكي في موضع السيرفو، مما يجعله مثالياً لمجموعة متنوعة من التطبيقات.

بعيد
أطراف جهاز استقبال الأشعة تحت الحمراء VS1838B
أطراف مستقبل الأشعة تحت الحمراء VS1838B

إليك بعض أفكار المشاريع باستخدام هذا الإعداد:

  • تعديل حركة ودوران الكاميرا عن بُعد.
  • التحكم في حركات ذراع روبوتي.
  • أتمتة الستائر أو الستائر الخارجية.
  • إنشاء تركيبات فنية تفاعلية.
  • بناء سيارة أو مركبة يتم التحكم بها عن بُعد.

الأجهزة/المكونات

  • لوحة أردوينو (مثل: أونو، نانو)
  • محرك سيرفو
  • تحكم عن بُعد بواسطة IR (أي جهاز تحكم قياسي سينجح، لكن الشيفرة مُعدة لجهاز تحكم معين)
  • وحدة استقبال الأشعة تحت الحمراء (مثل، TSOP1838)
  • أسلاك التوصيل
  • لوح التجارب (اختياري)

دليل الأسلاك

يحتوي محرك السيرفو على ثلاثة أسلاك: الأرض (عادةً بني أو أسود)، الطاقة (عادةً أحمر)، والإشارة (غالبًا برتقالي أو أبيض). كما يحتوي مستقبل الأشعة تحت الحمراء أيضًا على ثلاثة أسلاك: الأرض، والطاقة (VCC)، والإشارة.

في الفيديو عند 01:46

IR_remote_servo_wring

  • الأرضية للسيرفو إلى الأرضية لأردوينو
  • طاقة السيرفو إلى أردوينو 5 فولت
  • إشارة السيرفو إلى دبوس آردوينو 8 (في الفيديو عند 02:23)
  • أرضي جهاز استقبال الأشعة تحت الحمراء إلى أرضي الأردوينو
  • مستقبل الأشعة تحت الحمراء VCC إلى 5V من أردوينو
  • إشارة مستقبل IR إلى دبابيس أردوينو 11 (في الفيديو عند 02:38)

شرح الكود

يبدأ الكود بتضمين المكتبات اللازمة للتواصل بالأشعة تحت الحمراء والتحكم في السيرفو.


#include <IRremote.h>
#include <Servo.h>

بعد ذلك، يتم تعريف المتغيرات الأساسية. ستحتاج إلى تكوين هذه المتغيرات بناءً على إعدادك الخاص. (في الفيديو عند 03:44)


const char type = 'B'; // 'W' for white remote, 'B' for black remote
const boolean PCB = 0;   // 1 if the IR receiver has a PCB, 0 if it's a bare module
const int SERVO_PIN = 8; // The pin connected to the servo's signal wire
int angleStep = 10;      // How many degrees the servo moves per button press
const int ANGLE_CENTRE = 90; // The center/reset position of the servo

(في الفيديو عند 05:06)

أهم خطوة في التكوين هي مطابقة أزرار جهاز التحكم عن بُعد مع إجراءات محددة. يتضمن الكود مصفوفات لأنواع مختلفة من أجهزة التحكم عن بُعد (بيضاء/سوداء، PCB/غير PCB) وأكواد الأزرار المقابلة لها. ستحتاج إلى تحديد الأكواد الصحيحة لجهاز التحكم الخاص بك وتعيينها للإجراءات المرغوبة (يمين، يسار، مركز). (في الفيديو في 05:16)


const String RIGHT = ">"; // Replace with the code for your "right" button
const String LEFT = "<";  // Replace with the code for your "left" button
const String CENTRE = "OK"; // Replace with the code for your "center" button

(في الفيديو عند 08:12)

المservoAction()تتعامل الدالة مع حركة السيرفو بناءً على إشارة الأشعة تحت الحمراء المستلمة. تتحقق من الأمر المستلم وتضبط زاوية السيرفو وفقًا لذلك.angleStepالمتغير يتحكم في الزيادة أو النقصان في موضع السيرفو. (في الفيديو في 08:06)

مشروع حي/عرض تقديمي

(في الفيديو في 09:56)

يعرض الفيديو كيفية التحكم في السيرفو باستخدام أجهزة التحكم عن بُعد المختلفة. يُظهر كيفية تعديل الكود لأنواع أجهزة التحكم المختلفة ووحدات الاستقبال. تغطي العرض التوضيحي أيضًا كيفية التقاط رموز الأشعة تحت الحمراء من أجهزة التحكم الخاصة بك ودمجها في الكود. (في الفيديو عند 12:48)

فصول

  • [00:00] مقدمة ونظرة عامة على المشروع
  • :36 المكونات والمواد
  • تعليمات الأسلاك
  • [03:16] شرح الكود
  • عرض المشروع
  • استخدام جهاز التحكم عن بُعد الخاص بك

```

الصور

موصلات جهاز استلام الأشعة تحت الحمراء VS1838B
موصلات جهاز استلام الأشعة تحت الحمراء VS1838B
SG90_servo_motor-1
SG90_servo_motor-1
remote
remote
IR_remote_servo_wring
IR_remote_servo_wring
139-Source for controlling a servo motor with an IR remote controller using Arduino
اللغة: C++
/*
 * Original library from - http://arcfn.com
 * 
 * This Arduino code controls a servo motor with an IR remote controller or any TV remote.
 * 
 * You have to select the type of your remote as Black or White in the code below
 * and also select your receiver 1838 as either a PCB or bare module. See video for details.
 * 
 * You have to watch this video: https://youtu.be/muAkBQb24NI
 * before proceeding with this code. 
 * 
 * Modified/Written by Ahmad Shamshiri
 * on August 02, 2018 at 20:35 in Ajax, Ontario, Canada
 * for Robojax.com
 * Watch video instructions for this code: https://youtu.be/Wp7hX9UErSQ
 * Get other Arduino codes from Robojax.com
 * 
 */

#include <IRremote.h>

int RECV_PIN = 11;
const char type ='B';// W for white, B for black. Must keep single quotes like 'B' or 'W'
const boolean PCB = 0;// if receiver is PCB set to 1, if not set to 0. See video for details
boolean displayCode = true;// to display remote code. if not, set to false

//***** Servo settings begins
#include <Servo.h>
Servo RJservo;  // create servo object to control a servo
const int SERVO_PIN = 8;  // analog pin used to connect the potentiometer
int angle =90;    // initial angle  for servo
int angleStep =10;
const int ANGLE_CENTRE =90;// the centre/reset angle of your servo
//**** Servo settings ends

// remote settings 
const String RIGHT=">";// move servo to the right with this key on remote
const String LEFT ="<";// move servo to the left with this key on remote
const String CENTRE ="OK";// move servo to centre with this key on remote
// remote settings end

IRrecv irrecv(RECV_PIN);

// this is array holding codes for White Remote when used with PCB version of receiver
unsigned int whiteRemotePCB[] ={
            0xE318261B, // CH-
            0x511DBB,   // CH
            0xEE886D7F,  // CH+

            0x52A3D41F, // |<<
            0xD7E84B1B, // >>|
            0x20FE4DBB, // >||          

            0xF076C13B, // -
            0xA3C8EDDB, // +
            0x12CEA6E6, // EQ

            0xC101E57B, // 0
            0x97483BFB, // 100+
            0xF0C41643, // 200+

            0x9716BE3F, // 1
            0x3D9AE3F7, // 2
            0x6182021B, // 3           

            0x8C22657B, // 4 
            0x488F3CBB, // 5
            0x449E79F,  // 6

            0x32C6FDF7, // 7
            0x1BC0157B, // 8
            0x3EC3FC1B  // 9                          
            };

// this is array holding codes for White Remote when used with non-PCB version of receiver            
unsigned int whiteRemote[] ={
            0xFFA25D, // CH-
            0xFF629D,   // CH
            0xFFE21D,  // CH+

            0xFF22DD, // |<<
            0xFF02FD, // >>|
            0xFFC23D, // >||          

            0xFFE01F, // -
            0xFFA857, // +
            0xFF906F, // EQ

            0xFF6897, // 0
            0xFF9867, // 100+
            0xFFB04F, // 200+

            0xFF30CF, // 1
            0xFF18E7, // 2
            0xFF7A85, // 3           

            0xFF10EF, // 4 
            0xFF38C7, // 5
            0xFF5AA5,  // 6

            0xFF42BD, // 7
            0xFF4AB5, // 8
            0xFF52AD  // 9                          
            };
// key lables of white remote
 String whiteRemoteKey[] ={
            "CH-",
            "CH",
            "CH+",

            "|<<",
            ">>|",
            ">||",

            "-",
            "+",
            "EQ",

            "0",
            "100+",
            "200+",

            "1",
            "2",
            "3",

            "4",
            "5",
            "6",

            "7",
            "8",
            "9"
            };

// this is array holding codes for Black Remote when used with non-PCB version of receiver
 unsigned int blackRemote[] ={
            0xFF629D, // ^
            0xFF22DD,   // <
            0xFF02FD,  // OK
            0xFFC23D, // >
            0xFFA857, // v

            0xFF6897, // 1
            0xFF9867, // 2
            0xF0C41643, // 3           

            0xFF30CF, // 4 
            0xFF18E7, // 5
            0xFF7A85,  // 6

            0xFF10EF, // 7
            0xFF38C7, // 8
            0xFF5AA5,  // 9 

            0xFF42BD, // *
            0xFF4AB5, // 0
            0xFF52AD  // #                                      
            };

// this is array holding codes for Black Remote when used with PCB version of receiver
 unsigned int blackRemotePCB[] ={
            0x511DBB, // ^
            0x52A3D41F,   // <
            0xD7E84B1B,  // OK
            0x20FE4DBB, // >
            0xA3C8EDDB, // v


            0xC101E57B, // 1
            0x97483BFB, // 2
            0xF0C41643, // 3           

            0x9716BE3F, // 4 
            0x3D9AE3F7, // 5
            0x6182021B,  // 6

            0x8C22657B, // 7
            0x488F3CBB, // 8
            0x449E79F,  // 9 

            0x32C6FDF7, // *
            0x1BC0157B, // 0
            0x3EC3FC1B  // #                                      
            };

// Black remote key names
 String blackRemoteKey[] ={
            "^",
            "<",
            "OK",
            ">",
            "v",

            "1",
            "2",
            "3",

            "4",
            "5",
            "6",

            "7",
            "8",
            "9",
            
            "*",
            "0",
            "#"
            };

decode_results results;


void setup()
{
  Serial.begin(9600);
  // In case the interrupt driver crashes on setup, give a clue
  // to the user what's going on.
  Serial.println("Robojax IR Decode");
  Serial.println("Servo Control with Remote");
  irrecv.enableIRIn(); // Start the receiver

   RJservo.attach(SERVO_PIN);  // attaches the servo on pin servoPin to the servo object

}

void loop() {

  if (irrecv.decode(&results)) {
    if(displayCode)Serial.println(results.value, HEX);
    robojaxValidateCode(results.value);// used the "robojaxValidateCode" bellow
    irrecv.resume(); // Receive the next value
  }
  delay(50);// 50 millisecond delay
}

/*
 * function: robojaxValidateCode
 * validates the remote code and prints the correct key name.
 * cd is the code passed from the loop.
 * Written by A. S. for Robojax
 */
void robojaxValidateCode(int cd)
{

  // Robojax IR Remote decoder
  int found=0;

 if(type =='W' && !PCB)
 {
    // Robojax IR White Remote decoder
    // if type is set to 'W' (white remote) and PCB=0 then check White remote code
      for(int i=0; i< sizeof(whiteRemote)/sizeof(int); i++)
      {
        if(whiteRemote[i] ==cd)
        {
          
          Serial.print("Key pressed:");
          Serial.println(whiteRemoteKey[i]);
          servoAction(whiteRemoteKey[i]);// take action
          found=1;
        }// if matched
      }// for
 }else if(type =='W' && PCB){
    // Robojax IR White Remote decoder
    // if type is set to 'W' (white remote) and PCB=1 then check White remote code
      for(int i=0; i< sizeof(whiteRemotePCB)/sizeof(int); i++)
      {
        if(whiteRemotePCB[i] ==cd)
        {
          
          Serial.print("Key pressed:");
          Serial.println(whiteRemoteKey[i]);
          servoAction(whiteRemoteKey[i]);// take action 
          found=1;
        }// if matched
      }// for  
 }else if(type =='B' && PCB){
    // Robojax IR Black Remote decoder
       // if type is set to 'B' (black remote) and PCB=1 then check Black remote code
       for(int i=0; i< sizeof(blackRemotePCB)/sizeof(int); i++)
      {
        // Robojax IR black Remote decoder
        if(blackRemotePCB[i] ==cd)
        {

          Serial.print("Key pressed:");
          Serial.println(blackRemoteKey[i]);
         servoAction(blackRemoteKey[i]);// take action     
          found=1;
        }// if matched
      }// for   
 }else{

      // if type is set to 'B' (black remote) and PCB =0 then check Black remote code
       for(int i=0; i< sizeof(blackRemote)/sizeof(int); i++)
      {
        // Robojax IR black Remote decoder
        if(blackRemote[i] ==cd)
        {

          Serial.print("Key pressed:");
          Serial.println(blackRemoteKey[i]);
          servoAction(blackRemoteKey[i]);// take action          
    
          found=1;
        }// if matched
      }// for  
 }// else
  if(!found){
    if(cd !=0xFFFFFFFF)
      {
    Serial.println("Key unknown");
      }
  }// found
}// robojaxValidateCode end

/*
 * 
 * servoAction()
 * receives string "value" as input and based on the settings, 
 * sends translates it to servo value and controls servo, either by:
 * rotating servo to the right
 * rotating servo to the left
 * moving the servo to the middle
 * 
 */
void servoAction(String value)
{
  // Servo button demo with IR remote by Robojax.com
  while(value == RIGHT){

    if (angle > 0 && angle <= 180) {
      angle = angle - angleStep;
       if(angle < 0){
        angle = 0;
       }else{
      RJservo.write(angle); // move the servo to desired angle
      Serial.print("Moved to: ");
      Serial.print(angle);   // print the angle
      Serial.println(" degree");
       }
    }// if
    value =".";
    delay(100);
  }// while for RIGHT
  while(value == LEFT){

    // Servo button demo with IR remote by Robojax.com
    if (angle >= 0 && angle <= 180) {
      angle = angle + angleStep;
      if(angle >180){
        angle =180;
       }else{
      RJservo.write(angle); // move the servo to desired angle
      Serial.print("Moved to: ");
      Serial.print(angle);   // print the angle
      Serial.println(" degree");
       }
    }
    value =".";
    delay(100);
  }// while for LEFT

  if(value == CENTRE)
  {
    angle = ANGLE_CENTRE;
    RJservo.write(angle); // move the servo to centre at 90 degree angle
  }
    // Robojax IR Servo control
}//servoAction end

الموارد والمراجع

لا توجد موارد حتى الآن.

ملفات📁

لا توجد ملفات متاحة.