diff options
| -rw-r--r-- | keyboards/boston_meetup/2019/2019.c | 217 | ||||
| -rw-r--r-- | keyboards/boston_meetup/2019/2019.h | 19 | ||||
| -rw-r--r-- | keyboards/boston_meetup/2019/config.h | 196 | ||||
| -rw-r--r-- | keyboards/boston_meetup/2019/info.json | 12 | ||||
| -rw-r--r-- | keyboards/boston_meetup/2019/keymaps/default/keymap.c | 166 | ||||
| -rw-r--r-- | keyboards/boston_meetup/2019/keymaps/default/readme.md | 51 | ||||
| -rw-r--r-- | keyboards/boston_meetup/2019/keymaps/readme.md | 22 | ||||
| -rw-r--r-- | keyboards/boston_meetup/2019/readme.md | 13 | ||||
| -rw-r--r-- | keyboards/boston_meetup/2019/rules.mk | 24 | ||||
| -rw-r--r-- | keyboards/boston_meetup/boston_meetup.c | 2 | ||||
| -rw-r--r-- | keyboards/boston_meetup/boston_meetup.h | 19 | ||||
| -rw-r--r-- | keyboards/boston_meetup/config.h | 60 | ||||
| -rw-r--r-- | keyboards/boston_meetup/readme.md | 14 | ||||
| -rw-r--r-- | keyboards/boston_meetup/rules.mk | 2 | 
14 files changed, 817 insertions, 0 deletions
| diff --git a/keyboards/boston_meetup/2019/2019.c b/keyboards/boston_meetup/2019/2019.c new file mode 100644 index 000000000..9baed223b --- /dev/null +++ b/keyboards/boston_meetup/2019/2019.c @@ -0,0 +1,217 @@ +/* Copyright 2019 ishtob + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program.  If not, see <http://www.gnu.org/licenses/>. + */ +#include "2019.h" +#include "qwiic.h" +#include "action_layer.h" +#include "haptic.h" + +#ifdef RGB_MATRIX_ENABLE +#include "rgblight.h" + +const rgb_led g_rgb_leds[DRIVER_LED_TOTAL] = { +  /*{row | col << 4} +    |             {x=0..224, y=0..64} +    |              |         modifier +    |              |         | */ +  {{1|(3<<4)},    {188, 16}, 0}, +  {{3|(3<<4)},    {187, 48}, 0}, +  {{4|(2<<4)},    {149, 64}, 0}, +  {{4|(1<<4)},    {112, 64}, 0}, +  {{3|(0<<4)},    {37,  48}, 0}, +  {{1|(0<<4)},    {38, 16}, 0} +}; +#endif + +uint8_t *o_fb; + +uint16_t counterst = 0; + + + +#ifdef QWIIC_MICRO_OLED_ENABLE + +/* screen off after this many milliseconds */ +#include "timer.h" +#define ScreenOffInterval 60000 /* milliseconds */ +static uint16_t last_flush; + +volatile uint8_t led_numlock = false;  +volatile uint8_t  led_capslock = false;  +volatile uint8_t  led_scrolllock = false; + +static uint8_t layer; +static bool queue_for_send = false;  +static uint8_t encoder_value = 32; + +__attribute__ ((weak)) +void draw_ui(void) { +  clear_buffer(); +  last_flush = timer_read(); +  send_command(DISPLAYON); + +/* Boston MK title is 55 x 10 pixels */ +#define NAME_X 0 +#define NAME_Y 0  + +  draw_string(NAME_X + 1, NAME_Y + 2, "BOSTON MK", PIXEL_ON, NORM, 0); + +/* Layer indicator is 41 x 10 pixels */ +#define LAYER_INDICATOR_X 60 +#define LAYER_INDICATOR_Y 0  + +  draw_string(LAYER_INDICATOR_X + 1, LAYER_INDICATOR_Y + 2, "LAYER", PIXEL_ON, NORM, 0); +  draw_rect_filled_soft(LAYER_INDICATOR_X + 32, LAYER_INDICATOR_Y + 1, 9, 9, PIXEL_ON, NORM); +  draw_char(LAYER_INDICATOR_X + 34, LAYER_INDICATOR_Y + 2, layer + 0x30, PIXEL_ON, XOR, 0); + +/* Matrix display is 12 x 12 pixels */ +#define MATRIX_DISPLAY_X 8 +#define MATRIX_DISPLAY_Y 16 + +  for (uint8_t x = 0; x < MATRIX_ROWS; x++) { +    for (uint8_t y = 0; y < MATRIX_COLS; y++) { +      draw_pixel(MATRIX_DISPLAY_X + y + y + 2, MATRIX_DISPLAY_Y + x + x + 2,(matrix_get_row(x) & (1 << y)) > 0, NORM); +      draw_pixel(MATRIX_DISPLAY_X + y + y + 3, MATRIX_DISPLAY_Y + x + x + 2,(matrix_get_row(x) & (1 << y)) > 0, NORM); +      draw_pixel(MATRIX_DISPLAY_X + y + y + 2, MATRIX_DISPLAY_Y + x + x + 3,(matrix_get_row(x) & (1 << y)) > 0, NORM); +      draw_pixel(MATRIX_DISPLAY_X + y + y + 3, MATRIX_DISPLAY_Y + x + x + 3,(matrix_get_row(x) & (1 << y)) > 0, NORM); + +    } +  }  +  draw_rect_soft(MATRIX_DISPLAY_X, MATRIX_DISPLAY_Y, 12, 12, PIXEL_ON, NORM); +  /* hadron oled location on thumbnail */ +  draw_rect_filled_soft(MATRIX_DISPLAY_X + 5, MATRIX_DISPLAY_Y + 2, 6, 2, PIXEL_ON, NORM); +/* +  draw_rect_soft(0, 13, 64, 6, PIXEL_ON, NORM); +  draw_line_vert(encoder_value, 13, 6, PIXEL_ON, NORM); + +*/ + +/* Mod display is 41 x 16 pixels */ +#define MOD_DISPLAY_X 60 +#define MOD_DISPLAY_Y 20 + +  uint8_t mods = get_mods(); +  if (mods & MOD_LSFT) { +    draw_rect_filled_soft(MOD_DISPLAY_X + 0, MOD_DISPLAY_Y, 5 + (1 * 6), 11, PIXEL_ON, NORM); +    draw_string(MOD_DISPLAY_X + 3, MOD_DISPLAY_Y + 2, "S", PIXEL_OFF, NORM, 0); +  } else { +    draw_string(MOD_DISPLAY_X + 3, MOD_DISPLAY_Y + 2, "S", PIXEL_ON, NORM, 0); +  } +  if (mods & MOD_LCTL) { +    draw_rect_filled_soft(MOD_DISPLAY_X + 10, MOD_DISPLAY_Y, 5 + (1 * 6), 11, PIXEL_ON, NORM); +    draw_string(MOD_DISPLAY_X + 13, MOD_DISPLAY_Y + 2, "C", PIXEL_OFF, NORM, 0); +  } else { +    draw_string(MOD_DISPLAY_X + 13, MOD_DISPLAY_Y + 2, "C", PIXEL_ON, NORM, 0); +  } +  if (mods & MOD_LALT) { +    draw_rect_filled_soft(MOD_DISPLAY_X + 20, MOD_DISPLAY_Y, 5 + (1 * 6), 11, PIXEL_ON, NORM); +    draw_string(MOD_DISPLAY_X + 23, MOD_DISPLAY_Y + 2, "A", PIXEL_OFF, NORM, 0); +  } else { +    draw_string(MOD_DISPLAY_X + 23, MOD_DISPLAY_Y + 2, "A", PIXEL_ON, NORM, 0); +  } +  if (mods & MOD_LGUI) { +    draw_rect_filled_soft(MOD_DISPLAY_X + 30, MOD_DISPLAY_Y, 5 + (1 * 6), 11, PIXEL_ON, NORM); +    draw_string(MOD_DISPLAY_X + 33, MOD_DISPLAY_Y + 2, "G", PIXEL_OFF, NORM, 0); +  } else { +    draw_string(MOD_DISPLAY_X + 33, MOD_DISPLAY_Y + 2, "G", PIXEL_ON, NORM, 0); +  } + +/* Lock display is 23 x 32 */ +#define LOCK_DISPLAY_X 104 +#define LOCK_DISPLAY_Y 0 + +  if (led_numlock == true) { +    draw_rect_filled_soft(LOCK_DISPLAY_X, LOCK_DISPLAY_Y, 5 + (3 * 6), 9, PIXEL_ON, NORM); +    draw_string(LOCK_DISPLAY_X + 3, LOCK_DISPLAY_Y + 1, "NUM", PIXEL_OFF, NORM, 0); +  } else if (led_numlock == false) { +    draw_string(LOCK_DISPLAY_X + 3, LOCK_DISPLAY_Y + 1, "NUM", PIXEL_ON, NORM, 0); +  } +  if (led_capslock == true) { +    draw_rect_filled_soft(LOCK_DISPLAY_X + 0, LOCK_DISPLAY_Y + 11, 5 + (3 * 6), 9, PIXEL_ON, NORM); +    draw_string(LOCK_DISPLAY_X + 3, LOCK_DISPLAY_Y + 11 +1, "CAP", PIXEL_OFF, NORM, 0); +  } else if (led_capslock == false) { +    draw_string(LOCK_DISPLAY_X + 3, LOCK_DISPLAY_Y + 11 +1, "CAP", PIXEL_ON, NORM, 0); +  } + +  if (led_scrolllock == true) { +    draw_rect_filled_soft(LOCK_DISPLAY_X + 0, LOCK_DISPLAY_Y + 22, 5 + (3 * 6), 9, PIXEL_ON, NORM); +    draw_string(LOCK_DISPLAY_X + 3, LOCK_DISPLAY_Y + 22 +1, "SCR", PIXEL_OFF, NORM, 0); +  } else if (led_scrolllock == false) { +    draw_string(LOCK_DISPLAY_X + 3, LOCK_DISPLAY_Y + 22 +1, "SCR", PIXEL_ON, NORM, 0); +  } +  send_buffer(); +} + +void led_set_user(uint8_t usb_led) { +    if (IS_LED_ON(usb_led, USB_LED_NUM_LOCK)) { +      if (led_numlock == false){led_numlock = true;} +    } else { +      if (led_numlock == true){led_numlock = false;} +    } +    if (IS_LED_ON(usb_led, USB_LED_CAPS_LOCK)) { +      if (led_capslock == false){led_capslock = true;} +    } else { +      if (led_capslock == true){led_capslock = false;} +    } +    if (IS_LED_ON(usb_led, USB_LED_SCROLL_LOCK)) { +      if (led_scrolllock == false){led_scrolllock = true;} +    } else { +      if (led_scrolllock == true){led_scrolllock = false;} +    } +} + +uint32_t layer_state_set_kb(uint32_t state) { +  state = layer_state_set_user(state); +  layer = biton32(state); +  queue_for_send = true; +  return state; +} + +bool process_record_kb(uint16_t keycode, keyrecord_t *record) { +  queue_for_send = true; +  return process_record_user(keycode, record); +} + +void encoder_update_kb(uint8_t index, bool clockwise) { +  encoder_value = (encoder_value + (clockwise ? 1 : -1)) % 64; +  queue_for_send = true; +} + +#endif + +void matrix_init_kb(void) { +  queue_for_send = true; +	matrix_init_user(); +} +             +void matrix_scan_kb(void) { +if (queue_for_send) { +#ifdef QWIIC_MICRO_OLED_ENABLE +   draw_ui(); +#endif +   queue_for_send = false; +  } +#ifdef QWIIC_MICRO_OLED_ENABLE +  if (timer_elapsed(last_flush) > ScreenOffInterval) { +  send_command(DISPLAYOFF);      /* 0xAE */ +  } +#endif +  if (counterst == 0) { +    //testPatternFB(o_fb); +  } +  counterst = (counterst + 1) % 1024; +  //rgblight_task(); +	matrix_scan_user(); +} diff --git a/keyboards/boston_meetup/2019/2019.h b/keyboards/boston_meetup/2019/2019.h new file mode 100644 index 000000000..fbba5c315 --- /dev/null +++ b/keyboards/boston_meetup/2019/2019.h @@ -0,0 +1,19 @@ +/* Copyright 2019 ishtob + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program.  If not, see <http://www.gnu.org/licenses/>. + */ +#pragma once + +#include "boston_meetup.h" + diff --git a/keyboards/boston_meetup/2019/config.h b/keyboards/boston_meetup/2019/config.h new file mode 100644 index 000000000..565281644 --- /dev/null +++ b/keyboards/boston_meetup/2019/config.h @@ -0,0 +1,196 @@ +#pragma once + +/* USB Device descriptor parameter */ +#define DEVICE_VER 0x07E3 + +#undef MATRIX_ROWS +#undef MATRIX_COLS +/* key matrix size */ +#define MATRIX_ROWS 4 +#define MATRIX_COLS 4 + +/* + * Keyboard Matrix Assignments + * + * Change this to how you wired your keyboard + * COLS: AVR pins used for columns, left to right + * ROWS: AVR pins used for rows, top to bottom + * DIODE_DIRECTION: COL2ROW = COL = Anode (+), ROW = Cathode (-, marked on diode) + *                  ROW2COL = ROW = Anode (+), COL = Cathode (-, marked on diode) + * +*/ + +#undef MATRIX_ROW_PINS +#undef MATRIX_COL_PINS + +#define MATRIX_ROW_PINS { A3, B8, B9, B1 } +#define MATRIX_COL_PINS { A7, A8, B2, B10 } + +#define NUMBER_OF_ENCODERS 1 +#define ENCODERS_PAD_A { B13 } +#define ENCODERS_PAD_B { B14 } + +//Audio +#undef AUDIO_VOICES +#undef C6_AUDIO + +#ifdef AUDIO_ENABLE +    #define STARTUP_SONG SONG(ONE_UP_SOUND) +    // #define STARTUP_SONG SONG(NO_SOUND) + +#define AUDIO_CLICKY +  /* to enable clicky on startup */ +  //#define AUDIO_CLICKY_ON +#define AUDIO_CLICKY_FREQ_RANDOMNESS 1.5f +#endif + +//configure qwiic micro_oled driver for the 128x32 oled +#ifdef QWIIC_MICRO_OLED_ENABLE + +#undef I2C_ADDRESS_SA0_1 +#define I2C_ADDRESS_SA0_1 0b0111100 +#define LCDWIDTH      128 +#define LCDHEIGHT     32 +#define micro_oled_rotate_180 + +#endif +/* + * Keyboard Matrix Assignments + * + * Change this to how you wired your keyboard + * COLS: AVR pins used for columns, left to right + * ROWS: AVR pins used for rows, top to bottom + * DIODE_DIRECTION: COL2ROW = COL = Anode (+), ROW = Cathode (-, marked on diode) + *                  ROW2COL = ROW = Anode (+), COL = Cathode (-, marked on diode) + * +*/ + +/* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */ +#define DEBOUNCE 6 + +/* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ +//#define LOCKING_SUPPORT_ENABLE +/* Locking resynchronize hack */ +//#define LOCKING_RESYNC_ENABLE + +/* + * Force NKRO + * + * Force NKRO (nKey Rollover) to be enabled by default, regardless of the saved + * state in the bootmagic EEPROM settings. (Note that NKRO must be enabled in the + * makefile for this to work.) + * + * If forced on, NKRO can be disabled via magic key (default = LShift+RShift+N) + * until the next keyboard reset. + * + * NKRO may prevent your keystrokes from being detected in the BIOS, but it is + * fully operational during normal computer usage. + * + * For a less heavy-handed approach, enable NKRO via magic key (LShift+RShift+N) + * or via bootmagic (hold SPACE+N while plugging in the keyboard). Once set by + * bootmagic, NKRO mode will always be enabled until it is toggled again during a + * power-up. + * + */ +//#define FORCE_NKRO + +/* + * Feature disable options + *  These options are also useful to firmware size reduction. + */ + +/* disable debug print */ +//#define NO_DEBUG + +/* disable print */ +//#define NO_PRINT + +/* disable action features */ +//#define NO_ACTION_LAYER +//#define NO_ACTION_TAPPING +//#define NO_ACTION_ONESHOT +//#define NO_ACTION_MACRO +//#define NO_ACTION_FUNCTION +/* + * MIDI options + */ + +/* Prevent use of disabled MIDI features in the keymap */ +//#define MIDI_ENABLE_STRICT 1 + +/* enable basic MIDI features: +   - MIDI notes can be sent when in Music mode is on +*/ + +#define MIDI_BASIC + +/* enable advanced MIDI features: +   - MIDI notes can be added to the keymap +   - Octave shift and transpose +   - Virtual sustain, portamento, and modulation wheel +   - etc. +*/ +//#define MIDI_ADVANCED + +/* override number of MIDI tone keycodes (each octave adds 12 keycodes and allocates 12 bytes) */ +//#define MIDI_TONE_KEYCODE_OCTAVES 2 + +/* Haptic Driver initialization settings + * Feedback Control Settings */ +#define FB_ERM_LRA 1 /* For ERM:0 or LRA:1*/ +#define FB_BRAKEFACTOR 6 /* For 1x:0, 2x:1, 3x:2, 4x:3, 6x:4, 8x:5, 16x:6, Disable Braking:7 */ +#define FB_LOOPGAIN 1 /* For  Low:0, Medium:1, High:2, Very High:3 */ + +/* default 3V ERM vibration motor voltage and library*/ +#if FB_ERM_LRA == 0  +#define RATED_VOLTAGE 3 +#define V_RMS 2.3 +#define V_PEAK 3.30 +/* Library Selection */ +#define LIB_SELECTION 4 /* For Empty:0' TS2200 library A to D:1-5, LRA Library: 6 */ + +/* default 2V LRA voltage and library */ +#elif FB_ERM_LRA == 1 +#define RATED_VOLTAGE 2 +#define V_RMS 2.0 +#define V_PEAK 2.85 +#define F_LRA 200 +/* Library Selection */ +#define LIB_SELECTION 6 /* For Empty:0' TS2200 library A to D:1-5, LRA Library: 6 */ + +#endif + +/* Control 1 register settings */ +#define DRIVE_TIME 25 +#define AC_COUPLE 0 +#define STARTUP_BOOST 1 + +/* Control 2 Settings */ +#define BIDIR_INPUT 1 +#define BRAKE_STAB 1 /* Loopgain is reduced when braking is almost complete to improve stability */ +#define SAMPLE_TIME 3 +#define BLANKING_TIME 1 +#define IDISS_TIME 1 + +/* Control 3 settings */ +#define NG_THRESH 2 +#define ERM_OPEN_LOOP 1 +#define SUPPLY_COMP_DIS 0 +#define DATA_FORMAT_RTO 0 +#define LRA_DRIVE_MODE 0 +#define N_PWM_ANALOG 0 +#define LRA_OPEN_LOOP 0 +/* Control 4 settings */ +#define ZC_DET_TIME 0 +#define AUTO_CAL_TIME 3 + +#define RGBLIGHT_ANIMATIONS + +#define RGBLED_NUM 10 +#define RGB_DI_PIN B5 +#define DRIVER_LED_TOTAL RGBLED_NUM + +#define RGB_MATRIX_KEYPRESSES + +#define SOLENOID_PIN A14 + diff --git a/keyboards/boston_meetup/2019/info.json b/keyboards/boston_meetup/2019/info.json new file mode 100644 index 000000000..15ab72935 --- /dev/null +++ b/keyboards/boston_meetup/2019/info.json @@ -0,0 +1,12 @@ +{ +  "keyboard_name": "Boston Meetup 2019",  +  "url": "",  +  "maintainer": "qmk",  +  "width": 4,  +  "height": 4,  +  "layouts": { +    "LAYOUT": { +      "key_count": 13, + "layout": [{"label":"K00", "x":0, "y":0}, {"label":"K10", "x":0, "y":1}, {"label":"K11", "x":1, "y":1}, {"label":"K12", "x":2, "y":1}, {"label":"K13", "x":3, "y":1}, {"label":"K20", "x":0, "y":2}, {"label":"K21", "x":1, "y":2}, {"label":"K22", "x":2, "y":2}, {"label":"K23", "x":3, "y":2}, {"label":"K30", "x":0, "y":3}, {"label":"K31", "x":1, "y":3}, {"label":"K32", "x":2, "y":3}, {"label":"K33", "x":3, "y":3}]    } +  } +} diff --git a/keyboards/boston_meetup/2019/keymaps/default/keymap.c b/keyboards/boston_meetup/2019/keymaps/default/keymap.c new file mode 100644 index 000000000..52d67273e --- /dev/null +++ b/keyboards/boston_meetup/2019/keymaps/default/keymap.c @@ -0,0 +1,166 @@ +#include QMK_KEYBOARD_H + +// Each layer gets a name for readability, which is then used in the keymap matrix below. +// The underscores don't mean anything - you can have a layer called STUFF or any other name. +// Layer names don't all need to be of the same length, obviously, and you can also skip them +// entirely and just use numbers. + +enum custom_layers { +  _BASE, +  _LOWER, +  _RAISE, +  _ADJUST +}; + +enum custom_keycodes { +  BASE = SAFE_RANGE, +  LOWER, +  RAISE, +  KC_DEMOMACRO +}; + +// Custom macros +#define CTL_ESC     CTL_T(KC_ESC)               // Tap for Esc, hold for Ctrl +#define CTL_TTAB    CTL_T(KC_TAB)               // Tap for Esc, hold for Ctrl +#define CTL_ENT     CTL_T(KC_ENT)               // Tap for Enter, hold for Ctrl +#define SFT_ENT     SFT_T(KC_ENT)               // Tap for Enter, hold for Shift +// Requires KC_TRNS/_______ for the trigger key in the destination layer +#define LT_MC(kc)   LT(_MOUSECURSOR, kc)        // L-ayer T-ap M-ouse C-ursor +#define LT_RAI(kc)  LT(_RAISE, kc)              // L-ayer T-ap to Raise +#define DEMOMACRO   KC_DEMOMACRO                // Sample for macros + + +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + +/* Base + * ,------. + * | Esc  |  + * |------+------+-------------. + * |   :  |   7  |   8  |   9  |  + * |------+------+------+------| + * | RAISE|   4  |   5  |   6  |  + * |------+------+------+------| + * | LOWER|   1  |   2  |   3  | + * `---------------------------' + */ +[_BASE] = LAYOUT( +  KC_ESC, +  KC_COLN, KC_P7,  KC_P8,  KC_P9, +  RAISE,   KC_P4,  KC_P5,  KC_P6, +  LOWER,   KC_P1,  KC_P2,  KC_P3 +), + +/* Lower + * ,------. + * | Nmlk |  + * |------+------+-------------. + * |  :   |   /  |   *  |   -  |  + * |------+------+------+------| + * |      |      |   =  |   +  |  + * |------+------+------+------| + * |      |  0   |   .  |  ENT | + * `---------------------------' + */ +[_LOWER] = LAYOUT( +  KC_NLCK, +  KC_COLN,  KC_PSLS, KC_PAST, KC_PMNS, +  _______,  XXXXXXX, KC_EQL,  KC_PPLS, +  _______,  KC_P0,   KC_PDOT, KC_PENT +), + +/* Raise + * ,------. + * | Esc  |  + * |------+------+-------------. + * |RGB TG|RGB M+|RGB M-|      | + * |------+------+------+------| + * |      |RGB H+|RGB S+|RGB V+|  + * |------+------+------+------| + * |  `   |RGB H-|RGB S-|RGB V-| + * `---------------------------' + */ +[_RAISE] = LAYOUT( +  KC_NLCK, +  RGB_TOG, RGB_MOD, RGB_RMOD, XXXXXXX, +  _______, RGB_HUI, RGB_SAI,  RGB_VAI, +  _______, RGB_HUD, RGB_SAD,  RGB_VAD + +), + +/* Adjust + * ,------. + * | DFU  |  + * |------+------+-------------. + * |HPT TG|HPT FB|HPT RS| BKSP |  + * |------+------+------+------| + * |      |HPT M+|      |      |  + * |------+------+------+------| + * |      |HPT M-|Clk TG| Del  | + * `---------------------------' + */ +[_ADJUST] = LAYOUT( +  RESET, +  HPT_TOG, HPT_FBK,  HPT_RST, KC_BSPC, +  _______, HPT_MODI, XXXXXXX, XXXXXXX, +  _______, HPT_MODD, CK_TOGG, KC_DEL +), + + +}; + +uint32_t layer_state_set_user(uint32_t state) { +  return update_tri_layer_state(state, _LOWER, _RAISE, _ADJUST); +} + + +bool process_record_user(uint16_t keycode, keyrecord_t *record) { +  switch (keycode) { +    case KC_DEMOMACRO: +            if (record->event.pressed) { +        // when keycode KC_DEMOMACRO is pressed +        SEND_STRING("QMK is the best thing ever!"); +      } else { +        // when keycode KC_DEMOMACRO is released +      } +      break; +    case LOWER: +      if (record->event.pressed) { +          //not sure how to have keyboard check mode and set it to a variable, so my work around +          //uses another variable that would be set to true after the first time a reactive key is pressed. +        layer_on(_LOWER); +      } else { +        layer_off(_LOWER); +      } +      return false; +      break; +    case RAISE: +      if (record->event.pressed) { +        //not sure how to have keyboard check mode and set it to a variable, so my work around +        //uses another variable that would be set to true after the first time a reactive key is pressed. +        layer_on(_RAISE); +      } else { +        layer_off(_RAISE); +      } +      return false; +      break; +  } +  return true; +} + +bool music_mask_user(uint16_t keycode) { +  switch (keycode) { +    case RAISE: +    case LOWER: +      return false; +    default: +      return true; +  } +} + +void matrix_init_user(void) { +} + + +void matrix_scan_user(void) { +} + diff --git a/keyboards/boston_meetup/2019/keymaps/default/readme.md b/keyboards/boston_meetup/2019/keymaps/default/readme.md new file mode 100644 index 000000000..75f80b519 --- /dev/null +++ b/keyboards/boston_meetup/2019/keymaps/default/readme.md @@ -0,0 +1,51 @@ +# The Default Boston Meetup 2019 board Layout + +Keymap: +``` +Base +,------. +| Esc  |  +|------+------+-------------. +|   :  |   7  |   8  |   9  |  +|------+------+------+------| +| RAISE|   4  |   5  |   6  |  +|------+------+------+------| +| LOWER|   1  |   2  |   3  | +`---------------------------' + +Lower +,------. +| Nmlk |  +|------+------+-------------. +|  :   |   /  |   *  |   -  |  +|------+------+------+------| +|      |      |   =  |   +  |  +|------+------+------+------| +|      |   0  |   .  |  ENT | +`---------------------------' + +Raise +,------. +| Esc  |  +|------+------+-------------. +|RGB TG|RGB M+|RGB M-|      | +|------+------+------+------| +|      |RGB H+|RGB S+|RGB V+|  +|------+------+------+------| +|      |RGB H-|RGB S-|RGB V-| +`---------------------------' + +Adjust: +,------. +| DFU  |  +|------+------+-------------. +|HPT TG|HPT FB|HPT RS| BKSP |  +|------+------+------+------| +|      |HPT M+|      |      |  +|------+------+------+------| +|      |HPT M-|Clk TG| Del  | +`---------------------------' + +``` + +RGB still work in progress
\ No newline at end of file diff --git a/keyboards/boston_meetup/2019/keymaps/readme.md b/keyboards/boston_meetup/2019/keymaps/readme.md new file mode 100644 index 000000000..c10a49f7d --- /dev/null +++ b/keyboards/boston_meetup/2019/keymaps/readme.md @@ -0,0 +1,22 @@ +# How to add your own keymap + +Folders can be named however you'd like (will be approved upon merging), or should follow the format with a preceding `_`: + +    _[ISO 3166-1 alpha-2 code*]_[layout variant]_[layout name/author] + +\* See full list: https://en.wikipedia.org/wiki/ISO_3166-1#Officially_assigned_code_elements + +and contain the following files: + +* `keymap.c` +* `readme.md` *recommended* +* `config.h` *optional*, found automatically when compiling +* `Makefile` *optional*, found automatically when compling + +When adding your keymap to this list, keep it organised alphabetically (select list, edit->sort lines), and use this format: + +     * **folder_name** description + +# List of 2019 keymaps + +* **default** default 2019 macropad layout
\ No newline at end of file diff --git a/keyboards/boston_meetup/2019/readme.md b/keyboards/boston_meetup/2019/readme.md new file mode 100644 index 000000000..2bdac9dcd --- /dev/null +++ b/keyboards/boston_meetup/2019/readme.md @@ -0,0 +1,13 @@ +# Boston Meetup 2019 Macropad + + +  +Limited-run board designed for Boston MK community meetup 2019. + +Keyboard Maintainer: [ishtob](https://github.com/ishtob), [QMK](https://github.com/qmk)   + +Make example for this keyboard (after setting up your build environment): + +    make boston_meetup/2019:default + +See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
\ No newline at end of file diff --git a/keyboards/boston_meetup/2019/rules.mk b/keyboards/boston_meetup/2019/rules.mk new file mode 100644 index 000000000..7c03a025e --- /dev/null +++ b/keyboards/boston_meetup/2019/rules.mk @@ -0,0 +1,24 @@ +# project specific files + +# Cortex version +MCU  = STM32F303 + +# Build Options +#   comment out to disable the options. +# +BACKLIGHT_ENABLE = no +BOOTMAGIC_ENABLE = no	# Virtual DIP switch configuration +## (Note that for BOOTMAGIC on Teensy LC you have to use a custom .ld script.) +MOUSEKEY_ENABLE = yes	# Mouse keys +EXTRAKEY_ENABLE = yes	# Audio control and System control +CONSOLE_ENABLE = no	# Console for debug +COMMAND_ENABLE = no    # Commands for debug and configuration +#SLEEP_LED_ENABLE = yes  # Breathing sleep LED during USB suspend +NKRO_ENABLE = yes	    # USB Nkey Rollover +CUSTOM_MATRIX = no # Custom matrix file +AUDIO_ENABLE = yes +RGBLIGHT_ENABLE = no +RGB_MATRIX_ENABLE = no #WS2812 +HAPTIC_ENABLE += DRV2605L +QWIIC_ENABLE += MICRO_OLED +# SERIAL_LINK_ENABLE = yes diff --git a/keyboards/boston_meetup/boston_meetup.c b/keyboards/boston_meetup/boston_meetup.c new file mode 100644 index 000000000..a9201ac85 --- /dev/null +++ b/keyboards/boston_meetup/boston_meetup.c @@ -0,0 +1,2 @@ +#include "boston_meetup.h" + diff --git a/keyboards/boston_meetup/boston_meetup.h b/keyboards/boston_meetup/boston_meetup.h new file mode 100644 index 000000000..e1d9d9206 --- /dev/null +++ b/keyboards/boston_meetup/boston_meetup.h @@ -0,0 +1,19 @@ +#pragma once + +#ifdef KEYBOARD_boston_meetup_2019 +    #include "2019.h" +#define LAYOUT( \ +    K00, \ +    K10, K11, K12, K13, \ +    K20, K21, K22, K23, \ +    K30, K31, K32, K33  \ +  ) \ +{ \ +  {  K00,  KC_NO, KC_NO, KC_NO  }, \ +  {  K10,  K11,   K12,   K13    }, \ +  {  K20,  K21,   K22,   K23    }, \ +  {  K30,  K31,   K32,   K33    }  \ +} +#endif + +#include "quantum.h"
\ No newline at end of file diff --git a/keyboards/boston_meetup/config.h b/keyboards/boston_meetup/config.h new file mode 100644 index 000000000..b025e18df --- /dev/null +++ b/keyboards/boston_meetup/config.h @@ -0,0 +1,60 @@ +/* +Copyright 2012 Jun Wako <wakojun@gmail.com> + +This program is free software: you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation, either version 2 of the License, or +(at your option) any later version. + +This program is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with this program.  If not, see <http://www.gnu.org/licenses/>. +*/ + +#pragma once + +#include "config_common.h" + +/* USB Device descriptor parameter */ +#define VENDOR_ID       0xFB30 +#define PRODUCT_ID      0x26BE +#define MANUFACTURER    ishtob +#define PRODUCT         Boston Meetup Board +#define DESCRIPTION     A limited-run community meetup board + +//#define AUDIO_VOICES + +//#define BACKLIGHT_PIN B7 + +/* COL2ROW or ROW2COL */ +#define DIODE_DIRECTION COL2ROW + +/* define if matrix has ghost */ +//#define MATRIX_HAS_GHOST + +/* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ +//#define LOCKING_SUPPORT_ENABLE +/* Locking resynchronize hack */ +//#define LOCKING_RESYNC_ENABLE + +/* + * Feature disable options + *  These options are also useful to firmware size reduction. + */ + +/* disable debug print */ +//#define NO_DEBUG + +/* disable print */ +//#define NO_PRINT + +/* disable action features */ +//#define NO_ACTION_LAYER +//#define NO_ACTION_TAPPING +//#define NO_ACTION_ONESHOT +//#define NO_ACTION_MACRO +//#define NO_ACTION_FUNCTION diff --git a/keyboards/boston_meetup/readme.md b/keyboards/boston_meetup/readme.md new file mode 100644 index 000000000..2fa1ec958 --- /dev/null +++ b/keyboards/boston_meetup/readme.md @@ -0,0 +1,14 @@ +# Boston Meetup Macropads + + +  +Limited-run boards designed for Boston MK community meetups. + +Keyboard Maintainer: [ishtob](https://github.com/ishtob), [QMK](https://github.com/qmk)   +Hardware Supported: Boston Meetup PCB 2018, 2019  + +Make example for this keyboard (after setting up your build environment): + +    make boston_meetup/YYYY:default + +See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
\ No newline at end of file diff --git a/keyboards/boston_meetup/rules.mk b/keyboards/boston_meetup/rules.mk new file mode 100644 index 000000000..6dd899edc --- /dev/null +++ b/keyboards/boston_meetup/rules.mk @@ -0,0 +1,2 @@ + +DEFAULT_FOLDER = boston_meetup/2019 | 
