An asyncio-focused library for webrtc robot control
Project description
RTCBot
RTCBot's purpose is to provide a set of simple modules that help in developing remote-controlled robots in Python, with a focus on the Raspberry Pi.
The documentation includes tutorials that guide in developing your robot, starting from a basic connection between a Raspberry Pi and Browser, and encompass creating a video-streaming robot controlled entirely over a 4G mobile connection, all the way to a powerful system that offloads complex computation to a desktop PC in real-time.
All communication happens through WebRTC, using Python 3's asyncio and the wonderful aiortc library, meaning that your robot can be controlled with low latency both from the browser and through Python, even when it is not connected to your local network.
The library is explained piece by piece in the documentation.
See Documentation & Tutorials
Installing
pip install rtcbot
Example
This example uses RTCBot to live stream a webcam to the browser. For details, please look at the tutorials.
Python code that streams video to the browser:
from aiohttp import web
routes = web.RouteTableDef()
from rtcbot import RTCConnection, getRTCBotJS, CVCamera
camera = CVCamera()
# For this example, we use just one global connection
conn = RTCConnection()
conn.video.putSubscription(camera)
# Serve the RTCBot javascript library at /rtcbot.js
@routes.get("/rtcbot.js")
async def rtcbotjs(request):
return web.Response(content_type="application/javascript", text=getRTCBotJS())
# This sets up the connection
@routes.post("/connect")
async def connect(request):
clientOffer = await request.json()
serverResponse = await conn.getLocalDescription(clientOffer)
return web.json_response(serverResponse)
@routes.get("/")
async def index(request):
with open("index.html", "r") as f:
return web.Response(content_type="text/html", text=f.read())
async def cleanup(app):
await conn.close()
camera.close()
app = web.Application()
app.add_routes(routes)
app.on_shutdown.append(cleanup)
web.run_app(app)
Browser code (index.html) that displays the video stream:
<html>
<head>
<title>RTCBot: Video</title>
<script src="/rtcbot.js"></script>
</head>
<body style="text-align: center;padding-top: 30px;">
<video autoplay playsinline></video> <audio autoplay></audio>
<p>
Open the browser's developer tools to see console messages (CTRL+SHIFT+C)
</p>
<script>
var conn = new rtcbot.RTCConnection();
conn.video.subscribe(function(stream) {
document.querySelector("video").srcObject = stream;
});
async function connect() {
let offer = await conn.getLocalDescription();
// POST the information to /connect
let response = await fetch("/connect", {
method: "POST",
cache: "no-cache",
body: JSON.stringify(offer)
});
await conn.setRemoteDescription(await response.json());
console.log("Ready!");
}
connect();
</script>
</body>
</html>
Development
To use rtcbot
code directly, clone the repository, and install the requirements:
pip install -r requirements.txt
Then, you will need to perform the javascript build step, to prepare the browser code. This step requires both make
and npm
to be installed on your machine. To build the javascript, type in:
make js
This creates rtcbot/rtcbot.js
, which is returned by rtcbot.getRTCBotJS()
.
After these two steps, you should be able to successfully import and use the library.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file rtcbot-0.0.8.tar.gz
.
File metadata
- Download URL: rtcbot-0.0.8.tar.gz
- Upload date:
- Size: 33.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bc564294f6c1b2fc0e89de100705de2ebb1b7eb23c194a6f24a1e40f3cffdd14 |
|
MD5 | 8caa5d0f4299c50c1544d6779d843efd |
|
BLAKE2b-256 | 82b0a8bc86c5a05e5133afdec3f4c37100e43f44b133fc1bd2f2f98d43427a73 |
File details
Details for the file rtcbot-0.0.8-py3-none-any.whl
.
File metadata
- Download URL: rtcbot-0.0.8-py3-none-any.whl
- Upload date:
- Size: 41.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7a95bd6684426e6e6569c7fb663537068db38d19bfd122e7e665c6a2e2ec8e52 |
|
MD5 | 6518d527fbc9422e7a5de569abb23e35 |
|
BLAKE2b-256 | 776ee1cb9e34b8d8b3daa57714dc3bc1e9b9f7a0cf7d13605e7aef9c28a42557 |