HTML widgets for tkinter
Project description
tk_html_widgets
HTML widgets for tkinter
Overview
This module is a collection of tkinter widgets whose text can be set in HTML format. A HTML widget isn't a web browser frame, it's only a simple and lightweight HTML parser that formats the tags used by the tkinter Text base class. The widgets behaviour is similar to the PyQt5 text widgets (see the PyQt5 HTML markup subset).
Installation
pip install tk_html_widgets
Requirements
- Python 3.4 or later with tcl/tk support
- Pillow 5.3.0
Example
import tkinter as tk
from tk_html_widgets import HTMLLabel
root = tk.Tk()
text = HTMLLabel(root)
text.pack(fill="both", expand=True)
text.set_html('<h1 style="color: red; text-align: center"> Hello World </H1>')
text.fit_height()
root.mainloop()
Documentation
Classes:
All widget classes inherits from the tkinter.Text() base class.
class HTMLScrolledText(tkinter.Text)
Text-box widget with vertical scrollbar
class HTMLText(tkinter.Text)
Text-box widget without vertical scrollbar
class HTMLLabel(tkinter.Text)
Text-box widget with label appereance
Methods:
def set_html(self, html, strip=True):
Description: Sets the text in html text.
Args:
- html: input HTML string
- strip: if True (default) handles spaces in HTML-like style
def fit_height(self):
Description: Fit widget height in order to display all wrapped lines
HTML support:
Only a subset of the whole HTML tags and attributes are supported (see table below). Where is possibile, I hope to add more HTML support in the next releases.
Tags | Attributes | Notes |
---|---|---|
a | style, href | |
b | style | |
br | ||
code | style | |
div | style | |
em | style | |
h1 | style | |
h2 | style | |
h3 | style | |
h4 | style | |
h5 | style | |
h6 | style | |
i | style | |
img | src, width, height | local images only |
li | style | |
mark | style | |
ol | style, type | 1, a, A list types only |
p | style | |
pre | style | |
span | style | |
strong | style | |
u | style | |
ul | style | bullet glyphs only |
Comparison chart
In order to check the appearance of the HTML text displayed by the tk_html_widgets, I made some HTML templates and I compared the text displayed by the HTMLText widget with the text displayed by Firefox and the PyQt5 QTextBrowser widget. See details and templates HTML code in the examples folder.
Tags template comparison:
Firefox | tk_html_widgets.HTMLText | PyQt5.QtWidgets.QTextBrowser |
---|---|---|
Styles template comparison:
Firefox | tk_html_widgets.HTMLText | PyQt5.QtWidgets.QTextBrowser |
---|---|---|
Images template comparison:
Firefox | tk_html_widgets.HTMLText | PyQt5.QtWidgets.QTextBrowser |
---|---|---|
Acknowledgements
Thanks to my mentor and valued collegue Gianluca: a light in the darkness of code
.
Project details
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
File details
Details for the file tk_html_widgets-0.2.0.tar.gz
.
File metadata
- Download URL: tk_html_widgets-0.2.0.tar.gz
- Upload date:
- Size: 9.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.2 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.5.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0fba29fedb66d499c10cedeaedfc777476618cf6da13a7d88e7e3364eaad24be |
|
MD5 | 3b24c6014257b9d820903dd205cab44b |
|
BLAKE2b-256 | 7fae26c900c47463152969d39693bb10f8bc1697ba3b3316649b9d1305151871 |
File details
Details for the file tk_html_widgets-0.2.0-py3-none-any.whl
.
File metadata
- Download URL: tk_html_widgets-0.2.0-py3-none-any.whl
- Upload date:
- Size: 9.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.2 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.5.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b2a28d68f487f205981e27aaa44228ad3b5592829da85fc2df02b1f9c7980513 |
|
MD5 | 86bc7405e83b264d35baa1ff37b51593 |
|
BLAKE2b-256 | f8792b974836afd681846d6d2cf8bce6504bb269815e68128f9e324778c3c3bb |