MathKeyboardEngine provides the logic for a highly customizable virtual math keyboard. It is intended for use together with any LaTeX typesetting library.
Project description
MathKeyboardEngine for Python
MathKeyboardEngine for Python provides the logic for a highly customizable virtual math keyboard. It is intended for use together with any LaTeX typesetting library (for example matplotlib.mathtext).
Also available:
An execution timeline
todo. For now, see the JavaScript repo.
Let me test it now!
Live examples can be tested at MathKeyboardEngine.GitHub.io.
Pros and cons?
Unique about MathKeyboardEngine:
- it supports (almost?) all math mode LaTeX, including matrices. (Please share if you know anything that is not supported.)
- its syntax tree consists of very few different parts: the
StandardLeafNode
,StandardBranchingNode
,AscendingBranchingNode
andDescendingBranchingNode
can be used for almost all LaTeX, including fractions, powers, combinations, subscript, etc. with ready-to-use up/down/left/right navigation. - it can be used with any LaTeX math typesetting library you like.
A con:
- this library will never be able to handle setting the cursor with the touch of a finger on a typeset formula. (But it DOES support up/down/left/right navigation and has a selection mode via arrow keys.)
More pros:
- you have full control over what you display on the virtual keyboard keys and what a virtual key press actually does.
- customize the editor output at runtime: dot or comma as decimal separator, cross or dot for multiplication, cursor style, colors, etc.
- this library also supports handling input from a physical keyboard, where - for example - the forward slash "/" key can be programmed to result in encapsulating a previously typed number as the numerator of a fraction. (See the examples.)
- almost forgotten: it's open source, free to use, free to modify (please fork this repo)!
How to use this library
This library has been distributed via PyPi.
For installing a specific version of mathkeyboardengine - for example 0.1.0-alpha.12
- run the following command in the VS Code
Terminal:
py -m pip install mathkeyboardengine==0.1.0a12
Then create a new folder 'MathKeyboardEngineTest' and open it in VS Code
. Add a file main.py
with the following content:
from mathkeyboardengine import *
k = KeyboardMemory()
latexconfiguration = LatexConfiguration()
insert(k, DigitNode('2'))
insert_with_encapsulate_current(k, AscendingBranchingNode('', '^{', '}'))
insert(k, StandardLeafNode('x'))
print(get_edit_mode_latex(k, latexconfiguration))
Press the play button in the upper-right corner of VS Code
. The result that is displayed in the Terminal:
2^{x\blacksquare}
Documentation
todo. For now, see the JavaScript repo.
How to use this repo
Follow these steps to set up (and verify) a development environment for this repository:
- Install the latest version of Python via https://www.python.org/downloads. The download includes
pip
. - Open the Terminal in VS Code and run
py -m pip install -U pytest
. - Run all tests via
py -m pytest
. - See code coverage:
py -m pip install pytest-cov
py -m pytest --cov=src --cov-report term-missing
. - Run all tests for multiple versions of python and multiple operating systems:
py -m pip install --upgrade nox
py -m nox
(this usesnoxfile.py
from the root of the repository). - If you're interested all the release steps, see
_disthelper/release_steps.txt
.
Ask or contribute
- ask questions about anything that is not clear or when you'd like help.
- share ideas or what you've made.
- report a bug.
- request an enhancement.
- open a pull request.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for mathkeyboardengine-0.1.0a20.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | ae6c96bc5e056362646b71e88d4c6d7db057752a37bca3ebdb8ae7c1242c65e4 |
|
MD5 | 309f716aee0694a2ec1a0b464f4193cb |
|
BLAKE2b-256 | 1121ea93c98f5a5a64ccf81e16147a006141335b7ea08336238d245d2834b09e |
Hashes for mathkeyboardengine-0.1.0a20-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8550418384d485d352d4c4bd181d565103f97ee6d561e3eafc65a7b3c64631d4 |
|
MD5 | e0b1ffe8babb12a2a6c421d93a4c3538 |
|
BLAKE2b-256 | 622d40b29f79a2c2be88d6c78919d8e78f91bd4a5448979c12907198f76e251d |