# USense
## Overview
Well, this project is a little, quick, and fun one. Basically, the idea was to see what could be done with some RGB leds and capacitive touch inputs.
## Pictures It's all version 1, I unfortunately don't have any picture of the version 2 (but it was better!)
## PCB
Always print the PCB at 600DPI. The text acts as a fool-proof system. It should be readable on your final board. B ### Version 0 Before designing a board, I wanted to try the “capacitive input” stuff, so I designed this quick PCB
### Version 1
First version, used mostly for the firmware development and debug. The actual board is quite messy now, but still works. In this version, I thought I would put four leds on the board, but one was already enough…
### Version 2
I think this is the “Release” version.
## Firmware
### Bootloader
I worked hard to have a USB bootloader to be able to distribute the board, so Micronucleus fires up for 2-3 seconds at power-up. Here's the link: micronucleus-t84.tar.gz
### Test firmware
Since I don't have too much spare time, I only wrote a quick firmware to test the board and be able to give the v2 to a friend.
* The RGB led pulses/fades from one color to another automatically * One capacitive input increases the fading speed * The other decreases the speed * The two combined change the color changing cycle
The archive can be downloaded here: usense_20140907.tar.gz
### Test firmware - Protocol This can be found in include/usense_protocol.h
Messages are 8 bytes long (since it is the limit for wMaxPacketSize for low-speed USB devices)
[ Mode ] [ Val0 ] [ Val1 ] [ Val2 ] [ Val3 ] [ Val4 ] [ Val5 ] [ Val6 ]
* PC > USense *********************************************************
[ 0x01 ] Fade On
[ 0xRR ] Maximum brightness Red
[ 0xGG ] Maximum brightness Green
[ 0xBB ] Maximum brightness Blue
[ 0x02 ] Fade Off
[ 0x03 ] Get Fade
[ 0x04 ] Set Fade Steps
[ 0xVV ] 0x00-020
[ 0x05 ] Get Fade Steps
[ 0x06 ] Set Fade Delay
[ 0x07 ] Get Fade Delay
[ 0x10 ] Set Fixed color
[ 0xRR ] [ OxGG ] [ 0xBB ]
[ 0x11 ] Get LEDs color
[ 0x12 ] LEDs Off
[ 0x20 ] Get Touch
[ 0x21 ] Enable Touch INT
[ 0x22 ] Disable Touch INT
[ 0x23 ] Get Touch INT
[ 0x24 ] Enable Touch ACT
[ 0x25 ] Disable Touch ACT
[ 0x26 ] Get Touch ACT
[ 0x30 ] Get Fade Mode
[ 0x31 ] Set Fade Mode
[ 0x80 ] Reset
* Usense > PC *********************************************************
Usually, it's just an Ack so:
[ 0xRR ] [ 0xAA ]
[ 0xRR ] The request code (see PC > USense)
[ 0xAA ] Ack (0x42) or NAck (0xFF) Value for the previous request
For the "Get" requests, it's an Ack, then the value:
[ 0xRR ] [ 0xAA ] [ 0xV1 ] [ 0xV2 ] ...
[ 0xRR ] The request code (see PC > USense)
[ 0xAA ] Ack (0x42) or NAck (0xFF) Value for the previous request
[ 0xV1 ] ... The returned Value
ex:
Get LEDs color
[ 0x11 ] [ 0x42 ] [ 0xRR ] [ 0xGG ] [ 0xBB ] [ 0xrr ] [ 0xgg ] [ 0xbb ]
in capital letters: Value
in small letters: maximum fvalue for fading stuff
Get Touch
[ 0x23 ] [ 0x42 ] [ 0xVV ] Returns Inputs mask
[ 0xVV ] Touch inputs mask (0b1 means pressed, 0b0 means released)
Special case: for the "INT" messages, the auto-ack is 0x24 instead of 0x42
ex: Touch INT
[ 0x23 ] [ 0x24 ] [ 0xVV ] Touch INT message
[ 0xVV ] See above
### Firmware ideas
When I made the board, I was convinced you could do something actually useful with it… Here are a few ideas:
* Input device with visual feedback (both RGB and Status led), like a morse Keyer or something
* Music/Media control
* Notification LED you can actually dismiss by hardware (for emails, Skype, IRC, …)
* Mood lamp, zen/ambiant visualization for a small room
* Write an HTTP API and make it available from the Internet, so other people can visually _communicate_ with you
* Sound-reactive visualization
* … Up to you





