Skip to content

Latest commit

 

History

History
177 lines (106 loc) · 5.29 KB

firmware_en.md

File metadata and controls

177 lines (106 loc) · 5.29 KB

Firmware

To Simply Verify Function

It is possible to verify functionality without building using QMK Toolbox.

Imgur

  1. Verify that an atmega32u4 is detected
  2. Download any of the firmwares below which suits the options selected, and open it in QMK Toolbox

Imgur

  1. Press the reset button on helix, and verify that it shows as "connected"
  2. Immediately press flash

Imgur

If a message similar to this appears, flashing has succeeded.

Please verify that typing is possible using these firmwares.

To change the layout, use the build guide below.

To Customize

Download QMK Firmware from the following:

https://github.com/qmk/qmk_firmware/

(Press the green "Clone or download" button, and then "Download ZIP" to obtain a ZIP file.)

Extract after download.

If familiar with git, a git clone may be more suitable.

Setting up the build environment

macOS

homebrew will be used in this guide.

  1. Launch terminal
  2. Install homebrew if not installed yet.
  3. Run the following commands:
brew tap osx-cross/avr
brew tap PX4/homebrew-px4
brew update
brew install avr-gcc@7
brew install dfu-programmer
brew install gcc-arm-none-eabi
brew install avrdude

Windows

msys2 will be used.

  1. Visit the msys2 website, and download the installer suited for your PC:
  • 32bit: msys2-i686-xxxxxxx.exe
  • 64bit: msys2-x86_64-xxxxxxxx.exe
  1. Launch msys2.
  2. Move the QMK firmware folder to the folder (This guide assumes msys2 installed to the C drive): cd /c/qmk_firmware/
  3. Run util/msys2_install.sh
  4. The installer will ask you which packages to install (When in doubt, respond Y to install)
  5. When complete, restart msys2.

Build and flash

Run the following at the root directory of the QMK folder:

make helix:default

To flash at the same time, attach :avrdude to the command:

make helix:default:avrdude

For flashing via GUI, use QMK Toolbox as described earlier.

Both halves must be flashed.

Customize

Copy and rename the default folder in /keyboards/helix/rev2/keymaps/. This new folder will be used from now on.

For building this new keymap, the following command will be used:

make helix:<new keymap folder name>

Editing the keymaps

The default keymap is stored in keymap.c. It can be edited to modify the keymap freely.

Please see this page for a keycode reference.

Imgur

Making the keymap 4 rows

Within the folder, change the field HELIX_ROWS rules.mk from 5 to 4.

HELIX_ROWS = 4

Enable RGB backlighting

In the same file, change the LED_BACK_ENABLE from no to yes.

LED_BACK_ENABLE = yes

Enable RGB underglow

Again in the same file, change LED_UNDERGLOW_ENABLE from no to yes.

LED_UNDERGLOW_ENABLE = yes

Enable OLED display

Again in the same file, change OLED_ENABLE from no to yes.

OLED_ENABLE = yes

Edit font data

The font data is stored in helix/common/glcdfont.c. This data can be edited in the following ways for modifying OLED content.

Using the web tool

The web tool created by @teri_yakichan can be used to modify the file easily.

Helix Font Editor

Using an image editor

To use an image editor, do the following to convert text to image.

  1. Take the image data from glcdfont.c and move it to a text file. 0x00, 0x00 ... 0x00
  2. Use the script to convert to image
  3. Edit the image
  4. Use the script to convert back to text
  5. Insert to glcdfont.c

An example image being edited:

Font

The following script is used for conversion. https://github.com/MakotoKurauchi/helix/tree/master/FontConverter

Converting text to image

$ python3 hex2img.py inHex.txt outImage

Converting image to text

$ python3 img2hex.py inImage.bmp > outHex.txt

Creating a font data specific to the keymap

Editing helix/common/glcdfont.c affects all keymaps. To make a font data unique to a keymap, edit the LOCAL_GLCDFONT field in rules.mk:

LOCAL_GLCDFONT = yes

Then, rename glcdfont.c to helixfont.h and place it in the same directory as keymap.c.

Other customization

QMK has many features. See the docs and others' customizations to build your own unique helix.