kboard
A programmable keyboard for Android that lets you send phrases, lenny faces, macros, or data from the Internet in a single tap!
F-Droid (up to date)
Play Store (outdated)
Commands
kboard includes a VIM-like syntax for adding special macro keys, to perform tasks like cursor movements, copy/pasting and text manipulation.
A command key has the following format:
/<friendly label>!<comma separated commands>
Example:
/Italicise!dw,i(_$0_)
This creates a key titled "Italicise", which does the following: dw
deletes the previous word and adds it to the buffer, i
inserts the text in the brackets (which would be the deleted word wrapped in underscores.
Most commands can be preceded by a number, indicating how many times it will be run.
Available commands:
d
delete previous characterdw
delete previous word3dw
delete previous three wordsdd
delete alldt(char)
deletes (backwards) up to and including the specified characterds
- deletes either the selected text, or if nothing is selected then deletes everything.yy
copy ally
copy selectionp
paste from bufferpc
paste from clipboardsa
select allsw
select a word, going backwards from the current cursor positioni(text)
output the content of the brackets ($0 gets replaced * with the last deleted/copied content)iraw(text)
as i, but does not adhere to settings such as autospace or Passive Aggressiveupper(text)
as i, but in upper caselower(text)
as i, but lower casej
move cursor back by a characterk
move cursor forward by a characterb
move cursor back by a wordw
move cursor forward by a words
trigger a send commande(...)
execute the command in the bracketsrnd
output a random kboard keyrnd(word1;word2;...)
output a random word from the comma separated listrnde
output a random emojifr(from;to)
replace all instances offrom
toto
fancy(style)
outputs buffer text with funky unicode characters (circle, darkcircle,square,darksquare,double,monospace,fancy,fancybold)curl(URL)
requests data from a URL and outputs it.img(URL)
requests an image from a URL and enters it in compatible messaging apps (e.g. Whatsapp)utf(unicode characters)
outputs the text unescaping all unicode character codes (e.g.\u00A2
)urlencode(string)
outputs the url encoded version of a string (e.g.hello%3aworld
)qq
switch to the keyboard application you have been using before (same as pressing the earth-wireframe key) after the rest of the commands has been executed.undo
undo the last change (limited to changes made by kboard)
Examples of use
/Italicise Previous!dw,i($0)
/Bolden Previous!dw,i($0)
/Italics!i(__),j
- this writes the two underscores then moves the cursor between them
/Copy All!yy
/Repeat word x4!dw,4p
- repeats the previous word 4 times
/rly sad!1000i(๐ฅ)
/darkcircle!ds,fancy(darkcircle)
- replaces selection or everything with ๐
ฃ๐
๐
ง๐
ฃ ๐
๐
๐
๐
๐
ฃ๐
๐
๐
ข. Choose from circle
, darkcircle
, square
,darksquare
,double
,monospace
,fancy
,fancybold
.
Warning: weird unicode characters look cool but break accessibility software, so please don't use in public places!
/exec!dt(!),e($0)
- this is meta, it enables you to write and execute commands inline in a text field by writing e.g. !10e(^, i(* ), ^)
and hitting the exec key
/bullets!10e(^, i(* ), ^)
- prepends "* " the the previous 10 lines
/emojigame!10rnde
- outputs 10 random emoji
/feeling lucky!rnd,s
- sends a random kboard key
/birthday!dw,rnd(Happy Birthday name;Hey name, happy birthday.;hb2u;Have a great day name),fr(name,$0)
- write a name, then press this key to send a random birthday message to this name
/bdaysend!birthday,s
- Can also have commands that refer to other command keys you've made'
/uuid!curl(https://httpbin.org/uuid)
- Can make arbitrary GET requests to URLS
CURL examples
The curl
commands allows you to create your own HTTP endpoints to output anything you like!
Here are some examples of how it can be used:
/yt!ds,curl(https://kboard-api.glitch.me/youtube/$0)
An endpoint that searches the Youtube API, and returns the URL for the first video found.
/wolfram!ds,curl(https://api.wolframalpha.com/v1/result?appid=<APP_ID>&i=$0)
Uses the Wolfram Short Answers API to retrieve answers to anything Wolfram Alpha can answer. (Requires API key)
/cat!curl(https://kboard-api.glitch.me/catfact)
Outputs a cat fact from a Cat Fact API
/dad joke!curl(https://icanhazdadjoke.com/)
Outputs a random lame joke.
Accessibility Service (optional)
kboard provides an accessibility service which can be used to populate a person's name and messages from Whatsapp conversations.
This can be accessed with the keywords $name
, $fname
and $lname
, and $wachat
.
Getting the right content with the accessibility service is a bit flaky, generally going home/back will pick up the right content from a Whatsapp Conversation.
This service is optional, and the keyboard is fully functional without it.
Any content retrieved from WhatsApp is not sent or logged anywhere unless you explicitly do so yourself (e.g. by using it alongside curl
)