#include <Adafruit_GFX.h>
#include <Adafruit_SSD1306.h>
#include <MQ135.h>
#include <Adafruit_Sensor.h>
//#include <U8g2lib.h>
#include<DHT.h>
#include <Wire.h>
//U8G2_SSD1306_128X64_NONAME_2_HW_I2C u8g2(U8G2_R0);
#define SCREEN_WIDTH 128
#define SCREEN_HEIGHT 32
#define OLED_RESET -1
Adafruit_SSD1306 display(SCREEN_WIDTH,SCREEN_HEIGHT,&Wire,-1);
#define DHTTYPE DHT22
#define DHTPIN 2
DHT dht(DHTPIN, DHTTYPE);
//MQ135 gasSensor(A0);
const float GAMMA = 0.7;
const float RL10 = 50;

void setup() {
  Serial.begin(9600);
  Wire.begin();
  if (!display.begin(SSD1306_SWITCHCAPVCC, 0x3C)) {
    Serial.println(F("SSD1306 allocation failed"));
    for (;;);}
    delay(2000);
    display.clearDisplay();
    display.setTextColor(WHITE);
      
 // u8g2.begin();
  //u8g2.clearBuffer();
  //u8g2.setFont(u8g2_font_ncenB14_tr);
 // u8g2.setFont(u8g2_font_8x13_mf);
  dht.begin();

}



float getLightingMeter() {
  int analogValue = analogRead(A1);
  float voltage = analogValue / 1024. * 5;
  float resistance = 2000 * voltage / (1 - voltage / 5);
  float lux = pow(RL10 * 1e3 * pow(10, GAMMA) / resistance, (1 / GAMMA));
  return lux ;  // Replace with your actual air quality calculation
}

void displayTemperaturePage(float temperature) {
  //u8g2.clearBuffer();
  //u8g2.setCursor(0, 10);
  //u8g2.drawStr(0,10,"Temperature:");
  //u8g2.setCursor(0, 20);
  //u8g2.println(temperature);
  //u8g2.drawStr(0,20,"Can you see this!");
  //u8g2.sendBuffer();

  Serial.print("Temperature: ");
  Serial.print(temperature);
  Serial.print("*C\t");
  
  display.clearDisplay();
  display.setTextSize(1);
  display.setCursor(0,0);
  display.print("Temp: ");
  display.setTextSize(1);
  display.setCursor(70,0);
  display.print(temperature);
  //display.print(" ");
  display.setTextSize(1);
  display.cp437(true);
  display.write(167);
  display.setTextSize(0.5);
  display.print("C");
  display.display();
}

void displayHumidityPage(float humidity) {
  //u8g2.clearBuffer();
  //u8g2.setCursor(0, 10);
  //u8g2.print("Humidity:");
  //u8g2.setCursor(0, 20);
  //u8g2.println(humidity);
  //u8g2.sendBuffer();
  Serial.println("Humidity: ");
  Serial.print(humidity);
  Serial.print("%\t");
  display.clearDisplay();
  display.setTextSize(1);
  display.setCursor(0, 10);
  display.print("Humidity: ");
  display.setTextSize(1);
  display.setCursor(70, 10);
  display.print(humidity);
  display.print("%");
  display.display();
}

//void displayAirQualityPage(float airQuality) {
 // u8g2.clearBuffer();
  //u8g2.setCursor(0, 10);
  //u8g2.println("Air Quality:");
  //u8g2.setCursor(0, 20);
  //u8g2.println(airQuality);
  //u8g2.sendBuffer();
//}

void displayLightlevel(float lux){
  //u8g2.clearBuffer();
  //u8g2.setCursor(0, 10);
  //u8g2.print("Light:");
  //u8g2.setCursor(0, 20);
  //.println(lux);
  //u8g2.sendBuffer();
  Serial.println("Lighting: ");
  Serial.print(lux);
  Serial.print("lx\t");
  display.clearDisplay();
  display.setTextSize(1);
  display.setCursor(0, 20);
  display.print("Light: ");
  display.setTextSize(1);
  display.setCursor(70, 20);
  display.print(lux);
  display.print("lx");
  display.display();
}
void loop() {
  // Read sensor data
  float temperature = dht.readTemperature();
  float humidity = dht.readHumidity();
  //float airQuality = getAirQuality();
  float lux = getLightingMeter();

  
  // Display data on different pages
  displayTemperaturePage(temperature);
  delay(5000);
  displayHumidityPage(humidity);
  delay(5000);

 
  //displayAirQualityPage(airQuality);
  //delay(5000);
  displayLightlevel(lux);
  delay(5000);
  display.display();
}
uno:A5.2
uno:A4.2
uno:AREF
uno:GND.1
uno:13
uno:12
uno:11
uno:10
uno:9
uno:8
uno:7
uno:6
uno:5
uno:4
uno:3
uno:2
uno:1
uno:0
uno:IOREF
uno:RESET
uno:3.3V
uno:5V
uno:GND.2
uno:GND.3
uno:VIN
uno:A0
uno:A1
uno:A2
uno:A3
uno:A4
uno:A5
oled1:GND
oled1:VCC
oled1:SCL
oled1:SDA
dht1:VCC
dht1:SDA
dht1:NC
dht1:GND
ldr1:VCC
ldr1:GND
ldr1:DO
ldr1:AO