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.0a18.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 032c6f6170b91fcb0d4e50094e77ec10036e678c50cdac8b884dc038ce3d07f7 |
|
MD5 | 9c31e6c8f3e2d5c07752e245b9b4cd8c |
|
BLAKE2b-256 | 38b9141644566d8518c36495541f225f57e5617233b264d92faed1a71bbac694 |
Hashes for mathkeyboardengine-0.1.0a18-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7074ab0fe2f3237f70d2149ad1d06288faa8031f7e55428e3c1d048fd9857bec |
|
MD5 | 8e6efa857a90779009396b23cd74ae81 |
|
BLAKE2b-256 | 4a82730e7ae15a1ca0a25ac651b526083d1a626968b51cf7e4a630031c24a80d |