ข้ามไปที่เนื้อหาหลัก

ส่งงานครั้งที่ 14

Earthquake Detector Alarm

อุปกรณ์
  • Arduino UNO
  • Accelerometer ADXL335
  • 16x2 LCD
  • Buzzer
  • BC547 transistor
  • 1k Resistors
  • 10K POT
  • LED
  • Power Supply 9v/12v
  • Berg sticks male/female
Diagram



Code

#include<LiquidCrystal.h>      // ประกาศเมื่อใช้LCD
LiquidCrystal lcd(9,8,7,6,5,4);   // กำหนดขาที่ต่อกับจอ
#define buzzer 12 // ขาที่ต่อลำโพง
#define led 13  //ขาที่ต่อกับLED
#define x A0  // ขาOutputของแกนx
#define y A1  // ขาOutputของแกนy
#define z A2  // ขาOutputของแกนz
/*variables*/
int xsample=0;
int ysample=0;
int zsample=0;
long start;
int buz=0;
/*Macros*/
#define samples 50
#define maxVal 20   // ค่าที่เปลี่ยนแปลงทาง+มากที่สุด
#define minVal -20    // ค่าที่เปลี่ยนแปลงทาง-มากที่สุด
#define buzTime 5000  // เวลาที่ลำโพงดัง
void setup()
{
  lcd.begin(16,2);  //ตำแหน่งlcd
  Serial.begin(9600); // ค่าการรับส่งข้อมูลserial
  delay(1000);
  lcd.print("EarthQuake ");
  lcd.setCursor(0,1);
  lcd.print("Detector    ");
  delay(2000);
  lcd.clear();
  lcd.print("Circuit Digest ");
  lcd.setCursor(0,1);
  lcd.print("Saddam Khan    ");
  delay(2000);
  lcd.clear();
  lcd.print("Calibrating.....");
  lcd.setCursor(0,1);
  lcd.print("Please wait...");
  pinMode(buzzer, OUTPUT);
  pinMode(led, OUTPUT);
  buz=0;
  digitalWrite(buzzer, buz);
  digitalWrite(led, buz);
  for(int i=0;i<samples;i++)      // นำตัวอย่างไปเปรียบเทียบ
  {
    xsample+=analogRead(x);
    ysample+=analogRead(y);
    zsample+=analogRead(z);
  }
  xsample/=samples;   // รับค่า avg ให้ x
  ysample/=samples;     // รับค่า avg ให้ y
  zsample/=samples;   // รับค่า avg ให้ z
 
  delay(3000);
  lcd.clear();
  lcd.print("Calibrated");
  delay(1000);
  lcd.clear();
  lcd.print("Device Ready");
  delay(1000);
  lcd.clear();
  lcd.print(" X     Y     Z   ");
}
void loop()
{
    int value1=analogRead(x);   // อ่านค่า x ที่ได้
    int value2=analogRead(y);   //อ่านค่า y ที่ได้
    int value3=analogRead(z);   //อ่านค่า z ที่ได้
    int xValue=xsample-value1;    // หาค่าการเปลี่ยนแปลงของ x
    int yValue=ysample-value2;    // หาค่าการเปลี่ยนแปลงของ y
    int zValue=zsample-value3;    // หาค่าการเปลี่ยนแปลงของ z
  /*แสดงค่าที่เปลี่ยนแปลงบนจอLcd*/
    lcd.setCursor(0,1);
    lcd.print(zValue);
    lcd.setCursor(6,1);
    lcd.print(yValue);
    lcd.setCursor(12,1);
    lcd.print(zValue);
    delay(100);
  /* คำนวณค่าการเปลี่ยนแปลงกับค่ามากสุดที่เตรียมไว้*/
    if(xValue < minVal || xValue > maxVal  || yValue < minVal || yValue > maxVal  || zValue < minVal || zValue > maxVal)
    {
      if(buz == 0)
      start=millis();   // เวลาที่เริ่ม
       buz=1;       // ลำโพง / led ทำงาน
    } 
   else if(buz == 1)        //  ลำโพงทำงานเมื่อมีแ่นดินไหว
   {
      lcd.setCursor(0,0);
      lcd.print("Earthquake Alert   ");
      if(millis()>= start+buzTime)  
      buz=0;
   }
 
    else
    {
      lcd.clear();
      lcd.print(" X     Y     Z   ");
    }
    digitalWrite(buzzer, buz);    // ลำโพงเปิดปิดตามคำสั่ง
    digitalWrite(led, buz);   // ledเปิดปิดตามคำสั่ง
  /*ส่งค่าทีคำนวณได้เอาไปลงบนกราฟ*/
    Serial.print("x=");
    Serial.println(xValue);
    Serial.print("y=");
    Serial.println(yValue);
    Serial.print("z=");
    Serial.println(zValue);
    Serial.println(" $");
}

Credit By : https://circuitdigest.com/microcontroller-projects/arduino-earthquake-detector-alarm-circuit

ความคิดเห็น

โพสต์ยอดนิยมจากบล็อกนี้

ส่งงานครั้งที่ 17

Air Pollution Monitoring อุปกรณ์ MQ135 Gas sensor Arduino Uno Wi-Fi module ESP8266 16X2 LCD Breadboard 10K potentiometer 1K ohm resistors 220 ohm resistor Buzzer Diagram Code #include "MQ135.h" #include <SoftwareSerial.h> #define DEBUG true SoftwareSerial esp8266(9,10); // กำหนดขา 9 ของ Arduino เป็น RX pin และ ขา 10 ของ Arduino เป็น the TX pin const int sensorPin= 0; int air_quality; #include <LiquidCrystal.h> LiquidCrystal lcd(12,11, 5, 4, 3, 2); void setup() { pinMode(8, OUTPUT); lcd.begin(16,2); lcd.setCursor (0,0); lcd.print ("circuitdigest "); lcd.setCursor (0,1); lcd.print ("Sensor Warming "); delay(1000); Serial.begin(115200); esp8266.begin(115200);   sendData("AT+RST\r\n",2000,DEBUG); // reset module   sendData("AT+CWMODE=2\r\n",1000,DEBUG); // กำหนดค่า  access point   sendData("AT+CIFSR\r\n",1000,DEBUG); // รับ ip address   sendData("AT+CIPMUair_quali

ส่งงานครั้งที่ 16

Smoke Detector Using MQ2 อุปกรณ์ Arduino UNO Smoke Detector Arduino Shield (Self Designed) Power Supply Smoke Sensor (MQ2) Resistors (10K and 1K) Buzzer 16x2 LCD 10k POT LED LM358 Burg strips Diagram Code #include <LiquidCrystal.h> LiquidCrystal lcd(12, 11, 5, 4, 3, 2); #define buzzer 9 #define sensor A0   #define load_Res 10   #define air_factor 9.83                                                   float SmokeCurve[3] ={2.3,0.53,-0.44};    // (x, y, slope) x,y พิกัดของจุดหนึ่งและความลาดชันระหว่างสองจุด                                                                                       float Res=0;                 void setup() {   lcd.begin(16,2);   lcd.print("Calibrating.....");                 Res = SensorCalibration();                                                                                           lcd.print("Calibration done.");   lcd.setCursor(0,1);   lcd.print("Res=");   lcd.print(

ส่งงานครั้งที่ 18

12 V Battery Charger อุปกรณ์ Transformer 12V 1Amp IC LM317 (2) Diode Bridge W005 Connector Terminal Block (2) Capacitor 1000uF, 1uF Capacitor 0.1uF (5) Variable resistor 100R Resistor 1k (5) Resistor 10k Diode- Nn007  (3) LM358 – Opamp 0.05R - Shunt Resistor/wire LCD-16*2 (optional) Arduino Nano (optional) Diagram Code #include <LiquidCrystal.h>// ประกาศเมื่อใช้LCD LiquidCrystal lcd(11, 12, 10, 9, 8, 7); float voltage,current;  void setup() {   Serial.begin(9600);   //ตั้งค่าLCD   lcd.begin(16, 2);   // Print a message to the LCD.   lcd.setCursor(0, 0);   lcd.print("12V Charger");   lcd.setCursor(0, 1);   lcd.print("-Circuit Digest");   delay(2000);   lcd.clear();   lcd.setCursor(0, 0);   lcd.print("Voltage = ");   lcd.setCursor(0, 1);   lcd.print("Current = "); } void loop() {   voltage = (analogRead(A0)) * 0.0140625;   current = (analogRead(A1)) * 0.35;           lcd.setCursor(1