-
Notifications
You must be signed in to change notification settings - Fork 21
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Issue with connecting/shooting photos after 1st time ESP8266 & Hero 7 #40
Comments
Have you tried the example in the library, does it work? As far as i remember on my hero3, if i closed the connection wrongly (i.e. turn off the camera or esp manually) this same problem happened |
Hi. Yes, I tried the example and the same thing. It only ever works the first time connected, then after it fails. Only way it works again is by resetting the wifi connection on the GoPro, then it works again for the first time only and fails. I've read other threads with a similar issue. It's as if the GoPro is closing the connection. |
I think your delay is too long, you need to call the keep alive more often |
Edit: To clarify, I've removed the delay(1000); as well. I tried that. If you look at the sample I included, it dives right into attempting to take a shot while also having a keepAlive() in there. I've even removed it from setup() and tried it in the loop. All result in the same thing. Works fine the first time, then fails until GoPro WiFi is reset. |
So, I figured out the steps necessary to cause the fail, but still no closer to determining why. This has only been validated on a Hero 7 Black. After doing all sorts of tests including restarts (3s and 10s), removing power from the GP, downgrading the GP FW to 1.6.1 (was 1.8.x) it fails the same way every time. The only success I could get is to ensure that I always called gp.end() before powering down the ESP or camera. I was able to test this by calling it, then powering down the ESP and GP in different sequences. It always worked when powered back up. If either is powered down without this call, it fails on subsequent power cycles. To get it back in check, I found powering down both devices. For the GoPro remove the battery and any charge cable and wait a minute or so, then power on the GoPro, then the ESP and try again. If this fails after a number of attempts, try resetting the GoPro network connections (not this will require re-pairing to the GP app on your phone). Code for this is below. I've included a sample for the M5Atom Lite as well as M5Stick-C Plus, but any ESP32 with a few buttons wired up will do. In this case, a single click takes a shot, while holding it > 2 seconds calls gp.end() etc. A bit of a pain but it works. Ideally adding some sort supercap and watching the power pin to detect power disconnect which could feed into a software call go gp.end(). Good news is the M5Stick-C Plus has a built-in battery, so I suppose some code to detect battery drain over time and a graceful power down will do... Although I'm not certain, I think the GoPro is failing with some feature where it hasn't let go of a setting or mode. I'm thinking something related to the UDP client and maybe flushing things. It seems that a full power down with battery removal clears it for the time being... About the below code samples: These are both WIP and not in end-state. Right now they simply trigger a photo based on a button click. My end goal is for this to serve as a timelapse photo trigger for my resin printer. It will use a LDR sensor and trigger a photo when UV Light comes on. I already have this working with an ESP32Cam (www.plastibots.com), but wanted to get better resolution out of the GoPro. M5 Atom Lite Sample:
m5 Stick-C Plus Sample (note it's crude and still needs some work):
|
Hi. First off, thank you for the great effort put into creating this library! Have a challenge with failed connections after the first attempt. I can only get the ESP to trigger picture captures after resetting the GoPro WiFi connection and rebooting it. The first time in, I can connect and take photos. After this, it fails. Regardless of power cycling the ESP or the GoPro Below is the code I am using, and further down is the Serial output:
Attempting to connect to SSID: "GP50039006"
Using password: "kS9-mMx-Rvx"
.......................................................
Connected to GoPro
Attempting a shot.
Connection lost
Attempting a shot.
Connect the camera first
Attempting a shot.
Connect the camera first
Attempting a shot.
Connect the camera first..
The text was updated successfully, but these errors were encountered: