Difference between revisions of "Raspberry PI"
m |
m |
||
Line 31: | Line 31: | ||
/gradlew -Dorg.gradle.java.home=/path/to/jdk-11/ demonstrations | /gradlew -Dorg.gradle.java.home=/path/to/jdk-11/ demonstrations | ||
</nowiki> | </nowiki> | ||
# Why don't webcams work? | |||
BoofCV uses Webcam Capture and in it's default configuration it doesn't work on Raspberry PI. The good news is that there is a simple fix that needs to be added to your source code to get it to run on Raspberry PI! https://github.com/sarxos/webcam-capture/wiki/How-To-Configure-Raspberry-Pi | |||
It should also be pointed out that you don't have to use any of built in tools. You just need a way to convert the image into format that BoofCV understands. Once you got the bytes for an image that is often "simple" if you understad image formats. | |||
# How do I use the Raspberry PI Camera? | # How do I use the Raspberry PI Camera? | ||
Line 50: | Line 57: | ||
</nowiki> | </nowiki> | ||
/dev/video1 is the device associated with the Raspberry PI camera. | /dev/video1 is the device associated with the Raspberry PI camera. | ||
Revision as of 12:05, 26 April 2020
- Replacing Default Java
The default Java installation on Raspberry PI is not optimized for running on ARM and runs much, much slower than it should. You will need to download another version and use that.
- Download JDK built for Raspberry PI
- Decompress `tar -xzf jdk.tar.gz`
- Move to a location you like `sudo mv jdk-11 /opt`
- Add it to your path
- Building BoofCV
You can build BoofCV the usual way, just make sure you use Java 11 or newer to do so and install the ARM optimized JDK! On a regular desktop it takes about 1 minute to build, but on a Raspberry PI it can take 10 minutes or so.
To build and install into your local Maven repository:
cd boofcv ./gradlew install
If you are running your Raspberry PI as a Desktop you can run the demonstration apps. Might also want to plug a camera in or setup your Raspberry PI camera as discussed below.
cd boofcv ./gradlew demonstrations java -jar demonstrations/demonstrations.jar
Trouble Shooting:
If the `./gradlew` command fails and complains about Java 11 that means you didn't download Java 11 yet or your path is incorrect. One way to get around that is to force Gradle to use a specific JDK. /gradlew -Dorg.gradle.java.home=/path/to/jdk-11/ demonstrations
- Why don't webcams work?
BoofCV uses Webcam Capture and in it's default configuration it doesn't work on Raspberry PI. The good news is that there is a simple fix that needs to be added to your source code to get it to run on Raspberry PI! https://github.com/sarxos/webcam-capture/wiki/How-To-Configure-Raspberry-Pi
It should also be pointed out that you don't have to use any of built in tools. You just need a way to convert the image into format that BoofCV understands. Once you got the bytes for an image that is often "simple" if you understad image formats.
- How do I use the Raspberry PI Camera?
The easiest way to access the camera is to treat it as a UVC device. This way WebcamCapture will recognize it and all the example code will work. Unfortunately, you have to tell your Raspberry PI to load the UVC driver each time you boot by doing the following (Stack Exchange):
sudo modprobe bcm2835-v4l2
It should now show up in the list of cameras if you type v4l2-ctl --list-devices. This is what I see on my system. I also have a webcam plugged in to USB that's why there are two devices:
mmal service 16.1 (platform:bcm2835-v4l2): /dev/video1 Logitech Webcam C930e (usb-3f980000.usb-1.1.3.1): /dev/video0
/dev/video1 is the device associated with the Raspberry PI camera.