keychron_qmk_firmware/docs/ja/feature_led_matrix.md
James Young c66df16644
2020 November 28 Breaking Changes Update (#11053)
* Branch point for 2020 November 28 Breaking Change                                                

* Remove matrix_col_t to allow MATRIX_ROWS > 32 (#10183)                                           

* Add support for soft serial to ATmega32U2 (#10204)                                               

* Change MIDI velocity implementation to allow direct control of velocity value (#9940)            

* Add ability to build a subset of all keyboards based on platform.                                

* Actually use eeprom_driver_init().                                                               

* Make bootloader_jump weak for ChibiOS. (#10417)                                                  

* Joystick 16-bit support (#10439)                                                                 

* Per-encoder resolutions (#10259)                                                                 

* Share button state from mousekey to pointing_device (#10179)                                     

* Add hotfix for chibios keyboards not wake (#10088)                                               

* Add advanced/efficient RGB Matrix Indicators (#8564)                                             

* Naming change.                                                                                   

* Support for STM32 GPIOF,G,H,I,J,K (#10206)                                                       

* Add milc as a dependency and remove the installed milc (#10563)                                  

* ChibiOS upgrade: early init conversions (#10214)                                                 

* ChibiOS upgrade: configuration file migrator (#9952)                                             

* Haptic and solenoid cleanup (#9700)                                                              

* XD75 cleanup (#10524)                                                                            

* OLED display update interval support (#10388)                                                    

* Add definition based on currently-selected serial driver. (#10716)                               

* New feature: Retro Tapping per key (#10622)                                                      

* Allow for modification of output RGB values when using rgblight/rgb_matrix. (#10638)             

* Add housekeeping task callbacks so that keyboards/keymaps are capable of executing code for each main loop iteration. (#10530)

* Rescale both ChibiOS and AVR backlighting.                                                       

* Reduce Helix keyboard build variation (#8669)                                                    

* Minor change to behavior allowing display updates to continue between task ticks (#10750)        

* Some GPIO manipulations in matrix.c change to atomic. (#10491)                                   

* qmk cformat (#10767)                                                                             

* [Keyboard] Update the Speedo firmware for v3.0 (#10657)                                          

* Maartenwut/Maarten namechange to evyd13/Evy (#10274)                                             

* [quantum] combine repeated lines of code (#10837)                                                

* Add step sequencer feature (#9703)                                                               

* aeboards/ext65 refactor (#10820)                                                                 

* Refactor xelus/dawn60 for Rev2 later (#10584)                                                    

* add DEBUG_MATRIX_SCAN_RATE_ENABLE to common_features.mk (#10824)                                 

* [Core] Added `add_oneshot_mods` & `del_oneshot_mods` (#10549)                                    

* update chibios os usb for the otg driver (#8893)                                                 

* Remove HD44780 References, Part 4 (#10735)                                                       

* [Keyboard] Add Valor FRL TKL (+refactor) (#10512)                                                

* Fix cursor position bug in oled_write_raw functions (#10800)                                     

* Fixup version.h writing when using SKIP_VERSION=yes (#10972)                                     

* Allow for certain code in the codebase assuming length of string. (#10974)                       

* Add AT90USB support for serial.c (#10706)                                                        

* Auto shift: support repeats and early registration (#9826)                                       

* Rename ledmatrix.h to match .c file (#7949)                                                      

* Split RGB_MATRIX_ENABLE into _ENABLE and _DRIVER (#10231)                                        

* Split LED_MATRIX_ENABLE into _ENABLE and _DRIVER (#10840)                                        

* Merge point for 2020 Nov 28 Breaking Change
2020-11-28 12:02:18 -08:00

4.2 KiB

LED マトリックスライト

この機能により、外部ドライバによって駆動される LED マトリックスを使うことができます。この機能は、バックライト制御と同じキーコードを使えるようにするため、バックライトシステムに接続します。

RGB LED を使いたい場合は、代わりに RGB マトリックスサブシステム を使うべきです。

ドライバ設定

IS31FL3731

I2C IS31FL3731 RGB コントローラを使ったアドレス指定可能な LED マトリックスライトのための基本的なサポートがあります:有効にするには、rules.mk に以下を追加します:

LED_MATRIX_ENABLE = yes
LED_MATRIX_DRIVER = IS31FL3731

1から4個の IS31FL3731 IC を使うことができます。キーボード上に存在しない IC の LED_DRIVER_ADDR_<N> 定義を指定しないでください。config.h に以下の項目を定義することができます:

変数 説明 デフォルト
ISSI_TIMEOUT (オプション) i2c メッセージを待つ時間 100
ISSI_PERSISTENCE (オプション) 失敗したメッセージをこの回数再試行する 0
LED_DRIVER_COUNT (必須) LED ドライバ IC の数
LED_DRIVER_LED_COUNT (必須) 全てのドライバの LED ライトの数
LED_DRIVER_ADDR_1 (必須) 最初の LED ドライバのアドレス
LED_DRIVER_ADDR_2 (オプション) 2番目の LED ドライバのアドレス
LED_DRIVER_ADDR_3 (オプション) 3番目の LED ドライバのアドレス
LED_DRIVER_ADDR_4 (オプション) 4番目の LED ドライバのアドレス

2つのドライバを使う例です。

// これは7ビットのアドレスで、左シフトされます
// ビット0に0を設定すると書き込み、1を設定すると読み込みです (I2C プロトコルに従う)
// アドレスは配線によって変わります:
// 0b1110100 AD <-> GND
// 0b1110111 AD <-> VCC
// 0b1110101 AD <-> SCL
// 0b1110110 AD <-> SDA
#define LED_DRIVER_ADDR_1 0b1110100
#define LED_DRIVER_ADDR_2 0b1110110

#define LED_DRIVER_COUNT 2
#define LED_DRIVER_1_LED_COUNT 25
#define LED_DRIVER_2_LED_COUNT 24
#define LED_DRIVER_LED_COUNT LED_DRIVER_1_LED_TOTAL + LED_DRIVER_2_LED_TOTAL

現在、2つのドライバのみがサポートされますが、4つの組み合わせ全てをサポートすることは簡単です。

<keyboard>.c に全ての LED を列挙する配列を定義します:

const is31_led g_is31_leds[DRIVER_LED_TOTAL] = {
/* これらの位置については IS31 マニュアルを参照してください
*   driver
*   |  LED address
*   |  | */
{0, C3_3},
....
}

ここで、Cx_yデータシートおよびヘッダファイル drivers/issi/is31fl3731-simple.h で定義されるマトリックス内の LED の位置です。driverconfig.h で定義したドライバのインデックス(0123のいずれか)です。

キーコード

現在のところ、全ての LED マトリックスのキーコードはバックライトシステムと共有されます。

LED マトリックス効果

現在のところ、LED マトリックス効果は作成されていません。

カスタムレイヤー効果

カスタムレイヤー効果は <keyboard>.c 内で以下を定義することで行うことができます:

void led_matrix_indicators_kb(void) {
led_matrix_set_index_value(index, value);
}

同様の関数がキーマップ内で led_matrix_indicators_user として動作します。

サスペンド状態

サスペンド機能を使うには、以下を <keyboard>.c に追加します:

void suspend_power_down_kb(void)
{
led_matrix_set_suspend_state(true);
}

void suspend_wakeup_init_kb(void)
{
led_matrix_set_suspend_state(false);
}