ThingPulse / esp8266-oled-ssd1306

Driver for the SSD1306 and SH1106 based 128x64, 128x32, 64x48 pixel OLED display running on ESP8266/ESP32
https://thingpulse.com
Other
2.03k stars 643 forks source link

Not working for esp8266 with software i2c #296

Closed zanjie1999 closed 3 years ago

zanjie1999 commented 4 years ago

2020-01 version is working

The latest version is not working

SSD1306Wire display(0x3c, D4, D5);

D4=gpio2

D5=gpio14

meltdown03 commented 4 years ago
In file included from /home/neal/Arduino/google-iot/google-iot.ino:4:0:
/home/neal/Arduino/libraries/ESP8266_SSD1306/src/SSD1306Wire.h: In constructor 'SSD1306Wire::SSD1306Wire(uint8_t, int, int, OLEDDISPLAY_GEOMETRY, HW_I2C, int)':
/home/neal/Arduino/libraries/ESP8266_SSD1306/src/SSD1306Wire.h:76:47: error: 'Wire1' was not declared in this scope
       this->_wire = (_i2cBus==I2C_ONE)?&Wire:&Wire1;
                                               ^

This is the error I get when trying to build the new release for my ESP8266. I think it needs another #if ESP8266 preprocessor since the esp8266 only has the one TwoWire class by default.

marcelstoer commented 4 years ago

...the new release...

You mean after the recent changes by @benoitm974?

meltdown03 commented 4 years ago

...the new release...

You mean after the recent changes by @benoitm974?

Yes, I believe this line is the issue: https://github.com/ThingPulse/esp8266-oled-ssd1306/blob/65615be7dbd2dc8f1a0477ca1fe93c296d20ef99/src/SSD1306Wire.h#L76

benoitm974 commented 4 years ago

The original issue is 18days old, when my merge was not there yet, so I believe this issue is a different ticket

BUT still my code seems not proof for non ESP32 code, I've submitted a pull request, but I don't have ESP8266 to test.

meltdown03 commented 4 years ago

Yes, sorry, I don't think it's the same issue. The fix (#298) does work for my issue though, so thank you!

marcelstoer commented 4 years ago

The original issue is 18days old, when my merge was not there yet, so I believe this issue is a different ticket

I was also surprised and hence I asked for Neal's confirmation. However, his compiler clearly showed there something wrong. Thanks for the fix.

jkunkee commented 4 years ago

Another datapoint that might be useful here:

I have an ESP8266 project with an SSD1306 attached via I2C alongside a device that can only operate at 100kHz. The latest release (4.1.0 in the Arduino library manager, without this fix) always fails to communicate with one device or the other depending on whether I reset the clock speed after SSD1306 initialization using Wire.setClock.

I pulled down the main branch with #298 merged and reworked my code to call the new constructor to set the clock speed to 100kHz. Now, a) I no longer see the individual I2C transmit and receive failures I was seeing before and b) both devices work reliably.

(Seriously, @benoitm974, I can't thank you enough.)

benoitm974 commented 4 years ago

You're welcome I added this constructor for exactly this issue of having my temp sensor limited to 100khz!

Have fun.

Le jeu. 3 sept. 2020 à 18:00, Jon Kunkee notifications@github.com a écrit :

Another datapoint that might be useful here:

I have an ESP8266 project with an SSD1306 attached via I2C alongside a device that can only operate at 100kHz. The latest release (4.1.0 in the Arduino library manager, without this fix) always fails to communicate with one device or the other depending on whether I reset the clock speed after SSD1306 initialization using Wire.setClock.

I pulled down the main branch with #298 https://github.com/ThingPulse/esp8266-oled-ssd1306/pull/298 merged and reworked my code to call the new constructor to set the clock speed to 100kHz. Now, a) I no longer see the individual I2C transmit and receive failures I was seeing before and b) both devices work reliably.

(Seriously, @benoitm974 https://github.com/benoitm974, I can't thank you enough.)

— You are receiving this because you were mentioned. Reply to this email directly, view it on GitHub https://github.com/ThingPulse/esp8266-oled-ssd1306/issues/296#issuecomment-686590757, or unsubscribe https://github.com/notifications/unsubscribe-auth/AAIWETPNTQD7ZO4YGJHA7KDSD64SHANCNFSM4PBKZCWA .