/clouduboy

In-browser game editor for the web & microcontrollers

Primary LanguageJavaScriptMIT LicenseMIT

Clouduboy

Clouduboy Intro

Clouduboy is a connected Arduino cloud editor & MMDACCI. Nope, that's not latin for the release date - it means Massively Multi-Device Arduboy Cloud-Compiler & IDE. Whoah, that's quite a mouthful! But it really means that "connected" part, though! See, there are a lot of IDE-s and Code Editors and cloud-based Arduino-workbenches out there.
Clouduboy specifically focuses on making Arduino hacking truly fun, working with the device/browser of your choice and even if you only have very basic coding skills.

Using the service

Just open up your favorite web browser, and go to http://clouduboy.slsw.hu/ !

It should definitely work in Firefox & Chrome, but all other pretty recent browsers should be supported as we chip away on some of the nasty bugs in cross-browser land. On mobiles and tablets, Chrome & Firefox for Android should definitely work, and Safari support is coming along nicely.
Cross-browser support is a tough nut to crack, but feel free to jump in, any help is greatly appreciated!

Sessions

The first time you open up the site, you will be greeted with the startup screen. You can start a new session here, or type your magic wordkey to join an existing session. Yes, you heard that right, sessions are operated via magical word-triplet-wizardry! โœจ
QR codes are cumbersome, and NFC is not very prevalent on the web, so that leaves word codes - but hey, it is also much more fun to type "Wondrous Unicorn Fluff" than some random garblewords. I dare you to try! ๐Ÿ˜‰

(Also, I have my imaginary battery of horses with me, and they, too agree that my assumption of magical word-triplets being the staple of the product is indeed correct...)

The Flasher

You can also download the pre-packaged Flasher on the start page. The Flasher is a cross-platform Electron app to flash your games & creations, also written in JavaScript. Once started, like a mystical genie, the Flasher sits idly in your taskbar/tray (in the form of an Arduboy-icon), waiting for your commands.
The app connects to the Clouduboy server and lets you flash your games onto the Arduboy with a single click on the "lightning" icon in the Clouduboy menubar. It's that simple!

Upon startup, or if you initiate a new session you will also need to provide your magical word-triplet to the Flasher so it can establish a connection to your session.

Service Notes

Note, that this is'nt some big commercial app, floating on millions of dollars of VC-funding.โ€ป This implies that bugs are only fixed once someone has a bit of a spare time to hack on them. This also implies, that the service runs on a dirt-cheap, tiny DigitalOcean droplet, and since it also has to compile sketches, it will be slow.
Please be kind โ€” and if something breaks, file an issue.

โ€ป although, feel free to send any number of million dollars to here: Support ๐Ÿ˜‹

More on Clouduboy

Clouduboy helps you get the most out of your Arduboy, or Hackduboy by providing an easily accessible & cross-platform IDE (development environment) with clear-cut examples to make & remix your Very Own Arduboy games. Don't worry, even if you never programmed in C before โ€” the Arduboy library is rather straightforward to get you started in no time, building your own games with pretty pixelgraphics, buzzy music & tons of fun!

Not even that, but Clouduboy takes "connectedness" pretty seriously. How so? Well, like I said, games are great - they tingle, buzz, have flashy graphics and stuff. Normally, to make the Arduino's tiny chip understand all that, you have to descend to the depths of binary codes and bits & bytes, all that nasty stuff that chips & computers are really good at. Humans? Well, they... not so much.

Here comes Clouduboy's connectedness to the rescue, and the power of browsers & HTML5! The IDE includes a series of "editor extensions", that make creating and reading all that encoded data a breeze: built-in editor for sprites, even for polyphonic music! And the best thing? You don't have to wrestle your notebook's touchpad to wrangle those pixels: as this is just the "web", all that stuff is running in a browser! You could whip up your favorite phone or tablet, open Clouduboy in a browser, say your magic words, et voilรก, you can now use your fingers to draw and edit your sprites! Much easier, right?
The same goes for music: just grab your tablet, tap on an audio node, and play something nice! If you can play the piano, even better โ€” with a proper tablet you get multitouch-polyphony and real multi-channel creation, while Clouduboy does the heavy-lifting for you and records & converts your on-the-spot symphony into bits and blobs. ๐Ÿ˜‰

Clouduboy is also pretty much a living testament to JavaScript taking over the world - there aren't very many parts of it requiring any more than the knowledge of JavaScript & HTML5 (and even for those pesky parts, I have a few ideas mwahahaaa!).

The app is pure, browser-based JS & HTML5, the flasher itself is nothing more than a node.js/electron app using node-serialport (but maybe we won't even need that for long, if WebUSB/WebSerial takes over soon). All-in-all, if you are a JavaScript hacker, Clouduboy lets you dive a bit deeper into the soul of the system via Arduino, and lets you polish your webby skills as well, if you decided to contribute.

You will still need an internet connection (albeit, a not very swift one will do), and a computer if you want to flash sketches, but even those are requirements, that are (hopefully) going away (soon)... ๐Ÿ˜

Compatible devices

Clouduboy is compatible with the Arduboy DevKit, production Arduboys, and any "Hackduboy"-s you build, as an Arduboy is really just an ATmega32U4 (which is essentially an Arduino Leonardo/Micro), hooked up to some buttons, a screen and a piezo buzzer.

Hosting your own Clouduboy

How to make this even more awesome?

Clouduboy is still young, and, well, pretty much a hack. I have a lot in terms of ways it can be improved, and I bet you do, too. Here are some the things on my TODO-list, from the top of my head to get you started:

  • Real-time collaborative editing
  • Arduboy.js sketch runner/emulator
  • HTML5-to-Arduboy cross-compilation
  • Extend support for all 32u4-based Arduinos
  • ...and later to different Arduinos as well
  • Offline support (service workers)
  • Real offline support (JavaScript sketch compiler)
  • Host-your-own-Clouduboy-Tesselization (host this on a Tessel 2)
  • $5 true disconnectedness (Raspberry Pi Zero host+flasher)

That's a lot of ideas (and work) in there, right? So feel free to help out! Jump into the issues and happy hacking!

Open Source at โ™ฅ

Without all these awesome free/open source projects & the lovely people putting countless hours of work and love into making & maintaining them , Clouduboy wouldn't be where it is (heck, I'd say it wouldn't even be...).

I thank, from the bottom of my heart to all these lovely open-sourcerers โ€” and y'all should, too! ๐Ÿ’–

Contributing:

  • You are helping even if you just file the issues
  • Also, feel free to help fixing them โ€” have a look at the issues
  • You can support development & hosting
  • Please, be nice to maintainers, contributors, each other.
  • For details, check CONTRIBUTING.md.

License

  • Clouduboy is free software licensed under MIT license - see LICENSE.md for details.