mirror of
https://github.com/Keychron/qmk_firmware.git
synced 2025-01-01 06:18:52 +06:00
Merge remote-tracking branch 'origin/master' into develop
This commit is contained in:
commit
bfc8539d68
@ -15,11 +15,13 @@ You should have received a copy of the GNU General Public License
|
||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#define POINTING_DEVICE_ROTATION_90
|
||||
|
||||
//comment that out if your trackball is on the left side
|
||||
#define TRACKBALL_RIGHT
|
||||
|
||||
#ifdef TRACKBALL_RIGHT
|
||||
#define PIMORONI_TRACKBALL_INVERT_X
|
||||
#define PIMORONI_TRACKBALL_INVERT_Y
|
||||
#ifdef TRACKBALL_RIGHT
|
||||
#define POINTING_DEVICE_INVERT_X
|
||||
#define POINTING_DEVICE_INVERT_Y
|
||||
#endif
|
||||
|
||||
|
@ -16,8 +16,6 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include QMK_KEYBOARD_H
|
||||
#include "drivers/sensors/pimoroni_trackball.h"
|
||||
#include "pointing_device.h"
|
||||
|
||||
|
||||
enum layer_number {
|
||||
@ -29,13 +27,13 @@ enum layer_number {
|
||||
};
|
||||
|
||||
enum custom_keycodes {
|
||||
BALL_HUI,//cycles hue
|
||||
BALL_WHT,//cycles white
|
||||
BALL_DEC,//decreased color
|
||||
BALL_SCR,//scrolls
|
||||
BALL_NCL,//left click
|
||||
BALL_RCL,//right click
|
||||
BALL_MCL,//middle click
|
||||
BALL_HUI = SAFE_RANGE, //cycles hue
|
||||
BALL_WHT, //cycles white
|
||||
BALL_DEC, //decreased color
|
||||
BALL_SCR, //scrolls
|
||||
BALL_NCL, //left click
|
||||
BALL_RCL, //right click
|
||||
BALL_MCL, //middle click
|
||||
};
|
||||
|
||||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||
@ -78,8 +76,6 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||
|
||||
|
||||
#ifdef OLED_ENABLE
|
||||
|
||||
|
||||
oled_rotation_t oled_init_user(oled_rotation_t rotation) {
|
||||
|
||||
if (is_keyboard_master()) {
|
||||
@ -209,13 +205,23 @@ bool oled_task_user(void) {
|
||||
return false;
|
||||
}
|
||||
|
||||
#endif
|
||||
#endif //OLED_ENABLE
|
||||
|
||||
uint8_t white = 0;
|
||||
uint8_t red = 255;
|
||||
uint8_t green = 0;
|
||||
uint8_t blue = 0;
|
||||
|
||||
bool set_scrolling = false;
|
||||
report_mouse_t pointing_device_task_user(report_mouse_t mouse_report) {
|
||||
if (set_scrolling) {
|
||||
mouse_report.h = mouse_report.x;
|
||||
mouse_report.v = mouse_report.y;
|
||||
mouse_report.x = mouse_report.y = 0;
|
||||
}
|
||||
return mouse_report;
|
||||
}
|
||||
|
||||
void ball_increase_hue(void){
|
||||
if(red!=255&&green!=255&&blue!=255){
|
||||
red =255;
|
||||
@ -233,7 +239,7 @@ void ball_increase_hue(void){
|
||||
} else if(green ==0&&blue>0&&red==255){
|
||||
blue -=15;
|
||||
}
|
||||
trackball_set_rgbw(red,green,blue,white);
|
||||
pimoroni_trackball_set_rgbw(red,green,blue,white);
|
||||
}
|
||||
|
||||
void decrease_color(void){
|
||||
@ -246,7 +252,7 @@ void decrease_color(void){
|
||||
if (blue>0){
|
||||
blue-=15;
|
||||
}
|
||||
trackball_set_rgbw(red,green,blue,white);
|
||||
pimoroni_trackball_set_rgbw(red,green,blue,white);
|
||||
}
|
||||
|
||||
void cycle_white(void){
|
||||
@ -255,7 +261,7 @@ void cycle_white(void){
|
||||
} else{
|
||||
white=0;
|
||||
}
|
||||
trackball_set_rgbw(red,green,blue,white);
|
||||
pimoroni_trackball_set_rgbw(red,green,blue,white);
|
||||
}
|
||||
|
||||
bool process_record_user(uint16_t keycode, keyrecord_t *record){
|
||||
@ -280,9 +286,9 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record){
|
||||
|
||||
case BALL_SCR:
|
||||
if(record->event.pressed){
|
||||
trackball_set_scrolling(true);
|
||||
set_scrolling = true;
|
||||
} else{
|
||||
trackball_set_scrolling(false);
|
||||
set_scrolling = false;
|
||||
}
|
||||
break;
|
||||
|
||||
@ -298,6 +304,7 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record){
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
#ifdef ENCODER_ENABLE
|
||||
bool encoder_update_user(uint8_t index, bool clockwise) {
|
||||
if (index == 0) {
|
||||
@ -325,4 +332,4 @@ bool encoder_update_user(uint8_t index, bool clockwise) {
|
||||
// the missing ones are encoder 1 on the right side and encoder 3 on the left side
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
#endif // ENCODER_ENABLE
|
||||
|
@ -1,7 +1,6 @@
|
||||
# only uncomment on the side you have your trackball on
|
||||
POINTING_DEVICE_ENABLE = yes
|
||||
SRC += drivers/sensors/pimoroni_trackball.c
|
||||
QUANTUM_LIB_SRC += i2c_master.c
|
||||
POINTING_DEVICE_DRIVER = pimoroni_trackball
|
||||
OLED_ENABLE = yes
|
||||
OLED_DRIVER = SSD1306
|
||||
MOUSEKEY_ENABLE = no
|
||||
MOUSEKEY_ENABLE = yes
|
||||
|
Loading…
Reference in New Issue
Block a user