Skip to content

Latest commit

 

History

History
75 lines (54 loc) · 6.29 KB

README.md

File metadata and controls

75 lines (54 loc) · 6.29 KB

!!! Deprecated !!! This library is now part of a collective library containing all my current arduino libraries including new ones. This one will not be updated and will be deleted in some time... Available at: https://github.com/RPBCACUEAIIBH/HexaLib-Arduino

The TouchBar library is an engine designed to take an input, of 3 bits (first 3 bits of a byte such as the output of the Adafruit_MPR121 library, or a port register) and interpret it as a touch bar.

Features:

  • It senses directon whether you slide your finger over 1-2 pads(light touch scenario), or 2-3 pads at once (hard touch scenario) so it has some tolerance.
  • It senses quick tap on all 3 pads, so the same pads can be used as "buttons" except you loose the ability to hold them down(If it's held, it expects you to drag your finger on the bar.), they can only be tapped as buttons.
  • It can operate with a limited range, or roll over infinitely
  • With limited range, you get built in springback, snap, ramp and flip features.
    • If springback is enabled, it resets to default position when you release the touchbar. It will supress snap feature, but works with ramp also enabled.
    • If snap feature is enabled, tapping the pads will snap the position to minimim / default / maximim positions. This also works fine with the ramp feature.
    • When ramp is enabled, you're adjusting a target position, and the actual position will slowly move to the target position. In this case, you also have an adjustment resolution, and a ramp resolution, so you can make coarese adjustment on the touch bar, but the automatic adjustment will have a fine steps at and even speed.
    • Flip feature just flips pads A and C (Reverses scroll direction, and swaps Top and Bottom snap pads as well, just like you would orient it upside down.)
  • Settings requre 12 bytes of EEPROM.
  • It has twitch suppression which is a form of advanced parallel debouncing that suppresses fast oscillation of a pad, but immediately passes trough change on any other pad then the last one. (This is done to prevent false tap reading and thus snapping when barely touching the edge of a pad, such as placing/removing your finger from the touchbar, or swiping very lightly. False taps ware fairly common without this feature. Simple debouncing as it is commonly done for buttons would limit swipe speed...)

Update v2.1.0:

  • Added support for ESP8266 micros, with it's own pins, and with MPR121 touch module.

Update v2.0.0:

  • Mostly rewrote it for more flexibility extracting the settings to 2 new classes, which can be used by more then one TouchBar objects, thus saving memory, and making mode changes really simple. (Because of this it's no longger compatible with sketches written using previous versions, which is why I made it v2.0. My appoligies if this breaks your program, you can roll back to previous version using git tag.)
  • Kept the option to save settings/loading to/from EEPROM functionality, but I put it in 2 functions outside the classes. (It's totally optional now in case you want to do it your own way. Without this option it compiles to a bit smaller size and loading settings is also far faster. Credits to excsniper for the recommendation.)
  • Added documentation

Update v1.1.0:

  • Optimized it for use with my new TouchLib library. (Highly recommend it cause it's more compact, more responsive, and more stable. :D Example sketch included demoing the new features as well.)
  • Added SetTarget() and Restore() methods.

Hardware requirements:

  • Arduino running at 16MHz (Any type should do. 16MHz is important cause delays are based on cycles of execution not ms / us, 8MHz will work but require different settings. Mine is pro-mini 5V, 16MHz version.) or ESP8266 running at 80MHz
  • 3.3V regulator if your arduino doesn't have 3.3V power on it, and level shifter. (Ignore this if your arduino or ESP8266 has 3.3V onboard.)
  • MPR 121 touch module hooked up to i2c via the level shifter. (Ignore this for ESP8266 they also run at 3.3V.)
  • Touch bar hooked up to 0 to 3 touch touch inputs of the MPR121 module according to the provided documentation, A0-A3 pins of arduino or 12,13,14,16 pins of ESP8266.

Software requirements:

  • Arduino IDE
  • ESP8266 software (Only if you're using ESP8266 microcontroller. Available in Tools/Boards/Board Manager)
  • KiCAD
  • ToucLib (Also my library. This turns arduino pins into touch inputs, only requires a 1M pullup, no need for MPR121 module with this.)
  • or Adafruit_MPR121 library (or similar... not included, you need to install it separately!)
  • Wire library (required by Adafruit_MPR121, Should be included with your IDE)
  • TouchBar library (This one...)
  • EEPROM library (Required by TouchBar, Should be included with your IDE) (- Optionally you may also find my Delinearizer library useful for converting the linear output of the touch bar into logarithmic, inverse logarithmic, or S-curve output to mimic a potmeter. (eg. for use with audio equipment, dimming, or controlling motor speed.)

Skill requirements:

  • You need to have basic arduino skills. (Understanding how to interface 5V and 3.3V modules, hooking up and testing an i2c device with level shifter, soldering, understanding arduino code, installing and using libraries, etc. This is a library of source code and CAD files with an example sketch not a tutorial, so I won't explain everything here.)
  • You either need to make a PCB or order one! (The touch bar itself is basically a footprint you have to print on a PCB, it's a custom design, you can't really buy it.)

Instructions:

  1. Add library to your arduino IDE
  • Open terminal in your Arduino/libraries directory, and run "git clone https://github.com/RPBCACUEAIIBH/TouchBar" and restart the IDE.
  • Download as .zip package, go to the Sketch/Include Library/Add .ZIP Library... in you Arduino IDE, select it, and click ok.
  1. Open the included example sketch to see how to use it.
  2. It includes a KiCAD library I made with few symbols and several footprints so you can make a proper touch bar on PCB.

Note: The vias on the touch bar footprints are relatively large so that you can put LEDs beneath, and display it's position. Position display is not implemented yet and it's probably gonna be another library...

If you find this useful, please consider donationg.