Skip to main content

Lightweight And Full Featured Browser Based UI / GUI (Graphical User Interface Library)

Project description

# DicksonUI - The Best GUI Library For Python

With DicksonUI, you can make Graphical User Interfaces with python with just few lines of code. DicksonUI is super easy to use and handles everything for you. Just write your code easily or import any HTML code.

## Overview The DicksonUI Python GUI Library was written with lightweight use in mind. It provides the following key features - lightweight - Cross-Platform(Windows, Linux, Mac) - No Runtime Installer(Runtime is Browser) - Low Ram Usage(less on your script, all used by browser) - full featured(All features of html,css,js) - browser based(Any device has s browser installed) - powerful(power of bootstrap/AngularJS/React Coming Soon) - Extensible(write your own plugin and share) - HTML support - not just web pages - with js, css or any library(eg :-bootstap). - The most common Controls (Text, Links, Paragraphs or Headings(6 sizes)) are already implemented - Events - with wide range of event data(all event is handling in own thread so no errors)

## Usage

In the following paragraphs, I am going to describe how you can get and use DicksonUI for your own projects.

### Getting it To download dicksonui, either fork this Github repo or simply use Pypi via pip. DicksonUI is available on python 2 and 3 both. Dosen”t require Additional dependencies `sh $ pip install dicksonui ` If you use easy_install, easy_install browsergui. If you don’t like package managers, just download from Github and unzip and put the browsergui folder anywhere on your Python path.

## Initialize a Window First, let’s create a new Application.

`Python from dicksonui import Form, Application Myform = Form() App = Aplication() App.Add(Myform) print(App.location) `

#### Run!!! Run your code. For Python 3 `sh python3 myscript.py ` Or, For Python 2 `sh python myscript.py ` This will print a link http://localhost:<port>

Run your favorite browser `sh chromium-browser ` And then navigate to above link. 😥😥😥 Nothing!!!but a blank page.

#### Add items to form Okay, now that we will learn about Controls

`Python from dicksonui import Form, Application, Controls MyHeading = Controls.heading(1) Heading.innerHTML = """Hello world! bye!""" Myform = Form() Myform.Add(MyHeading) App = Aplication() App.Add(Myform) print(App.location) ` Run it View wiki for more info

## alternatives?

-[RemI](https://github.com/dddomodossola/remi), which has exactly the same idea (build a GUI in Python, run it in a browser). Definitely worth a look.It is little heavy an use websockets. So it cannot run on older browsers. Instead we use Ajax long polling which is used by facebook.

-[tkinter](https://docs.python.org/3/library/tkinter.html#module-tkinter) (standard library)

Advantages: it’s well-known. Lots of people have written tutorials and documentation for it.

Disadvantages: it feels like a wrapper around Tk, because it is. This gives good performance and detailed control, but writing it feels unintuitive (to me). Also, I’ve had trouble getting it to work with multiple Python installations. it isnt based on browsers and have limited features.

-[flexx](https://github.com/zoofIO/flexx) is very large and had more dependencies, it use tornado server. but we use our own few lines.limited features! and you can easily mix server-side and client-side

-eel is an alternative for Electron but it is based on bottle server. and it is not a pythonic way.

##Ok until next time, Bye!

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

DicksonUI-1.1.1.tar.gz (13.8 kB view details)

Uploaded Source

Built Distributions

DicksonUI-1.1.1-py3.7.egg (30.5 kB view details)

Uploaded Source

DicksonUI-1.1.1-py3-none-any.whl (16.3 kB view details)

Uploaded Python 3

File details

Details for the file DicksonUI-1.1.1.tar.gz.

File metadata

  • Download URL: DicksonUI-1.1.1.tar.gz
  • Upload date:
  • Size: 13.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/47.1.1 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.7.3

File hashes

Hashes for DicksonUI-1.1.1.tar.gz
Algorithm Hash digest
SHA256 564ff6ac24e0e7581c0db0c8fa0c05b75edd1f6ee29b629f0ab2bf88fea37214
MD5 7a48b231a6692a69606c256979ac0213
BLAKE2b-256 ee8af6df13cd7ef3d29395229e71d9b98d88426dc85137644d9cd41bcd08b918

See more details on using hashes here.

File details

Details for the file DicksonUI-1.1.1-py3.7.egg.

File metadata

  • Download URL: DicksonUI-1.1.1-py3.7.egg
  • Upload date:
  • Size: 30.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/47.1.1 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.7.3

File hashes

Hashes for DicksonUI-1.1.1-py3.7.egg
Algorithm Hash digest
SHA256 29666a5568c3cae866177be86c770c4f62d6c53c1ecb7a02f3298803af9ec8bc
MD5 6d0f02ff52071a439db24adea13b6558
BLAKE2b-256 870666aa7ab7acedadd19ae61797982b7e03c364ad7978dbc699134b71cfdc64

See more details on using hashes here.

File details

Details for the file DicksonUI-1.1.1-py3-none-any.whl.

File metadata

  • Download URL: DicksonUI-1.1.1-py3-none-any.whl
  • Upload date:
  • Size: 16.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/47.1.1 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.7.3

File hashes

Hashes for DicksonUI-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e2fd4e674cebf7b692e83977434738a39b81ccf446dde21cdf33b8f4cca728be
MD5 185b6dc7da2b6244ec4a22e8e486cdf9
BLAKE2b-256 bd1752886ecc6750d1242e91c09da24f0a2b0a0ba173f0f4aa7c35ace6c80b9d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page