JulesTk
A simple MVC Framework for Tkinter in Python
Install / Use
/learn @ajongbloets/JulesTkREADME
======== Jules-tk
A small MVC Framework for Tkinter.
The model is Thread-safe, but since Tk is not thread safe, the view and controllers are not thread-safe. In threaded applications; use different threads to update the model and run a polling (using view.after) to update the view.
Look at the examples for small showcases on how to use julesTk.
Design structure
MVC: Model-View-Controller, is a well-known and wide practiced design paradigm for designing Graphical User Interfaces (GUI's). Using a MVC approach makes writing complex applications easier as software with this approach is more modular.
Tkinter: The default GUI framework of python. Although not the most beautiful around it does not require (complex) dependencies and is therefore very portable.
Application
Main controller responsible for configuring the application and managing the mainloop. Keeps track of all controllers loaded in the application.
The Controller
A Controller serves as the logic hub of the application and as a bridge between a view and model. It is important to understand that julesTk drives on a strict one-to-one relation between controller and view!
The View
- Frame: Non-interacting Frame widget.
- View: interacting, requires a controller.
- ViewSet: combine multiple views into one window.
The Model
Models store and manipulate data contained by the application. They also serve as a gateway in multi-threaded applications: Meaning, multiple threads can share information via the Model. One could - for example - use threads to manipulate the Model, while the View and Controller are updated in the MainThread using the Model.
Observer and Observable
The observer-observable paradigm enables objects to notify other objects upon an important change.
Models are by default observable, but Controllers need to inherit the Observer class.
See the click_me example for a demonstration of this paradigm.
Be aware that this paradigm is not easy to implement in multi-threaded applications. In those cases it may be better to use a polling mechanism in the MainThread to periodically update the View.
Application flow
- app.py, calls a controller
- controller loads model
- controller loads view
- app.py enters mainloop
- app.py exits mainloop
- app.py asks controllers to stop
- controller asks view to stop
While in the main loop
- view receives user input
- view calls controller
- controller handles input - acts on model
- controller handles update - acts on view
Modals
Basic functionality for modal window have been implemented. These windows allow to block input to any other window than the modal window. This allows for the creation of Dialogs (such as alert boxes, question boxes or progress dialogs). A basic implementation of these dialog is made in the utils subpackage.
Modal windows can be used with a MVC approach but also in a quick and dirty view-only manner. This latter is suitable for simple dialogs.
Plotting
Basic plotting is implemented using matplotlib with the plot.Plot Widget.
See the random_plot example for a demonstration.
Future plans
- Support events
- Implement validating models/variables for dialogs (or other widgets)
Related Skills
node-connect
343.1kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
frontend-design
90.0kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
openai-whisper-api
343.1kTranscribe audio via OpenAI Audio Transcriptions API (Whisper).
qqbot-media
343.1kQQBot 富媒体收发能力。使用 <qqmedia> 标签,系统根据文件扩展名自动识别类型(图片/语音/视频/文件)。
