Ви не увійшли.
Здраствуйте. У меня есть задача, Ардуино Nano V3 + шилд ENC28J60 + Температурный датчик DS18B20, шилд использует для своей работы 2, 10, 11, 12, 13 цифровые пины, датчик 2 или 10 пин. Шилд мне нужен для отправки одного значения типа float xx.xx на сервер, но есть проблема когда шилд подключается - ардуино уже не видит датчика (Он у меня на 2 цифровой пин подключет). Можете помочь, может как то программно освобождать для датчика 2 пин можно?
Все компоненты покупались по ссылкам:
https://arduino.ua/prod2565-ethernet-shild-dlya-arduino-nano-v3
https://arduino.ua/prod414-temperatyrnii-datchik-vodonepronicaemii-ds18b20
https://arduino.ua/prod166-arduino-nano-v3-0-avr-atmega328-p-20au-s-kabelem-mini-usb-i-raspayannimi-razyomami
Остання редакція VAlekkk (2019-10-23 14:48:15)
Неактивний
Вот скетч:
#include "etherShield.h"
#include "ETHER_28J60.h"
#include <OneWire.h>
#include <DallasTemperature.h>
#define ONE_WIRE_BUS 2
static uint8_t mac[6] = {0x54, 0x55, 0x58, 0x10, 0x00, 0x24};
static uint8_t ip[4] = {192, 168, 0, 5};
static uint16_t port = 80;
OneWire oneWire(ONE_WIRE_BUS);
DallasTemperature sensors(&oneWire);
ETHER_28J60 ethernet;
void setup(void)
{
Serial.begin(9600);
ethernet.setup(mac, ip, port);
sensors.begin();
}
void loop(void) {
sensors.requestTemperatures();
if (ethernet.serviceRequest())
{
float getTemp = sensors.getTempCByIndex(0);
ethernet.print("<html><head><title>Температура</title> </head>");
ethernet.print("<body><CENTER><H2>Температура</H2></BR><H1>");
ethernet.print(getTemp);
ethernet.print(" ºC</H1>");
ethernet.print("</CENTER></body></html>");
ethernet.respond();
}
Serial.print("Celsius temperature: ");
Serial.print(sensors.getTempCByIndex(0));
Serial.print(" - Fahrenheit temperature: ");
Serial.println(sensors.getTempFByIndex(0));
delay(1000);
}
Вывод когда Ethernet не подключен:
Celsius temperature: 22.50 - Fahrenheit temperature: 72.50Celsius temperature: 22.50 - Fahrenheit temperature: 72.50Celsius temperature: 22.50 - Fahrenheit temperature: 72.50
Вывод когда Ethernet подключен:
Celsius temperature: -127.00 - Fahrenheit temperature: -196.60Celsius temperature: -127.00 - Fahrenheit temperature: -196.60Celsius temperature: -127.00 - Fahrenheit temperature: -196.60
Неактивний
Відключи шилд, під`єднай DS18B20 через пін №3 (щоб перевірити)
Залий цей код:
#include <OneWire.h>
// OneWire DS18S20, DS18B20, DS1822 Temperature Example
//
// http://www.pjrc.com/teensy/td_libs_OneWire.html
//
// The DallasTemperature library can do all this work for you!
// http://milesburton.com/Dallas_Temperature_Control_Library
OneWire ds(3); // on pin 10 (a 4.7K resistor is necessary)
void setup(void) {
Serial.begin(9600);
}
void loop(void) {
byte i;
byte present = 0;
byte type_s;
byte data[12];
byte addr[8];
float celsius, fahrenheit;
if ( !ds.search(addr)) {
Serial.println("No more addresses.");
Serial.println();
ds.reset_search();
delay(250);
return;
}
Serial.print("ROM =");
for( i = 0; i < 8; i++) {
Serial.write(' ');
Serial.print(addr[i], HEX);
}
if (OneWire::crc8(addr, 7) != addr[7]) {
Serial.println("CRC is not valid!");
return;
}
Serial.println();
// the first ROM byte indicates which chip
switch (addr[0]) {
case 0x10:
Serial.println(" Chip = DS18S20"); // or old DS1820
type_s = 1;
break;
case 0x28:
Serial.println(" Chip = DS18B20");
type_s = 0;
break;
case 0x22:
Serial.println(" Chip = DS1822");
type_s = 0;
break;
default:
Serial.println("Device is not a DS18x20 family device.");
return;
}
ds.reset();
ds.select(addr);
ds.write(0x44, 1); // start conversion, with parasite power on at the end
delay(1000); // maybe 750ms is enough, maybe not
// we might do a ds.depower() here, but the reset will take care of it.
present = ds.reset();
ds.select(addr);
ds.write(0xBE); // Read Scratchpad
Serial.print(" Data = ");
Serial.print(present, HEX);
Serial.print(" ");
for ( i = 0; i < 9; i++) { // we need 9 bytes
data[i] = ds.read();
Serial.print(data[i], HEX);
Serial.print(" ");
}
Serial.print(" CRC=");
Serial.print(OneWire::crc8(data, 8), HEX);
Serial.println();
// Convert the data to actual temperature
// because the result is a 16 bit signed integer, it should
// be stored to an "int16_t" type, which is always 16 bits
// even when compiled on a 32 bit processor.
int16_t raw = (data[1] << 8) | data[0];
if (type_s) {
raw = raw << 3; // 9 bit resolution default
if (data[7] == 0x10) {
// "count remain" gives full 12 bit resolution
raw = (raw & 0xFFF0) + 12 - data[6];
}
} else {
byte cfg = (data[4] & 0x60);
// at lower res, the low bits are undefined, so let's zero them
if (cfg == 0x00) raw = raw & ~7; // 9 bit resolution, 93.75 ms
else if (cfg == 0x20) raw = raw & ~3; // 10 bit res, 187.5 ms
else if (cfg == 0x40) raw = raw & ~1; // 11 bit res, 375 ms
//// default is 12 bit resolution, 750 ms conversion time
}
celsius = (float)raw / 16.0;
fahrenheit = celsius * 1.8 + 32.0;
Serial.print(" Temperature = ");
Serial.print(celsius);
Serial.print(" Celsius, ");
Serial.print(fahrenheit);
Serial.println(" Fahrenheit");
}
Неактивний
Будь ласка розкажіть який саме резістор, бо та сама фігня з датчиком на wemos r1d1
4.7kOm - був брак, я з ним провозився 2 дня.
Не верю! (с)
При чем здесь тогда пины - типа на одних работало, на других нет?!
VAlekkk пише:4.7kOm - був брак, я з ним провозився 2 дня.
Не верю! (с)
При чем здесь тогда пины - типа на одних работало, на других нет?!
Работало без Ethernet шилда на 10 и на 2 пине, почему не знаю, а когда заменить резистор, он заработал на любом другом пине!
Неактивний
VAlekkk пише:4.7kOm - був брак, я з ним провозився 2 дня.
Не верю! (с)
При чем здесь тогда пины - типа на одних работало, на других нет?!
Наскільки я зрозумів з викуреного гугла, на деякі піни резистор вже підтягнуто при розпайці плати.
Наскільки я зрозумів з викуреного гугла, на деякі піни резистор вже підтягнуто при розпайці плати.
на нанке все пины пустые, да и на других ардуинах тоже. На ECP8266 (NodeMCU и т.п.) да, некоторые пины с распаянными на плате резисторами