You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

147 lines
9.6 KiB

  1. # Haptic Feedback
  2. ## Haptic feedback rules.mk options
  3. The following options are currently available for haptic feedback in `rule.mk`:
  4. `HAPTIC_ENABLE += DRV2605L`
  5. `HAPTIC_ENABLE += SOLENOID`
  6. ## Known Supported Hardware
  7. | Name | Description |
  8. |--------------------|-------------------------------------------------|
  9. | [LV061228B-L65-A](https://www.digikey.com/product-detail/en/jinlong-machinery-electronics-inc/LV061228B-L65-A/1670-1050-ND/7732325) | z-axis 2v LRA |
  10. | [Mini Motor Disc](https://www.adafruit.com/product/1201) | small 2-5v ERM |
  11. ## Haptic Keycodes
  12. Not all keycodes below will work depending on which haptic mechanism you have chosen.
  13. | Name | Description |
  14. |-----------|-------------------------------------------------------|
  15. |`HPT_ON` | Turn haptic feedback on |
  16. |`HPT_OFF` | Turn haptic feedback on |
  17. |`HPT_TOG` | Toggle haptic feedback on/off |
  18. |`HPT_RST` | Reset haptic feedback config to default |
  19. |`HPT_FBK` | Toggle feedback to occur on keypress, release or both |
  20. |`HPT_BUZ` | Toggle solenoid buzz on/off |
  21. |`HPT_MODI` | Go to next DRV2605L waveform |
  22. |`HPT_MODD` | Go to previous DRV2605L waveform |
  23. |`HPT_DWLI` | Increase Solenoid dwell time |
  24. |`HPT_DWLD` | Decrease Solenoid dwell time |
  25. ### Solenoids
  26. First you will need a build a circuit to drive the solenoid through a mosfet as most MCU will not be able to provide the current needed to drive the coil in the solenoid.
  27. [Wiring diagram provided by Adafruit](https://playground.arduino.cc/uploads/Learning/solenoid_driver.pdf)
  28. Select a pin that has PWM for the signal pin
  29. ```
  30. #define SOLENOID_PIN *pin*
  31. ```
  32. Beware that some pins may be powered during bootloader (ie. A13 on the STM32F303 chip) and will result in the solenoid kept in the on state through the whole flashing process. This may overheat and damage the solenoid. If you find that the pin the solenoid is connected to is triggering the solenoid during bootloader/DFU, select another pin.
  33. ### DRV2605L
  34. DRV2605L is controlled over i2c protocol, and has to be connected to the SDA and SCL pins, these varies depending on the MCU in use.
  35. #### Feedback motor setup
  36. This driver supports 2 different feedback motors. Set the following in your `config.h` based on which motor you have selected.
  37. ##### ERM
  38. Eccentric Rotating Mass vibration motors (ERM) is motor with a off-set weight attached so when drive signal is attached, the off-set weight spins and causes a sinusoidal wave that translate into vibrations.
  39. ```
  40. #define FB_ERM_LRA 0
  41. #define FB_BRAKEFACTOR 3 /* For 1x:0, 2x:1, 3x:2, 4x:3, 6x:4, 8x:5, 16x:6, Disable Braking:7 */
  42. #define FB_LOOPGAIN 1 /* For Low:0, Medium:1, High:2, Very High:3 */
  43. /* Please refer to your datasheet for the optimal setting for your specific motor. */
  44. #define RATED_VOLTAGE 3
  45. #define V_PEAK 5
  46. ```
  47. ##### LRA
  48. Linear resonant actuators (LRA, also know as a linear vibrator) works different from a ERM. A LRA has a weight and magnet suspended by springs and a voice coil. When the drive signal is applied, the weight would be vibrate on a single axis (side to side or up and down). Since the weight is attached to a spring, there is a resonance effect at a specific frequency. This frequency is where the LRA will operate the most efficiently. Refer to the motor's datasheet for the recommanded range for this frequency.
  49. ```
  50. #define FB_ERM_LRA 1
  51. #define FB_BRAKEFACTOR 3 /* For 1x:0, 2x:1, 3x:2, 4x:3, 6x:4, 8x:5, 16x:6, Disable Braking:7 */
  52. #define FB_LOOPGAIN 1 /* For Low:0, Medium:1, High:2, Very High:3 */
  53. /* Please refer to your datasheet for the optimal setting for your specific motor. */
  54. #define RATED_VOLTAGE 2
  55. #define V_PEAK 2.8
  56. #define V_RMS 2.0
  57. #define V_PEAK 2.1
  58. #define F_LRA 205 /* resonance freq */
  59. ```
  60. #### DRV2605L waveform library
  61. DRV2605L comes with preloaded library of various waveform sequences that can be called and played. If writing a macro, these waveforms can be played using `DRV_pulse(*sequence name or number*)`
  62. List of waveform sequences from the datasheet:
  63. |seq# | Sequence name |seq# | Sequence name |seq# |Sequence name |
  64. |-----|---------------------|-----|-----------------------------------|-----|--------------------------------------|
  65. | 1 | strong_click | 43 | lg_dblclick_med_60 | 85 | transition_rampup_med_smooth2 |
  66. | 2 | strong_click_60 | 44 | lg_dblsharp_tick | 86 | transition_rampup_short_smooth1 |
  67. | 3 | strong_click_30 | 45 | lg_dblsharp_tick_80 | 87 | transition_rampup_short_smooth2 |
  68. | 4 | sharp_click | 46 | lg_dblsharp_tick_60 | 88 | transition_rampup_long_sharp1 |
  69. | 5 | sharp_click_60 | 47 | buzz | 89 | transition_rampup_long_sharp2 |
  70. | 6 | sharp_click_30 | 48 | buzz_80 | 90 | transition_rampup_med_sharp1 |
  71. | 7 | soft_bump | 49 | buzz_60 | 91 | transition_rampup_med_sharp2 |
  72. | 8 | soft_bump_60 | 50 | buzz_40 | 92 | transition_rampup_short_sharp1 |
  73. | 9 | soft_bump_30 | 51 | buzz_20 | 93 | transition_rampup_short_sharp2 |
  74. | 10 | dbl_click | 52 | pulsing_strong | 94 | transition_rampdown_long_smooth1_50 |
  75. | 11 | dbl_click_60 | 53 | pulsing_strong_80 | 95 | transition_rampdown_long_smooth2_50 |
  76. | 12 | trp_click | 54 | pulsing_medium | 96 | transition_rampdown_med_smooth1_50 |
  77. | 13 | soft_fuzz | 55 | pulsing_medium_80 | 97 | transition_rampdown_med_smooth2_50 |
  78. | 14 | strong_buzz | 56 | pulsing_sharp | 98 | transition_rampdown_short_smooth1_50 |
  79. | 15 | alert_750ms | 57 | pulsing_sharp_80 | 99 | transition_rampdown_short_smooth2_50 |
  80. | 16 | alert_1000ms | 58 | transition_click | 100 | transition_rampdown_long_sharp1_50 |
  81. | 17 | strong_click1 | 59 | transition_click_80 | 101 | transition_rampdown_long_sharp2_50 |
  82. | 18 | strong_click2_80 | 60 | transition_click_60 | 102 | transition_rampdown_med_sharp1_50 |
  83. | 19 | strong_click3_60 | 61 | transition_click_40 | 103 | transition_rampdown_med_sharp2_50 |
  84. | 20 | strong_click4_30 | 62 | transition_click_20 | 104 | transition_rampdown_short_sharp1_50 |
  85. | 21 | medium_click1 | 63 | transition_click_10 | 105 | transition_rampdown_short_sharp2_50 |
  86. | 22 | medium_click2_80 | 64 | transition_hum | 106 | transition_rampup_long_smooth1_50 |
  87. | 23 | medium_click3_60 | 65 | transition_hum_80 | 107 | transition_rampup_long_smooth2_50 |
  88. | 24 | sharp_tick1 | 66 | transition_hum_60 | 108 | transition_rampup_med_smooth1_50 |
  89. | 25 | sharp_tick2_80 | 67 | transition_hum_40 | 109 | transition_rampup_med_smooth2_50 |
  90. | 26 | sharp_tick3_60 | 68 | transition_hum_20 | 110 | transition_rampup_short_smooth1_50 |
  91. | 27 | sh_dblclick_str | 69 | transition_hum_10 | 111 | transition_rampup_short_smooth2_50 |
  92. | 28 | sh_dblclick_str_80 | 70 | transition_rampdown_long_smooth1 | 112 | transition_rampup_long_sharp1_50 |
  93. | 29 | sh_dblclick_str_60 | 71 | transition_rampdown_long_smooth2 | 113 | transition_rampup_long_sharp2_50 |
  94. | 30 | sh_dblclick_str_30 | 72 | transition_rampdown_med_smooth1 | 114 | transition_rampup_med_sharp1_50 |
  95. | 31 | sh_dblclick_med | 73 | transition_rampdown_med_smooth2 | 115 | transition_rampup_med_sharp2_50 |
  96. | 32 | sh_dblclick_med_80 | 74 | transition_rampdown_short_smooth1 | 116 | transition_rampup_short_sharp1_50 |
  97. | 33 | sh_dblclick_med_60 | 75 | transition_rampdown_short_smooth2 | 117 | transition_rampup_short_sharp2_50 |
  98. | 34 | sh_dblsharp_tick | 76 | transition_rampdown_long_sharp1 | 118 | long_buzz_for_programmatic_stopping |
  99. | 35 | sh_dblsharp_tick_80 | 77 | transition_rampdown_long_sharp2 | 119 | smooth_hum1_50 |
  100. | 36 | sh_dblsharp_tick_60 | 78 | transition_rampdown_med_sharp1 | 120 | smooth_hum2_40 |
  101. | 37 | lg_dblclick_str | 79 | transition_rampdown_med_sharp2 | 121 | smooth_hum3_30 |
  102. | 38 | lg_dblclick_str_80 | 80 | transition_rampdown_short_sharp1 | 122 | smooth_hum4_20 |
  103. | 39 | lg_dblclick_str_60 | 81 | transition_rampdown_short_sharp2 | 123 | smooth_hum5_10 |
  104. | 40 | lg_dblclick_str_30 | 82 | transition_rampup_long_smooth1 | | |
  105. | 41 | lg_dblclick_med | 83 | transition_rampup_long_smooth2 | | |
  106. | 42 | lg_dblclick_med_80 | 84 | transition_rampup_med_smooth1 | | |
  107. ### Optional DRV2605L defines
  108. ```
  109. #define DRV_GREETING *sequence name or number*
  110. ```
  111. If haptic feedback is enabled, the keyboard will vibrate to a specific sqeuence during startup. That can be selected using the following define:
  112. ```
  113. #define DRV_MODE_DEFAULT *sequence name or number*
  114. ```
  115. This will set what sequence HPT_RST will set as the active mode. If not defined, mode will be set to 1 when HPT_RST is pressed.