Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
Tkinter GUI Application Development Blueprints, Second Edition
Tkinter GUI Application Development Blueprints, Second Edition

Tkinter GUI Application Development Blueprints, Second Edition: Build nine projects by working with widgets, geometry management, event handling, and more , Second Edition

eBook
£7.99 £32.99
Paperback
£41.99
Subscription
Free Trial
Renews at £16.99p/m

What do you get with eBook?

Product feature icon Instant access to your Digital eBook purchase
Product feature icon Download this book in EPUB and PDF formats
Product feature icon Access this title in our online reader with advanced features
Product feature icon DRM FREE - Read whenever, wherever and however you want
OR
Modal Close icon
Payment Processing...
tick Completed

Billing Address

Table of content icon View table of contents Preview book icon Preview Book

Tkinter GUI Application Development Blueprints, Second Edition

Making a Text Editor

We got a fairly high-level overview of Tkinter in Chapter 1, Meet Tkinter. Now that we know some things about Tkinter's core widgets, geometry management, and the binding of commands and events to callbacks, let's use our skills in this project to create a text editor.

We will, in the process of creating a text editor, take a closer look at some widgets and learn how to tweak them to meet our specific needs.

The following are the key objectives for this project:

  • Delving into some commonly used widgets, such as the Menu, Menubutton, Text, Entry, Checkbutton, and Button widgets
  • Exploring the filedialog and messagebox modules of Tkinter
  • Learning the vital concepts of indexing and tagging, as applied to Tkinter
  • Identifying the different types of Toplevel windows

Project overview

The goal here is to build a text editor with some nifty features. Let's call it the Footprint Editor:

We intend to include the following features in the text editor:

  • Creating new documents, opening and editing existing documents, and saving documents
  • Implementing common editing options such as cut, copy, paste, undo, and redo
  • Searching within a file for a given search term
  • Implementing line numbering and the ability to show/hide line numbers
  • Implementing theme selection to let a user choose custom color themes for the editor
  • Implementing the about and help windows

Getting started – setting up the editor skeleton

Our first goal is to implement the broad visual elements of the text editor. As programmers, we have all used text editors to edit code. We are mostly aware of the common GUI elements of a text editor. So, without further ado, let's get started.

The first phase implements the Menu, Menubutton, Label, Button, Text, and Scrollbar widgets. Although we'll cover all of these in detail, you might find it helpful to look at the widget-specific options in the documentation of Tkinter maintained by its author, Frederick Lundh, at http://effbot.org/tkinterbook/. You can also use the interactive shell, as discussed in Chapter 1, Meet Tkinter.

You might also want to bookmark the official documentation page of Tcl/Tk at http://www.tcl.tk/man/tcl8.6/TkCmd/contents.htm. This site includes the original Tcl/Tk reference. While it...

Adding a menu and menu items

Menus offer a very compact way of presenting a large number of choices to the user without cluttering the interface. Tkinter offers the following two widgets to handle menus:

  • Menu widget: This appears at the top of applications, which is always visible to end users
  • Menu items: These show up when a user clicks on a menu

We will use the following code to add Toplevel menu buttons:

my_menu = Menu(parent, **options)

For example, to add a File menu, we will use the following code:

# Adding Menubar in the widget
menu_bar = Menu(root)
file_menu = Menu(menu_bar, tearoff=0)
# all file menu-items will be added here next
menu_bar.add_cascade(label='File', menu=file_menu)
root.config(menu=menu_bar)

The following screenshot is the result of the preceding code (2.01.py):

Similarly, we will add the Edit, View, and About menus (2.01.py).

We will also define...

Implementing the View menu

Tkinter offers the following three varieties of menu item:

  • Checkbutton menu items: These let you make a yes/no choice by checking/unchecking the menu item
  • Radiobutton menu items: These let you choose an option from many different options
  • Cascade menu items: These menu items only open up to show another list of choices

The following View menu shows these three menu item types in action:

The first three menu items in the View menu let users make a definite yes or no choice by checking or unchecking thems. These are examples of the Checkbutton menu.

The Themes menu item in the preceding screenshot is an example of a Cascade menu. Hovering over this Cascade menu simply opens another list of menu items. However, we can also bind a menu item by using the postcommand=callback option. This can be used to manage something just before bringing up the cascading...

Adding a built-in functionality

Tkinter's Text widget comes with some handy built-in functionalities to handle common text-related functions. Let's leverage these functionalities to implement some common features in the text editor.

Let's start by implementing the cut, copy, and paste features. We now have the editor GUI ready. If you open the program and play with the Text widget, you will see that you can perform basic functions such as cut, copy, and paste in the text area by using Ctrl + X, Ctrl + C, and Ctrl + V, respectively. All of these functions exist without us having to add a single line of code for these functionalities.

The Text widget clearly comes with these built-in events. Now, we simply want to connect these events to their respective menu items.

The documentation of the Tcl/Tk universal widget methods tells us that we can trigger events without...

Indexing and tagging

Though we managed to leverage some built-in functionalities to gain a quick advantage, we need more control over the text area so that we can bend it to our will. This will require the ability to target each character or text location with precision.

We will need to know the exact position of each character, the cursor, or the selected area in order to do anything with the contents of the editor.

The Text widget offers us the ability to manipulate its content using index, tags, and mark, which let us target a position or place within the text area for manipulation.

Index

Indexing helps you target a particular place within a piece of text. For example, if you want to mark a particular word in bold, red...

Implementing the Select All feature

We know that Tkinter has a built-in sel tag that applies a selection to a given text range. We want to apply this tag to the entire text in the widget.

We can simply define a function to handle this, as follows (2.05.py):

def select_all(event=None):
content_text.tag_add('sel', '1.0', 'end')
return "break"

After doing this, add a callback to the Select All menu item:

edit_menu.add_command(label='Select All', underline=7, accelerator='Ctrl+A', command=select_all)

We also need to bind the function to the Ctrl + A keyboard shortcut. We do this by using the following key bindings (2.05.py):

content_text.bind('<Control-A>', select_all)
content_text.bind('<Control-a>', select_all)

The coding of the Select All feature is complete. To try it out, add some text...

Implementing the Find Text feature

Next, let's code the Find Text feature (2.05.py). The following screenshot shows an example of the Find Text feature:

Here's a quick summary of the desired functionality. When a user clicks on the Find menu item, a new Toplevel window opens up. The user enters a search keyword and specifies whether the search needs to be case-sensitive. When the user clicks on the Find All button, all matches are highlighted.

To search through the document, we rely on the text_widget.search() method. The search method takes in the following arguments:

search(pattern, startindex, stopindex=None, forwards=None, backwards=None, exact=None, regexp=None, nocase=None, count=None)

For the editor, define a function called find_text and attach it as a callback to the Find menu (2.05.py):

edit_menu.add_command(label='Find',underline= 0, accelerator...

Types of Toplevel window

Previously in this chapter, we used the following line of code:

search_toplevel.transient(root)

Let's explore what it means here. Tkinter supports the following four types of Toplevel window:

  • The main Toplevel window: This is the type we have been constructing so far.
  • The child Toplevel window: This type is independent of the root. The Toplevel child behaves independently of its root, but it gets destroyed if its parent is destroyed.
  • The transient Toplevel window: This always appears at the top of its parent, but it does not entirely grab the focus. Clicking again on the parent window allows you to interact with it. The transient window is hidden when the parent is minimized, and it is destroyed if the parent is destroyed. Compare this to what is called a modal window. A modal window grabs all the focus from the parent window and asks a user to first...

Working with forms and dialogs

The goal for this iteration is to implement the functionality of the File menu options: Open, Save, and Save As.

We can implement these dialogs by using the standard Tkinter widgets. However, since these are so commonly used, a specific Tkinter module called filedialog has been included in the standard Tkinter distribution.

Here's an example of a typical filedialog:

Tkinter defines the following common use cases for filedialogs:

Functions Description
askopenfile This returns the opened file object
askopenfilename This returns the filename string, not the opened file object
askopenfilenames This returns a list of filenames
askopenfiles This returns a list of open file objects or an empty list if
Cancel is selected
asksaveasfile This asks for a filename to save as and returns the opened
file object
asksaveasfilename This asks for...

Working with message boxes

Now, let's complete the code for the About and Help menus. The functionality is simple. When a user clicks on the Help or About menu, a message window pops up and waits for the user to respond by clicking on a button. Though we can easily code new Toplevel windows to show the About and Help messages, we will instead use a module called messagebox to achieve this functionality.

The messagebox module provides ready-made message boxes to display a wide variety of messages in applications. The functions available through this module include showinfo, showwarning, showerror, askquestion, askokcancel, askyesno, askyesnocancel, and askretrycancel, as shown in the following screenshot:

To use this module, we simply import it into the current namespace by using the following command:

import tkinter.messagebox 

A demonstration of the commonly used functions...

The icons toolbar and View menu functions

In this iteration, we will add the following functionalities to the text editor:

  • Showing shortcut icons on the toolbar
  • Displaying line numbers
  • Highlighting the current line
  • Changing the color theme of the editor

Let's start with a simple task first. In this step, we will add shortcut icons to the toolbar, as shown in the following screenshot:

You may recall that we have already created a frame to hold these icons. Let's add these icons now.

While adding these icons, we have followed a convention. The icons have been named exactly the same as the corresponding function that handles them. Following this convention has enabled us to loop through a list, simultaneously apply the icon image to each button, and add the command callback from within the loop. All the icons have been placed in the icons folder.

The following code adds...

Displaying line numbers

Let's work toward showing line numbers to the left of the Text widget. This will require us to tweak the code in various places. So, before we start coding, let's look at what we are trying to achieve.

The View menu has a menu item that allows users to choose whether to Show Line Number. We only want to show line numbers if the option is selected, as shown in the following screenshot:

If the option is selected, we need to display line numbers in the left frame that we created earlier.

The line number should update every time a user enters a new line, deletes a line, cuts or pastes line text, performs an undo or a redo operation, opens an existing file, or clicks on the New menu item. In short, the line number should be updated after every activity results in a change of content. Therefore, we need to define a function called on_content_changed...

Adding the cursor information bar

The cursor information bar is simply a small label at the bottom-right corner of the Text widget that displays the current position of the cursor, as shown in the following screenshot:

The user can choose to show/hide this info bar from the View menu (2.11.py).

Begin by creating a Label widget within the Text widget and pack it in the bottom-right corner, as follows:

cursor_info_bar = Label(content_text, text='Line: 1 | Column: 1')
cursor_info_bar.pack(expand=NO, fill=None, side=RIGHT, anchor='se')

In many ways, this is similar to displaying line numbers. Here, too, the positions must be calculated after every keystroke, after events such as cut, paste, undo, redo, new, and open, or activities that lead to a change in cursor positions. Because this too needs to be updated for all the changed content, for every keystroke, we...

Adding themes

You may recall that, while defining the Themes menu, we defined a color scheme dictionary containing the name and hexadecimal color codes as a key-value pair, as follows:

color_schemes = {
'Default': '#000000.#FFFFFF',
'Greygarious':'#83406A.#D1D4D1',
'Aquamarine': '#5B8340.#D1E7E0',
'Bold Beige': '#4B4620.#FFF0E1',
'Cobalt Blue':'#ffffBB.#3333aa',
'Olive Green': '#D1E7E0.#5B8340',
'Night Mode': '#FFFFFF.#000000',
}

The theme choice menu has already been defined. Let's add a callback command to handle the selected menu (2.12.py):

themes_menu.add_radiobutton(label=k, variable=theme_choice, command=change_theme).

Finally, let's define the change_theme function to handle the changing of themes, as follows:

def change_theme(event...

Creating a context/pop-up menu

Let's complete the editor in this final iteration by adding a contextual menu to the editor (2.12.py), as shown in the following screenshot:

The menu that pops up on a right-click at the location of the cursor is called the context menu or the pop-up menu.

Let's code this feature in the text editor. First, define the context menu, as follows:

popup_menu = Menu(content_text)
for i in ('cut', 'copy', 'paste', 'undo', 'redo'):
cmd = eval(i)
popup_menu.add_command(label=i, compound='left', command=cmd)
popup_menu.add_separator()
popup_menu.add_command(label='Select All',underline=7, command=select_all)

Then, bind the right-click of a mouse with a callback named show_popup_menu, as follows:

content_text.bind('<Button-3>', show_popup_menu)

Finally...

Summary

In this chapter, we covered the following points:

  • We completed coding the editor in twelve iterations. We started by placing all the widgets on the Toplevel window.
  • We then leveraged some built-in features of the Text widget to code some functionality.
  • We learned the important concepts of indexing and tagging.
  • We also saw how to use the filedialog and messagebox modules to quickly code some common features in programs.

Congratulations! You completed coding your text editor. In the next chapter, we will make a programmable drum machine.

QA section

Here are a few questions to reflect upon:

  • What's the difference between the Checkbutton menu item and the Radio button menu item?
  • What's the Cascade menu button used for?
  • Identify different kinds of Toplevel window.
  • List the different types of filedialogs and message boxes available in Tkinter.
  • We used the pack geometry manager to build this text editor. Could we have built this using the grid geometry manager? How would the grid geometry manager fare against pack?
  • How can we trigger events without an external stimulus in Tkinter?
  • What are accelerator options in menu items?
  • What is a transient window?

Further reading

The source code for the filedialog module can be found within the Tkinter source code in a separate file named filedialog.py. You are encouraged to take a look at its implementation.

If you are feeling adventurous and want to further explore the Text Editor program, I encourage you to have a look at the source code for Python's built-in editor named IDLE, which is written in Tkinter. The source code for IDLE can be found in your local Python library directory in a folder called idlelib. On Linux Mint, this is located at /usr/lib/python3.4/idlelib.

Read the official Python styling guide, which is specified in the PEP8 documentation at https://www.python.org/dev/peps/pep-0008.

If you like, try to implement syntax highlighting of Python code in the text editor. A naive implementation would first involve defining a list of keywords. Then we can bind the <KeyRelease...

Left arrow icon Right arrow icon
Download code icon Download Code

Key benefits

  • A Practical, guide to learn the application of Python and GUI programming with tkinter
  • Create multiple cross-platform real-world projects by integrating host of third party libraries and tools
  • Learn to build beautiful and highly interactive user interfaces, targeting multiple devices.

Description

Tkinter is the built-in GUI package that comes with standard Python distributions. It is a cross-platform package, which means you build once and deploy everywhere. It is simple to use and intuitive in nature, making it suitable for programmers and non-programmers alike. This book will help you master the art of GUI programming. It delivers the bigger picture of GUI programming by building real-world, productive, and fun applications such as a text editor, drum machine, game of chess, audio player, drawing application, piano tutor, chat application, screen saver, port scanner, and much more. In every project, you will build on the skills acquired in the previous project and gain more expertise. You will learn to write multithreaded programs, network programs, database-driven programs, asyncio based programming and more. You will also get to know the modern best practices involved in writing GUI apps. With its rich source of sample code, you can build upon the knowledge gained with this book and use it in your own projects in the discipline of your choice.

Who is this book for?

This book is for a beginner to intermediate-level Pythonists who want to build modern, cross-platform GUI applications with the amazingly powerful Tkinter. Prior knowledge of Tkinter is required.

What you will learn

  • -A Practical, guide to help you learn the application of Python and GUI programming with Tkinter
  • - Create multiple, cross-platform, real-world projects by integrating a host of third-party libraries and tools
  • - Learn to build beautiful and highly interactive user interfaces, targeting multiple devices.

Product Details

Country selected
Publication date, Length, Edition, Language, ISBN-13
Publication date : Mar 20, 2018
Length: 422 pages
Edition : 2nd
Language : English
ISBN-13 : 9781788834452
Category :
Languages :
Tools :

What do you get with eBook?

Product feature icon Instant access to your Digital eBook purchase
Product feature icon Download this book in EPUB and PDF formats
Product feature icon Access this title in our online reader with advanced features
Product feature icon DRM FREE - Read whenever, wherever and however you want
OR
Modal Close icon
Payment Processing...
tick Completed

Billing Address

Product Details

Publication date : Mar 20, 2018
Length: 422 pages
Edition : 2nd
Language : English
ISBN-13 : 9781788834452
Category :
Languages :
Tools :

Packt Subscriptions

See our plans and pricing
Modal Close icon
£16.99 billed monthly
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Simple pricing, no contract
£169.99 billed annually
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just £5 each
Feature tick icon Exclusive print discounts
£234.99 billed in 18 months
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just £5 each
Feature tick icon Exclusive print discounts

Frequently bought together


Stars icon
Total £ 116.97
Tkinter GUI Programming by Example
£41.99
Tkinter GUI Application Development Cookbook
£32.99
Tkinter GUI Application Development Blueprints, Second Edition
£41.99
Total £ 116.97 Stars icon
Banner background image

Table of Contents

11 Chapters
Meet Tkinter Chevron down icon Chevron up icon
Making a Text Editor Chevron down icon Chevron up icon
Programmable Drum Machine Chevron down icon Chevron up icon
Game of Chess Chevron down icon Chevron up icon
Building an Audio Player Chevron down icon Chevron up icon
Paint Application Chevron down icon Chevron up icon
Piano Tutor Chevron down icon Chevron up icon
Fun with Canvas Chevron down icon Chevron up icon
Multiple Fun Projects Chevron down icon Chevron up icon
Miscellaneous Tips Chevron down icon Chevron up icon
Other Books You May Enjoy Chevron down icon Chevron up icon

Customer reviews

Rating distribution
Full star icon Full star icon Full star icon Full star icon Empty star icon 4
(5 Ratings)
5 star 60%
4 star 20%
3 star 0%
2 star 0%
1 star 20%
Simon Jul 20, 2021
Full star icon Full star icon Full star icon Full star icon Full star icon 5
So far I have found this book first class, & well laid out. It it give worthy while explanations. Wothy paying for. True you will need to wait for Packet to email you the downloads but, so what
Amazon Verified review Amazon
Mr C. Nov 13, 2020
Full star icon Full star icon Full star icon Full star icon Full star icon 5
On chapter 3 at the moment. A good, well written, easy to follow, tutorial book. Not for the beginner, but as a next step, it fills the gaps in knowledge well.
Amazon Verified review Amazon
D. R. Crawford Dec 15, 2020
Full star icon Full star icon Full star icon Full star icon Full star icon 5
I haven't even bought this book yet, but ALREADY it has fixed a problem with Tkinter for me. I was trying to change the color of text in a Label widget, but I couldn't find any way to do it no matter what I tried, and furthermore NO ONE could tell me how to do it, NO ONE. Oh, there was LOTS of advice, with "working" code examples, NONE of which worked. Finally, I just happened to skim through the "Look Inside" for this book, and LO AND BEHOLD, the author explains simply and concisely, what I was doing wrong and how to do it correctly. Admittedly I'm a beginner with Tkinter and Python itself, but still, no one could tell me what was wrong until I found this book.
Amazon Verified review Amazon
Pete Jan 06, 2024
Full star icon Full star icon Full star icon Full star icon Empty star icon 4
The kindle version is a reasonable price but the paper one is overpriced imho. Takes you stepwise through tkinter functionality with explanations. With the source download you can play around with every example. It's good to have a unified source of information but I still need to Google specific questions. There are a variety of applications, again built stepwise. I have not had time yet to look deeply into these but I believe dipping into them shows you how to do more. I do have a minor criticism that there is a lot of time spent using the 'pack' geometry manager and then immediately after and in one exercise only the author says you should better use 'grid'. My experiments show that tkinter does not allow you to mix these two methods. Perhaps it would have been better from the very start to use grid? Overall glad I bought it but don't ignore video channels like codemy...
Amazon Verified review Amazon
Dr. Marilou Haines Apr 17, 2021
Full star icon Empty star icon Empty star icon Empty star icon Empty star icon 1
Bought this book from Amazon. Although I am a registered customer from the PacktPub publisher, I am unable to download, or even request that they send me the example code files.I can access their website with my credentials and browse through it. However, when I try to send a message to customer service that their instructions are not working for me , I get a response that my CREDENTIALS COULD BE AUTHENTICATED. Other buyers are complaining that is publisher is unethical. If I don't get the example files I will file a complaint against them with Amazon. Thank you.
Amazon Verified review Amazon
Get free access to Packt library with over 7500+ books and video courses for 7 days!
Start Free Trial

FAQs

How do I buy and download an eBook? Chevron down icon Chevron up icon

Where there is an eBook version of a title available, you can buy it from the book details for that title. Add either the standalone eBook or the eBook and print book bundle to your shopping cart. Your eBook will show in your cart as a product on its own. After completing checkout and payment in the normal way, you will receive your receipt on the screen containing a link to a personalised PDF download file. This link will remain active for 30 days. You can download backup copies of the file by logging in to your account at any time.

If you already have Adobe reader installed, then clicking on the link will download and open the PDF file directly. If you don't, then save the PDF file on your machine and download the Reader to view it.

Please Note: Packt eBooks are non-returnable and non-refundable.

Packt eBook and Licensing When you buy an eBook from Packt Publishing, completing your purchase means you accept the terms of our licence agreement. Please read the full text of the agreement. In it we have tried to balance the need for the ebook to be usable for you the reader with our needs to protect the rights of us as Publishers and of our authors. In summary, the agreement says:

  • You may make copies of your eBook for your own use onto any machine
  • You may not pass copies of the eBook on to anyone else
How can I make a purchase on your website? Chevron down icon Chevron up icon

If you want to purchase a video course, eBook or Bundle (Print+eBook) please follow below steps:

  1. Register on our website using your email address and the password.
  2. Search for the title by name or ISBN using the search option.
  3. Select the title you want to purchase.
  4. Choose the format you wish to purchase the title in; if you order the Print Book, you get a free eBook copy of the same title. 
  5. Proceed with the checkout process (payment to be made using Credit Card, Debit Cart, or PayPal)
Where can I access support around an eBook? Chevron down icon Chevron up icon
  • If you experience a problem with using or installing Adobe Reader, the contact Adobe directly.
  • To view the errata for the book, see www.packtpub.com/support and view the pages for the title you have.
  • To view your account details or to download a new copy of the book go to www.packtpub.com/account
  • To contact us directly if a problem is not resolved, use www.packtpub.com/contact-us
What eBook formats do Packt support? Chevron down icon Chevron up icon

Our eBooks are currently available in a variety of formats such as PDF and ePubs. In the future, this may well change with trends and development in technology, but please note that our PDFs are not Adobe eBook Reader format, which has greater restrictions on security.

You will need to use Adobe Reader v9 or later in order to read Packt's PDF eBooks.

What are the benefits of eBooks? Chevron down icon Chevron up icon
  • You can get the information you need immediately
  • You can easily take them with you on a laptop
  • You can download them an unlimited number of times
  • You can print them out
  • They are copy-paste enabled
  • They are searchable
  • There is no password protection
  • They are lower price than print
  • They save resources and space
What is an eBook? Chevron down icon Chevron up icon

Packt eBooks are a complete electronic version of the print edition, available in PDF and ePub formats. Every piece of content down to the page numbering is the same. Because we save the costs of printing and shipping the book to you, we are able to offer eBooks at a lower cost than print editions.

When you have purchased an eBook, simply login to your account and click on the link in Your Download Area. We recommend you saving the file to your hard drive before opening it.

For optimal viewing of our eBooks, we recommend you download and install the free Adobe Reader version 9.