The shipping fee depends on your address
Standard: 9-15 business days,fee is down to $3.99
Express: 4-7 business days,fee is down to $5.99
WE'RE READY TO BUILD A CUSTOM PRODUCT FOR YOU.
If you're looking for a custom product, we can help. Kindly contact us via email support@keszoox.com and send us the details for your need, then we'll let you know how we can deliver the right solution.We make into production usually Within 1 - 3 Bussiness Days.
Expect customization orders.Pressure, humidity and temperature sensor module with I2C and SPI interfaces.
The GY-BME280 is a high precision combined digital pressure, humidity and temperature sensor module with I2C and SPI interfaces.
The BME280 is a precision Bosch sensor that can be used in many applications from weather monitoring to gaming controls to altitude measurements with enough precision to know if an object has been lifted a couple of feet.
The BME280 is a higher performance version of the BMP280 with much better noise performance and also includes humidity sensing the BMP280 does not have.
Compared to the BME280 I2C module, this one exposes the SPI interface along with I2C but it is 3.3V operation only while the BME280 I2C module has a built in regulator and logic level shifters and will operate at either 5V or 3.3V.
The temperature measurement is used internally to compensate the pressure and humidity sensors and is also available to estimate the ambient temperature as well.
The device has numerous sampling and filtering options that can be employed to optimize the device for specific applications.
Note that this device operates at 3.3V. If it is being used with a 5V MCU, it should be powered off the 3.3V output. The good news is that the I2C interface is an open-drain interface with 10K pull-up resistors to the modules Vcc (3.3V) and so it can be used without level shifting. If you want to use the SPI interface instead, it will need to be level shifted to avoid possible damage to the module.
The BME280 can measure temperature over the range of -40 to 80°C.
Full accuracy of ±1.0°C is obtained over the range of 0 to 65°C. Outside that range, the accuracy can decrease to ±1.5°C
The BME280 can measure humidity over the range of 0 to 100% with an accuracy of ±3%.
The sensor can measure up to 100% humidity over the temperature range of 0 to 60°C. At very high or low temperatures, the maximum measurable humidity decreases per the graph on page 10 of the datasheet.
The BME280 can measure pressure over the range of 300 to 1100 hPa with excellent accuracy of ±1.0 hPa.
Full accuracy is obtained over the temperature range of 0 to 65°C. This gives an elevation measurement accuracy of approximately ±1 meter. Outside that range the accuracy can decrease to ±1.7 hPa
The BME280 does not measure altitude directly, but it can be calculated using the pressure reading. Most libraries for this device include altitude calculation routines.
Since the device does a very good job of measuring pressure, it can do a very good job of calculating relative altitude. If you have an altitude reading with the device sitting on a table and then move it to the floor, it will show a 2 foot decrease in altitude.
If on the other hand you are trying to measure absolute altitude, such as the altitude of your table relative to sea level, things get more complicated. Since altitude is relative to sea level the device needs to know the current air pressure corrected to sea level so that it has a reference by which to calculate the altitude given the air pressure that it is currently reading.
You can get somewhat close by finding the reported air pressure from a local airport or weather service on-line which are corrected for sea level. In our example program down below, you would enter this value in the SEA_LEVEL_PRESSURE constant. In our example, we have 1013.25 loaded which is a typical reading.
Since the air pressure is constantly changing based on time, location and weather conditions, unless you have an accurate barometer corrected to sea level with you to reference, it will be difficult to get closer than 20-30 feet.
If you know the altitude that the sensor is at, you can also back into a reading by modifying the SEA_LEVEL_PRESSURE constant to give you the correct altitude reading. This might be useful if you want to make absolute measurements based on your current elevation, such as sending a rocket up into the air.
Because the I2C interface does not require level shifting when used with a 5V MCU, it is typically the preferred interface to use.
The CSB (Chip Select Bus) pin determines which bus to use. A logic HIGH selects the I2C bus. A 10K pull-up resistor on the module pulls this pin HIGH and so the I2C bus is selected by default unless this pin is grounded.
The module supports two different I2C addresses, either 0x76 or 0x77 which allows up to 2 sensors to be used on the same bus. The SDO pin determines which address to used. A weak pull-down resistor on the module pulls SDO low so 0x76 is the default address if the SDO pin is not connected. Connect the SDO to Vcc to select 0x77.
The SCL and SDA pins connect to the SCL and SDA pins on the MCU.
If more than 2 sensors are needed, then the SPI bus can be used.
To enable the SPI interface, connect CSB to ground.
The other connection are:
Note that if using this module with a 5V MCU, a logic level shifter should be added to these lines.
The module brings out the following connections.
1 x 6 Header
The module ships with the male header strip loose. The header can be soldered to the top or bottom of the module depending on the planned use or wires can be used to make the connections.
For breadboard use, we put the headers on the bottom. Soldering is easiest if the header is inserted into a solderless breadboard to hold it in position during the soldering process.
These are nice little assemblies. The boards are high quality with gold plating.
The program below implements a simple weather station using the GY-BME280 module and a LCD2004 20 x 4 LCD to display the info.
A simpler version of the program that just dumps the information to the Serial Monitor window can be found on the BME280 I2C page.
There are many libraries for the BME280 sensor. In the example here, we are using the Adafruit libraries. Note that the Adafruit_sensor library will need to be manually downloaded from this link: https://github.com/adafruit/Adafruit_Sensor
The other libraries can be downloaded via the IDE library manager.
/* BME280 Weather Station application Uses LCD2004 with I2C interface for display. Connect I2C interface of both LCD display and BME280 SCL connects to A5 or dedicated SCL pin SDA connects to A4 or dedicated SDA pin Connect LCD Vcc to 5V and GND to ground Connect BME280 Vcc to 3.3V and GND to ground Need to install library LiquidCrystal_I2C Need to install library Adafruit_BME280 Need to manually install library Adafruit_Sensor */ #include <Adafruit_Sensor.h> #include <Adafruit_BME280.h> #include <Wire.h> #include <LiquidCrystal_I2C.h> float temperature; float humidity; float pressure; float altitude; float const ALTITUDE = 62.0; // Altitude at my location in meters float const SEA_LEVEL_PRESSURE = 1013.25; // Pressure at sea level Adafruit_BME280 bme; // I2C LiquidCrystal_I2C lcd(0x27, 20, 4); // I2C address, 20 char x 4 lines //=============================================================================== // Initialization //=============================================================================== void setup(void) { lcd.begin(); lcd.clear(); // Clear display lcd.backlight(); // Make sure backlight is on lcd.print("Reading sensor"); bool status; // default settings status = bme.begin(0x76); // The I2C address of the sensor is 0x76 if (!status) { // Loop if sensor not found lcd.clear(); lcd.print("Error. Check"); lcd.setCursor(0, 1); lcd.print("connections"); while (1); } // Print non-changing info on LCD once lcd.clear(); // Clear display lcd.setCursor(0, 0); //Set cursor to character 0 on line 0 lcd.print("Temperature: "); lcd.setCursor(0, 1); //Set cursor to line 1 lcd.print("Humidity: "); lcd.setCursor(0, 2); // Set cursor to line 2 lcd.print("Pressure: "); lcd.setCursor(0, 3); // Set cursor to line 3 lcd.print("Altitude: "); } //=============================================================================== // Main //=============================================================================== void loop() { getPressure(); // Get sensor data and print to LCD getHumidity(); getTemperature(); getAltitude(); delay(2000); // Update readings every 2 seconds } //=============================================================================== // getTemperature - Subroutine to get and print temperature //=============================================================================== void getTemperature() { temperature = bme.readTemperature(); temperature = temperature * 9 / 5 + 32; // Convert C to F String temperatureString = String(temperature, 1); // One decimal position lcd.setCursor(13, 0); // Move to start of reading lcd.print(" "); // Clear old reading lcd.setCursor(13, 0); // Reset cursor location lcd.print(temperatureString); // Write new reading lcd.print((char)223); // Degree symbol lcd.print("F "); } //=============================================================================== // getHumidity - Subroutine to get and print humidity //=============================================================================== void getHumidity() { humidity = bme.readHumidity(); String humidityString = String(humidity, 0); lcd.setCursor(13, 1); lcd.print(" "); lcd.setCursor(13, 1); lcd.print(humidityString); lcd.print("%"); } //=============================================================================== // getPressure - Subroutine to get and print pressure //=============================================================================== void getPressure() { pressure = bme.readPressure(); pressure = bme.seaLevelForAltitude(ALTITUDE, pressure); pressure = pressure / 3386.39; // Convert hPa to in/Hg lcd.setCursor(13, 2); lcd.print(" "); lcd.setCursor(13, 2); String pressureString = String(pressure, 2); lcd.print(pressureString); lcd.print("""); } //=============================================================================== // getAltitude - Subroutine to get and print temperature //=============================================================================== void getAltitude() { altitude = bme.readAltitude(SEA_LEVEL_PRESSURE); altitude = altitude * 3.28084; // Convert meters to feet lcd.setCursor(13, 3); lcd.print(" "); lcd.setCursor(13, 3); String altitudeString = String(altitude, 0); lcd.print(altitudeString); lcd.print(" ft"); }
Notes:
Operating Ratings | ||
Vcc Range | 1.7 – 3.6V (3.3V Typical) | |
Humidity | Range | 0 – 100% |
Accuracy | ±3% | |
Pressure | Range | 300 – 1100hPa |
Accuracy | ±1hPa | |
Temperature | Range | -40 – 80°C |
Accuracy | ±1.0C | |
Dimensions | L x W (PCB) | 15.5 x 11.5mm (0.61 x 0.45″) |
Country of Origin | China | |
Datasheet | Bosch | BME280 |
Wikepdia: https://en.wikipedia.org/wiki/Atmospheric_pressure
Air Pressure Calculator: https://www.mide.com/pages/air-pressure-at-altitude-calculator
WE'RE READY TO BUILD A CUSTOM PRODUCT FOR YOU.
All orders are dispatched from our warehouse. The shipments are fully tracked—from our door to yours. Please allow 3-5 business days for your order to be processed in addition to the shipping times below.
Standard: 9-15 business days. Express: 4-7 business days.
Please note that shipping providers are extremely busy during this time, and some orders might experience a delay on top of usual delivery times. If your order is late, please allow 5-10 days more than indicated in standard shipping times before contacting our customer service. Thank you for your understanding.
All orders are 100% tracked. You’ll receive an email with a tracking number and a link to track your parcel once your order leaves our warehouse. Please allow 24-48 hours for the tracking link to start showing shipping information.
Receive our latest updates about our products & promotions.
Thanks for subscribing!
This email has been registered!