Search This Blog

Sunday, 15 June 2025

tes sms dan call sim800 dan oled 128x64

 #include <HardwareSerial.h>

#include <Wire.h> // Untuk komunikasi I2C OLED

#include <Adafruit_GFX.h>

#include <Adafruit_SSD1306.h>


// Definisikan pin RX dan TX untuk komunikasi serial antara ESP32 dan SIM800L

#define SIM800L_RX_PIN 16 // Pin RX ESP32 terhubung ke TX SIM800L

#define SIM800L_TX_PIN 17 // Pin TX ESP32 terhubung ke RX SIM800L


// Definisikan pin untuk LED indikator

#define LED_PIN 2 // Contoh pin GPIO2 untuk LED, bisa diganti sesuai kebutuhan


// Ukuran layar OLED (128x64)

#define SCREEN_WIDTH 128 // Lebar piksel OLED

#define SCREEN_HEIGHT 64 // Tinggi piksel OLED


// Deklarasi objek SSD1306 (OLED I2C address 0x3C atau 0x3D)

// Ganti 0x3C jika OLED Anda menggunakan alamat 0x3D

Adafruit_SSD1306 display(SCREEN_WIDTH, SCREEN_HEIGHT, &Wire, -1);


// Buat objek HardwareSerial untuk SIM800L

HardwareSerial sim800lSerial(1); // Gunakan UART1 pada ESP32 (UART0 digunakan untuk Serial debugging)


// --- Deklarasi Fungsi Prototipe ---

// Fungsi untuk mengirim perintah AT dan membaca responsnya

String sendATCommand(String command);

// Fungsi untuk mendapatkan dan menampilkan kekuatan sinyal di OLED

void getAndDisplaySignalStrength();

// Fungsi untuk mengirim SMS

void sendSMS(String phoneNumber, String message);

// Fungsi baru untuk mengontrol status LED berdasarkan hasil "ping"

void setLedStatus(bool pingSuccess);

// Fungsi baru untuk melakukan panggilan telepon

void makeCall(String phoneNumber, int callDurationSeconds);


void setup() {

  // Inisialisasi komunikasi serial untuk debugging (monitor serial)

  Serial.begin(115200);

  Serial.println("Memulai pengujian koneksi ESP32 dengan SIM800L, OLED, dan LED...");


  // Inisialisasi pin LED sebagai output

  pinMode(LED_PIN, OUTPUT);

  digitalWrite(LED_PIN, LOW); // Pastikan LED mati di awal inisialisasi


  // Inisialisasi OLED

  if (!display.begin(SSD1306_SWITCHCAPVCC, 0x3C)) { // Alamat I2C umum untuk OLED

    Serial.println(F("Alokasi SSD1306 gagal"));

    for (;;) ; // Jangan lanjutkan jika gagal, berhenti di sini

  }

  display.display(); // Tampilkan logo boot-up Adafruit

  delay(2000);

  display.clearDisplay(); // Hapus tampilan

  display.setTextSize(1); // Ukuran teks 1

  display.setTextColor(SSD1306_WHITE); // Warna teks putih


  // Tampilkan pesan inisialisasi di OLED

  display.setCursor(0, 0);

  display.println("ESP32 + SIM800L");

  display.println("Inisialisasi...");

  display.display();

  delay(2000);


  // Inisialisasi komunikasi serial untuk SIM800L

  // Baud rate 9600, 8 bit data, tanpa paritas, 1 bit stop

  sim800lSerial.begin(9600, SERIAL_8N1, SIM800L_RX_PIN, SIM800L_TX_PIN);

  delay(1000); // Beri waktu modul untuk stabil


  // --- Pengujian Modul SIM800L dan Indikator LED ---


  Serial.println("Mengirim AT command untuk memeriksa koneksi...");

  display.clearDisplay();

  display.setCursor(0, 0);

  display.println("Cek Koneksi GSM...");

  display.display();

  // Kirim perintah AT dan perbarui status LED

  String atResponse = sendATCommand("AT");

  // Perbarui status LED: ON jika ada "OK", berkedip jika tidak

  setLedStatus(atResponse.indexOf("OK") != -1);

  delay(1000);


  Serial.println("Mengirim AT+CSQ untuk memeriksa kualitas sinyal...");

  display.clearDisplay();

  display.setCursor(0, 0);

  display.println("Mengecek Sinyal...");

  display.display();

  // Panggil fungsi untuk mendapatkan dan menampilkan sinyal (fungsi ini juga memanggil sendATCommand)

  getAndDisplaySignalStrength();

  delay(2000);


  Serial.println("Mengirim AT+CREG? untuk memeriksa pendaftaran jaringan...");

  display.clearDisplay();

  display.setCursor(0, 0);

  display.println("Mendaftar Jaringan...");

  display.display();

  // Kirim perintah AT+CREG? dan perbarui status LED

  String cregResponse = sendATCommand("AT+CREG?");

  setLedStatus(cregResponse.indexOf("OK") != -1); // Update LED berdasarkan respons CREG

  delay(2000); // Beri waktu lebih untuk pendaftaran jaringan jika diperlukan


  Serial.println("Mencoba mengirim SMS...");

  display.clearDisplay();

  display.setCursor(0, 0);

  display.println("Mengirim SMS...");

  display.display();

  // Kirim SMS (fungsi ini juga memanggil sendATCommand dan mengupdate LED)

  sendSMS("+628112508805", "Halo dari ESP32 dan SIM800L!");

  delay(3000); // Beri waktu setelah pengiriman SMS


  // --- Pengujian Panggilan Telepon ---

  Serial.println("Mencoba melakukan panggilan telepon...");

  display.clearDisplay();

  display.setCursor(0, 0);

  display.println("Melakukan Panggilan...");

  display.display();

  // Lakukan panggilan ke nomor yang sama, durasi 10 detik

  makeCall("+628112508805", 10);

  delay(3000); // Beri waktu setelah panggilan


  // Pesan akhir pengujian di OLED

  display.clearDisplay();

  display.setCursor(0, 0);

  display.println("Pengujian Selesai!");

  display.println("Cek SMS & Panggilan Anda.");

  display.display();

}


void loop() {

  // Dalam loop, kita bisa memperbarui kekuatan sinyal dan melakukan "ping" secara berkala

  // untuk mempertahankan indikator LED tetap relevan.


  delay(5000); // Jeda 5 detik sebelum ping berikutnya

  Serial.println("Melakukan ping (AT command) untuk indikator LED...");

  // Kirim perintah AT sebagai "ping" dan perbarui status LED

  String atResponseLoop = sendATCommand("AT");

  setLedStatus(atResponseLoop.indexOf("OK") != -1); // Perbarui status LED

  

  delay(5000); // Jeda lagi sebelum pengecekan sinyal

  getAndDisplaySignalStrength(); // Memperbarui kekuatan sinyal di OLED dan LED

}


// Fungsi untuk mengirim AT command ke SIM800L dan membaca responsnya

String sendATCommand(String command) {

  Serial.print("Mengirim: ");

  Serial.println(command);

  sim800lSerial.println(command); // Kirim perintah ke SIM800L


  String response = "";

  long timeout = millis();

  // Tunggu respons selama 2 detik

  while (millis() - timeout < 2000) {

    if (sim800lSerial.available()) {

      char c = sim800lSerial.read(); // Baca karakter dari SIM800L

      Serial.write(c); // Tulis karakter ke Monitor Serial untuk debugging

      response += c; // Tambahkan karakter ke string respons

    }

  }

  Serial.println(); // Baris baru untuk kejelasan di Monitor Serial

  return response; // Kembalikan string respons lengkap

}


// Fungsi untuk mengontrol status LED berdasarkan hasil "ping"

// Jika pingSuccess TRUE (modul merespons "OK"), LED menyala stabil.

// Jika pingSuccess FALSE (modul tidak merespons "OK" atau timeout), LED berkedip cepat.

void setLedStatus(bool pingSuccess) {

  if (pingSuccess) {

    digitalWrite(LED_PIN, HIGH); // LED ON (menyala stabil)

    Serial.println("LED ON: Modul merespons dengan OK.");

  } else {

    Serial.println("LED BLINK: Modul tidak merespons OK (timeout atau error).");

    for (int i = 0; i < 5; i++) { // Berkedip cepat 5 kali

      digitalWrite(LED_PIN, HIGH); // LED menyala

      delay(100); // Jeda singkat

      digitalWrite(LED_PIN, LOW); // LED mati

      delay(100); // Jeda singkat

    }

    digitalWrite(LED_PIN, LOW); // Pastikan LED mati setelah berkedip

  }

}


// Fungsi untuk mendapatkan dan menampilkan kekuatan sinyal (RSSI) di OLED

void getAndDisplaySignalStrength() {

  String response = sendATCommand("AT+CSQ"); // Kirim AT+CSQ dan dapatkan respons

  // Perbarui status LED berdasarkan respons AT+CSQ juga

  setLedStatus(response.indexOf("OK") != -1);


  int rssi = -1; // Nilai default jika tidak ditemukan

  int commaIndex = response.indexOf(','); // Cari koma pertama

  // Periksa apakah respons mengandung "+CSQ:" dan koma

  if (response.indexOf("+CSQ:") != -1 && commaIndex != -1) {

    // Ekstrak string RSSI

    String rssiStr = response.substring(response.indexOf(":") + 1, commaIndex);

    rssi = rssiStr.toInt(); // Konversi ke integer

  }


  // Tampilkan informasi sinyal di OLED

  display.clearDisplay();

  display.setCursor(0, 0);

  display.setTextSize(1);

  display.println("Kekuatan Sinyal:");

  display.setTextSize(2); // Ukuran teks lebih besar untuk nilai RSSI


  if (rssi >= 0 && rssi <= 31) { // Periksa apakah RSSI valid

    display.print("RSSI: ");

    display.print(rssi);

    display.print(" (");

    display.print(-113 + rssi * 2); // Konversi kasar ke dBm (untuk referensi)

    display.println(" dBm)");


    display.setTextSize(1);

    display.print("Status: ");

    if (rssi >= 20) {

      display.println("Sangat Baik");

    } else if (rssi >= 10) {

      display.println("Baik");

    } else if (rssi >= 2) {

      display.println("Cukup");

    } else {

      display.println("Lemah/Tidak Ada");

    }

  } else {

    display.println("Tidak Diketahui"); // Jika RSSI tidak valid

  }

  display.display(); // Tampilkan ke layar OLED

}


// Fungsi untuk mengirim SMS ke nomor telepon tertentu dengan pesan tertentu

void sendSMS(String phoneNumber, String message) {

  Serial.println("Mengatur mode SMS ke Text Mode...");

  // Atur modul ke Text Mode SMS dan perbarui status LED

  String modeResponse = sendATCommand("AT+CMGF=1");

  setLedStatus(modeResponse.indexOf("OK") != -1);

  delay(1000); // Beri waktu modul untuk merespons


  Serial.print("Mengirim SMS ke: ");

  Serial.println(phoneNumber);

  sim800lSerial.print("AT+CMGS=\""); // Perintah untuk mengirim SMS

  sim800lSerial.print(phoneNumber); // Nomor tujuan

  sim800lSerial.println("\""); // Akhiri perintah dengan kutip dan baris baru

  delay(100); // Beri sedikit waktu


  sim800lSerial.print(message); // Kirim isi pesan

  sim800lSerial.write(0x1A); // Karakter Ctrl+Z untuk mengakhiri pesan dan memicu pengiriman

  Serial.println("Pesan dikirim. Menunggu konfirmasi...");


  String smsConfirmation = "";

  long timeout = millis();

  // Tunggu respons konfirmasi pengiriman SMS selama 10 detik

  while (millis() - timeout < 10000) {

    if (sim800lSerial.available()) {

      char c = sim800lSerial.read();

      Serial.write(c);

      smsConfirmation += c;

    }

  }

  Serial.println();

  // Perbarui status LED: ON jika SMS dikonfirmasi OK atau +CMGS:, BLINK jika error/timeout

  setLedStatus(smsConfirmation.indexOf("OK") != -1 || smsConfirmation.indexOf("+CMGS:") != -1);

}


// Fungsi untuk melakukan panggilan telepon ke nomor yang ditentukan

// Panggilan akan otomatis diputus setelah callDurationSeconds

void makeCall(String phoneNumber, int callDurationSeconds) {

  Serial.print("Melakukan panggilan ke: ");

  Serial.println(phoneNumber);

  display.clearDisplay();

  display.setCursor(0,0);

  display.println("Memanggil:");

  display.println(phoneNumber);

  display.display();


  String callResponse = sendATCommand("ATD" + phoneNumber + ";"); // Perintah dial, ';' penting

  // Perbarui status LED: ON jika modul menerima perintah dial ("OK"), BLINK jika tidak

  setLedStatus(callResponse.indexOf("OK") != -1);


  if (callResponse.indexOf("OK") != -1) {

    Serial.println("Panggilan dimulai. Menunggu koneksi atau timeout...");

    display.clearDisplay();

    display.setCursor(0,0);

    display.println("Panggilan Berlangsung...");

    display.println(phoneNumber);

    display.display();


    // Tunggu durasi panggilan yang ditentukan

    delay(callDurationSeconds * 1000);


    Serial.println("Mengakhiri panggilan...");

    display.clearDisplay();

    display.setCursor(0,0);

    display.println("Mengakhiri Panggilan...");

    display.display();

    String hangupResponse = sendATCommand("ATH"); // Perintah untuk menutup panggilan

    // Perbarui LED berdasarkan respons ATH

    setLedStatus(hangupResponse.indexOf("OK") != -1);

    delay(1000); // Beri waktu modul untuk memutus panggilan


    Serial.println("Panggilan diakhiri.");

  } else {

    Serial.println("Gagal memulai panggilan atau nomor tidak valid.");

    display.clearDisplay();

    display.setCursor(0,0);

    display.println("Panggilan Gagal!");

    display.println("Periksa Sinyal/No.");

    display.display();

    // LED sudah diatur ke BLINK oleh sendATCommand jika gagal

  }

}


No comments:

Post a Comment

CARGER AKI CONTROLER INA226-LIBARY WE ROTARI SW+OLED 0.96 SUKSES TAMPILAN LEBIH BAIK

 #include <Wire.h>  #include <Adafruit_GFX.h>    // Library grafis Adafruit #include <Adafruit_SSD1306.h> // Library untuk...