I have recently been given an Arduino Uno, and I already have the Wemos D1 which has Wifi.
What I want to do as an end product is have the UNO with a number of push button switches connected, using MQTT to communicate through the Wemos Wifi to my RC car that is using MQTT.
I think that the first step is to make the wemos into a Wifi dongle for the Arduino.
Here are some videos to help:
https://www.youtube.com/watch?v=WnRk8w7SyTo
This looks like a good intro to getting started with Wemos D1, but no Wifi.
https://www.youtube.com/watch?v=q2k3CzT5qE0 -This one just a repeat, ignore it.
https://www.youtube.com/watch?v=3bFs_MZVFxw -Wemos wifi web server to control a relay.
Setting static IP address. More there than you think.
https://iotbyhvm.ooo/esp8266-static-ip-address-using-arduino-example/
And another: https://www.geekstips.com/esp8266-arduino-tutorial-iot-code-example/
also: https://create.arduino.cc/projecthub/imjeffparedes/add-wifi-to-arduino-uno-663b9e
MQTT
https://www.arduino.cc/reference/en/libraries/mqtt-client/
https://www.digikey.co.uk/en/maker/blogs/2018/how-to-use-basic-mqtt-on-arduino
https://github.com/256dpi/arduino-mqtt
https://pubsubclient.knolleary.net/ *** Just a library
22/10/20
https://www.youtube.com/watch?v=NtyyfcYQxa4 and
https://github.com/martin-ger/uMQTTBroker
Observing operation via a terminal on the R-Pi:
mosquitto_sub -h 192.168.4.1 -v -t "rc-car-pwm/#"
FORGET THE ARDUINO
Have discovered this and will convert it to use the Wemos D-1 as the Publisher for a test.
https://www.instructables.com/The-Universal-MQTT-Remote/
Have ordered 4x20 LCD screen. [See references at end] had to change program from 16x2
It connects as follows:
gnd
Vcc Vin. 5v.
SDA D2 or GPIO 4
SCL D1 or GPIO 5
As the program stands it has 4 switches, so I have assigned them as follows:
Forward +15 14, D5 on Wemos, Orange
Stop 2 , D4 on Wemos, Purple
Reverse 12, D6 on Wemos, Blue
Left 13, D7 on Wemos, Grey
14/11/20 connected up with new screen, fing shows wifi on all devices
arduino IDE serial monitor shows wemos attempting to make mqtt connection multiple times, but of course my R-Pi software does not have the loop to also try that.
rebooted pi so see if that worked.
Arduino Uno compile error:
WARNING: library LiquidCrystal_I2C claims to run on avr architecture(s) and may be incompatible with your current board which runs on esp8266 architecture(s). This is apparently due to it not specifically specifying esp8166 in the config file.
Because of this I swapped SDA and SCL https://www.instructables.com/Interfacing-LCD-20X4-Display-to-Nodemcu/
MQTT-DASH Wemos program
UserName=rc-car-11
+Password
Client_ID=rc-car-11c client_Name=rc-car-11
Topic=rc-car-pwm
forward,backwards etc
It's confusing.
More hints:
https://iotdesignpro.com/projects/how-to-connect-esp8266-with-mqtt
-- testing this.
http://bytesofgigabytes.com/mqtt/esp8266-as-mqtt-publisher-and-subscriber/
https://vimalb.github.io/IoT-ESP8266-Starter/Lesson_04/lesson.html
TESTING SCREEN
Going to try this:
https://blog.hau.me/2018/12/26/i2c-oled-display-on-a-wemos-d1-mini/
from first test file address is 0x27
Second test file didn't do anything.
third test file (the adafruit one) caused the display to flash, so that's progress of a sort.
This is with D1 for the clock.
D5 for the clock didn't do anything.
Found this: Uses 3v3 and not 5v
http://www.esp8266learning.com/wemos-mini-i2c-lcd-example.php
After trying a number of test programs I discovered that the screen brightness was turned up full and thus no characters could be seen.
Now have it displaying with the Emile Renaud program - the first.
Wemos-MQTT-Test doesn't
I2C-Test-2 doesn't
I2C-Test-3 flashes screen, doesn't display words
I2C-test-4 works once I change the order of the setCursor values
lcd.setCursor(0,2); is position 0, line 2
As the program seems to work, but pushing the buttons doesn't do anything, I'll test the voltage to the switches and see if they need pullups. Only the stop button registers any voltage. All the others need pullups. Perhaps because all of them are at 0v is the reason why nothing can be transmitted.
Found an IC that is 1 central pin for 12 15K resistors on other pins. Will use it for pullups for input pins.
Interesting sites:
https://chewett.co.uk/blog/1066/pin-numbering-for-wemos-d1-mini-esp8266/
https://community.wia.io/d/49-wemos-d1-mini-esp8266-smart-iot-button-with-messagebird-sms-and-voice-messages *** this is quite a complex example with short and long presses of a button.
https://docs.wemos.cc/en/latest/d1/d1_mini.html
The random Nerd has a good explanation and example:
https://randomnerdtutorials.com/esp8266-nodemcu-digital-inputs-outputs-arduino/
This one tells me about INPUT_PULLUP, enabling internal pullup resistors
https://vimalb.github.io/IoT-ESP8266-Starter/Lesson_09/lesson.html
25/11/20 Lots of errors in the modified program. I tried to set the message to be transmitted (Topic) according to which button was pushed, but it doesn't like this. I think that I am going to have to specify an array of messages and then use the button press to set the key.
That looks better, but still having trouble with the connect.
Added Esp8266MQTTClient library by Tuan PM
EspMQTTClient by Patrick LaPointe is already installed.
adding Esp_WiFiManager by Khoi Huang
Still have this error:
/home/peterm/wemos-Arduino/mqtt-Wemos-RC11-c/mqtt-Wemos-RC11-c.ino:
In function 'void loop()': mqtt-Wemos-RC11-c:62:18: error: expected primary-expression before '.' token if (!WiFiClient.connected() && WiFi.status() == 3)
^
Tomorrow, look at this:
https://gist.github.com/boverby/d391b689ce787f1713d4a409fb43a0a4
It compiles with a change of a deprecated label.
Now set my Wifi bits in, and then add the display
serial set to 115200
Connecting to rc-car
..........
WiFi connected
IP address:
192.168.4.7
Attempting MQTT connection...connected
subscribed to : rc-car-11/esp-bc:dd:c2:24:b0:f4/in
Publish topic: rc-car-11/esp-bc:dd:c2:24:b0:f4/out
Publish message: {"micros":20001072,"counter":1,"client":esp-bc:dd:c2:24:b0:f4}
Publish topic: rc-car-11/esp-bc:dd:c2:24:b0:f4/out
Publish message: {"micros":40002085,"counter":2,"client":esp-bc:dd:c2:24:b0:f4}
--------
Put in LCD stuff, and moved void (setup) to beginning, but no display, though it all compiles OK.
Put in display commands at appropriate place and it's OK. At some places it didn't work...
Note that it is using the library ESP_WiFiManager.
Going to change it to version f, and add the pins setup.
29/11/20
Connected to Raspberry Pi with Termius,
mosquitto_sub -h 192.168.4.1 -v -t "rc-car-11/#"
And this is the result:
This gives me a starting place for adding the switches.
Note that the Rc-car is 'rc-car-pwm', but I have used on the wemos program 'rc-car-11'. This will have to change.
Maybe that's why nothing worked on the previous revision of the wemos program- Stupid.
5/12/2020 Ok, I have the wemos sending the state 'forward' to the Raspberry Pi correctly now.
I have now added the switch sampling software to this and got it to compile without errors. I need to reduce the 5000 msec delay and test it. Oh, first add debug messages to the display.
Sort of works... Display flashes all sorts of random characters filling screen unti it has a message to display. I don't think the flow of routines is quite correct.
The serial monitor shows lots of stuff.
It's a watchdog timer thing.
https://github.com/esp8266/Arduino/issues/2866
or
https://forum.arduino.cc/index.php?topic=442570.0
Need to add a Yield() statement, now trying that to see where.
Adjusted timout back to 2sec from 0.5 sec.
iFi connected
IP address:
192.168.4.7
Attempting MQTT connection...connected
subscribed to : rc-car-pwm/Wemos-ESP8266/in
--------------- CUT HERE FOR EXCEPTION DECODER ---------------
Exception (3):
epc1=0x40100961 epc2=0x00000000 epc3=0x00000000 excvaddr=0x40000150 depc=0x00000000
>>>stack>>>
ctx: cont
sp: 3ffffd80 end: 3fffffc0 offset: 0190
3fffff10: 00000001 3ffee4c4 00000001 40201720
3fffff20: 00000000 00000c00 3ffee4c4 3ffee698
3fffff30: 3ffee460 3ffe84cc 00000020 40100c07
3fffff40: 3ffee460 3ffee4c4 3fffff8c 40206fde
3fffff50: 40206fac 3ffee4c4 3fffff8c 402042e6
3fffff60: 3ffee460 3ffee4c4 3fffff8c 402042fc
3fffff70: 3ffee460 00000000 3fffff8c 402015e6
3fffff80: 00000000 00000000 00000001 40100154
3fffff90: 3fffdad0 00000000 3ffee658 40100175
3fffffa0: 3fffdad0 00000000 3ffee658 40204adc
3fffffb0: feefeffe feefeffe 3ffe8514 40100ec1
<<<stack<<<
--------------- CUT HERE FOR EXCEPTION DECODER ---------------
ets Jan 8 2013,rst cause:2, boot mode:(3,6)
load 0x4010f000, len 3584, room 16
tail 0
chksum 0xb0
csum 0xb0
v2843a5ac
~ld
Connecting to rc-car
......
Got it working by changing the code to a do-while loop.
Have wired it up in the case.
Slow (D0) green
Right (D3) Orange
Stop (D4) Red
Forward (D5) Blue
Reverse (D6) Yellow
Left (D7) White
Ground Black
Here are some pictures of the finished product. The case was an old ADSL router.
and inside:
I moved the Wemos and turned it around so that the USB connection lined up with the hole in the case just to the right of it, so that it can be powered by a USB powerbank, or updated. The pushbuttons were cannibalized out of an old digital radio. The bits of pcb they are attached to made it easy to hot glue them in and also to solder to. I never connected up the battery pack.
24/1/2021 I keep having the problem that the 'SLOW' button connected to D0 causes flickering on the display and keeps on occuring despite other buttons being pressed.
Investigation finds that it is not a hardware problem, and here is a possible cause that needs invetigation. It looks like I can only have 5 inputs and my sixth is invalid!
https://community.blynk.cc/t/esp8266-gpio-pins-info-restrictions-and-features/22872
26/1/2021 Trying to find out the state of the subscriber on the R-Pi and why it doesn't work.
Learnt the command ps aux | grep subscriber
and the analysis of the output:
D uninterruptible sleep (usually IO)
R running or runnable (on run queue) *** state desired. ***
S interruptible sleep (waiting for an event to complete)
T stopped, either by a job control signal or because it is being traced
W paging (not valid since the 2.6.xx kernel)
X dead (should never be seen)
Z defunct ("zombie") process, terminated but not reaped by its parent
15/2/2021 If I remember correctly I got it working by taking out the timestamp from the Logging. I am just logging statements now.
References:
13/11/2023
https://www.ebay.co.uk/itm/295128076779